解压filename.tar.xz文件
xz -d解压成filename.tar文件. -z为压缩
tar -xvf 解压成源文件 -C表示解压到指定目录
redis-cli keys rActivity*|xargs redis-cli del
https://dev.mysql.com/doc/mysql-yum-repo-quick-guide/en/
如果指定了gpgcheck=1则要设置gpgkey路径
wget http://repo.mysql.com/RPM-GPG-KEY-mysql -O /etc/pki/rpm-gpg/RPM-GPG-KEY-mysql
1.service mysqld start 启动失败
用/usr/bin/mysqld_safe (查看/etc/init.d/mysqld文件,可知执行文件位置)启动查看错误,
2.[ERROR] /usr/sbin/mysqld: Can't create/write to file '/usr/local/mysql/mysql.pid' (Errcode: 2 - No such file or directory)
创建目录:mkdir -p /usr/local/mysql
配置权限:chown mysql:mysql /usr/local/mysql
chmod 755 /usr/local/mysql
3.[ERROR] Can't find error-message file '/usr/local/mysql/share/mysql/errmsg.sys'. Check error-message file location and 'lc-messages-dir' configuration directive
4.mysqld_safe A mysqld process already exists
测试有mysqld进程在运行,也可以用service mysqld start可以启动
5.配置开机启动
chkconfig mysqld on
chkconfig --list mysqld
6.mysql初始化
如果提示没有file directory,则创建相应的目录
mysqld --initialize --basedir=/usr/local/mysql --datadir=/var/lib/mysql --user=mysql
--lc_messages_dir=/usr/local/mysql/share/mysql --lc_messages=en_US
配置/etc/my.cnf,在[mysqld]下面添加两行
skip-grant-tables
sql_mode='STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION'
登录mysql进入mysql数据库修改root密码Anthentication和Host设置为%,并执行set password=PASSWORD('密码'),全局生效,不然mysql5.7会报错,flush privileges设置完了后注释skip-grant-tables,重启服务
配置: ./configure --with-lua=/usr/local --with-lua-include=/usr/local/include
--with-lua是lua.h的目录,
gmake build&& gmake install
通过luaRocks下载包:如 luarocks install md5
1. yum install subversion #安装svn
2. groupadd svn #为运行svn设置专用的用户组,非必须操作,但推荐
3. useradd -d /var/svn -g svn svn #为运行svn设置专用的用户,同时指定home目录为:/var/svn 非必须操作,但推荐
4. passwd svn #为运行svn专用用户设置密码,非必须操作,但推荐
5. su -l svn #开始切换为svn用户进行后续操作6. mkdir -p /var/svn/default-repo #为即将创建的代码库建立一下文件夹
7. svnadmin create /var/svn/default-repo/ #建立代码库,/var/svn/default-repo/为代码库所在文件夹
8. cd /var/svn/default-repo/conf #进入新建立的代码库的 conf目录下,准备进行相关配置
9. vim svnserve.conf #设置认证相关的配置:svnserve -d -r /var/svn/default-repo/ #启动svn server (默认端口3690)注:同一台服务器可以运行多个svnserver,只需要启动时换一个端口即可:svnserve -d -r /var/svn/another-repo/ --listen-port 3691
svn info /data/www/poker |grep Revision|awk -F ':' '{print $2}'
http://www.fastadmin.net
$ yum -y install gcc gcc-c++ autoconf automake$ yum -y install zlib zlib-devel openssl openssl-devel pcre-devel$ sudo groupadd -r nginx$ sudo useradd -s /sbin/nologin -g nginx -r nginx-user
$ yum -y install nginx
php代理配置讲解nginx将会连接回环地址9000端口执行PHP文件,需要使用tcp/ip协议,速度比较慢.建议大家换成使用socket方式连将fastcgi_pass 127.0.0.1:9000;改成fastcgi_pass unix:/var/run/phpfpm.sock/usr/local/nginx-1.0.6/sbin/nginx -t/usr/local/nginx-1.0.6/sbin/nginx -s
ngx_auth_request 模块发起的“子请求”确实是与其“父请求”共享一套 Nginx 变量的值容器。ngx_echo,ngx_lua,以及 ngx_srcache 在内的许多第三方模块都选择了禁用父子请求间的变量共享。$request_method 变量即使在 GET “子请求” /sub 中使用,得到的值依然是“主请求” /main 的请求方法,POST.我们并不能通过标准的 $request_method 变量取得“子请求”的请求方法。为了达到我们最初的目的,我们需要求助于第三方模块 ngx_echo 提供的内建变量 $echo_request_methodngx_lua 模块proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;proxy_set_header remote_header_test "123123123";proxy_set_header Host $host:$server_port;proxy_set_header X-Real-IP $remote_addr;proxy_set_header X-Real-PORT $remote_port;proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;set_real_ip_from:真实服务器上一级代理的IP地址或者IP段,可以写多行real_ip_header:从哪个header头检索出要的IP地址real_ip_recursive:递归排除IP地址,ip串从右到左开始排除set_real_ip_from里面出现的IP,如果出现了未出现这些ip段的IP,那么这个IP将被认为是用户的IP在nginx中配置proxy_pass代理转发时,如果在proxy_pass后面的url加/,表示绝对根路径;如果没有/,表示相对路径,把匹配的路径部分也给代理走。nginx模块nginx-http-footer-filter研究使用------------------------nginx升级-------------------------3. 执行完后,这里不用在 make install 了,接下来重名/sbin/nginx为nginx.old# mv /usr/local/webserver/nginx/sbin/nginx /usr/local/webserver/nginx/sbin/nginx.old4. 复制编译后objs目录下的nginx文件到nginx的安装目录sbin/下# cp objs/nginx /usr/local/webserver/nginx/sbin/5. 测试一下新复制过来文件生效情况:# /usr/local/webserver/nginx/sbin/nginx -tnginx: the configuration file /usr/local/webserver/nginx/conf/nginx.conf syntax is oknginx: configuration file /usr/local/webserver/nginx/conf/nginx.conf test is successful6. 让nginx把nginx.pid文件修改成nginx.pid.oldbin,随即启动nginx,实现不间断# kill -USR2 `cat /usr/local/webserver/nginx/nginx.pid` 更新配置文件# kill -QUIT `cat /usr/local/webserver/nginx/nginx.pid.oldbin` 优雅的关闭
7.检验升级配置和之前是否一样
openssl sha1 /usr/sbin/nginx
openssl sha1 /usr/sbin/nginx_bak
1.逻辑核数:cat /proc/cpuinfo | grep "processor" | wc -l
2.系统CPU的物理核数: cat /proc/cpuinfo |grep "cpu cores"|uniq
详细参考:http://blog.csdn.net/wswit/article/details/52665413
10.mysql导入导出数据
select * from point_reports_1 where MOD(page_no,2) = 1 into outfile "/var/lib/mysql-files/fromtable_2.txt";如果出现安全方面的错误提示,show variables like '%secure_file_priv%';开启授权,/var/lib/mysql-files为导出授权目录load data infile "/var/lib/mysql-files/fromtable_2.txt" into table point_reports_0;
11.php
php://memory 和 php://temp 是一次性的,比如:stream 流关闭后,就无法再次得到以前的内容了。
If a $_POST is used with large fields e.g. textarea's with more than 120kb characters php returns a blank screen, even if the max_post_size is 8M.This problem may be caused by an apache-module SecFilter.Adding the following lines to the .htaccess solves the problem.SecFilterEngine OffSecFilterScanPOST Off
eval() 不能被禁用,因为是语言构造,不是函数open_basedir = "/var/www/htdocs/:/var/www/tmp/" adds both paths /var/www/htdocs/ and /var/www/tmp/. Do not forget the trailing slash, otherwise the last directory will be considered as a prefix (< 5.3.4).
allow_url_fopen = On 会影响file_get_contents访问url
ctrl+r 向前恢复 u 撤销(向后恢复)
umask 表示去掉的权限
date +%s
---------查看指定时间 -------
#date -d 2008-01-01 +%s
#date -d 20080101 +%s
---------获取七天前的日期--echo `date -d "7 day ago" +%Y%m%d`
echo "vagrant"|passwd --stdin vagrant
-d:删除密码,仅有系统管理者才能使用;
-f:强制执行;
-k:设置只有在密码过期失效后,方能更新;
-l:锁住密码;
-s:列出密码的相关信息,仅有系统管理者才能使用;
-u:解开已上锁的帐号。chage -l vbird2chage -d 0 agetest// 此时此账号癿密码建立时间会被改为 1970/1/1 ,所以会有问题!下次改用户登录强制更改密码,bash 的 login shell 情况下所读取的整体环境配置文件其实叧有 /etc/profile,
所读取癿个人偏好配置文件其实主要有三个,依序分别是:1. ~/.bash_profile2. ~/.bash_login3. ~/.profile
1. 标准输入 (stdin) :代码为 0 ,使用 < 或 << ;2. 标准输出 (stdout):代码为 1 ,使用 > 或 >> ;3. 标准错误输出(stderr):代码为 2 ,使用 2> 或 2>> ;
开机启动过程:BIOS,MBR,开机管理程序,操作系统核心档案window安装时,覆盖掉MBR,自己所在分割槽的启动扇区。linux安装时,可选择安装在MBR或者其他启动扇区,linux的loader可以手动设置选单,所以你可以在linux的bootloader里面加入windows的开机选项
我们可以利用 /etc/at.allow 不 /etc/at.deny 这两个档案来进行 at 癿使用限制呢! 加上这两个档案后, at 的工作情况其实是这样的:1. 先找寻 /etc/at.allow 这个档案,写在这个档案中癿使用者才能使用 at ,没有在这个档案中癿使用者则丌能使用 at (即使没有写在 at.deny 当中);2. 如果 /etc/at.allow 丌存在,就寻找 /etc/at.deny 这个档案,若写在这个 at.deny 癿使用者则丌能使用 at ,而没有在这个 at.deny 档案中癿使用者,就可以使用 at 咯;3. 如果两个档案都不存在,那么只有 root 可以使用 at 这个指令。
ps -aux|grep ver-dev|grep -v grep|awk '{print $2}'|xargs kill -9批量干死develop项目的poker进程
chkconfig --list [name]chkconfig --add namechkconfig --del namechkconfig [--level levels] name
Linux IPC消息队列是一个全内存设计,内核保证读写顺序和数据同步,并且性能非常强悍的先进现先出数据结构。它的特性如下:每秒可读写超过50万次(4核/4G内存的机器)支持消息多类型,抢队列时可根据需要获取特定的消息类型每个消息长度最大支持65535个字节,队列长度受内存大小限制,最大不超过机器内存的50%,可以修改内核参数来调整.
ngx_http_read_client_request_body 异步的,返回NGX_DONEngx_http_discard_request_body将来自客户端的HTTP包体丢弃,如果不接收发来的TCP流,有可能造成客户端发送超时ngx_http_send_header方法会首先调用所有的HTTP过滤模块共同处理headers_out中定义的HTTP响应头部全部处理完毕后才回序列化为TCP字节流发送到客户端ngx_http_output_filter方法即可向客户端发送HTTP响应包体,发送结束后HTTP框架会调用ngx_http_finalize_request方法结束请求http_rang_header_filter模块就是用来处理HTTP请求头部range部分的,ngx_cycle_t ngx_connection_t ngx_listening_t
dd if=/dev/zero of=/tmp/s.tmp bs=10M count=1
#!/bin/bash# chkconfig: - 85 15# description: Nginx server control script# processname: nginx# config file: /usr/local/nginx/conf/nginx.conf# pid file: /usr/local/nginx/logs/nginx.pid
关键是前三行是必须的
vagrant box add mybox box路径
初始化mybox的box:vagrant init mysql
vagrant up/halt/reload
vagrant destroy
vagrant ssh
打包:vagrant package --base vagrant_web_1513310482712_24913(虚拟机名称) --output lnmp.box
yum -y install dos2unix*
常见问题解决:http://blog.csdn.net/u012246178/article/details/63253531
1.查看/下所有文件夹大小:du -ah --max-depth=1 /
2.当我们在系统下运行某个程序出错的时候,系统会自动将残留在内存中的数据存成 core 文件
删除所有core文件(包含分号): find / -name core -print -exec rm -rf {} \;
3.Linux 提供了众多语言的手册页(man)比如 Ubuntu 的 手册页位于/usr/share/man 目录下 ,可以使用命令删除多余语言的手册页保留中英文即可
# cd /usr/share/man# find ./ -maxdepth 1 -type d | tail -n +2 | grep -E -v '(en|zh|man).*' | \
4.清理旧版本的软件缓存apt-get autoclean5.清理所有软件缓存:apt-get clean
6.在目录中查找更改时间在n日以前的文件并删除它们,一般用于日志文件类操作find . -type f -mtime +14 -exec rm {} \;
b打断点 c继续运行 d清除所有断点 r运行,忽视断点 s(step in) n(step out) p 打印变量
不同于其他语言的数组把 0 作为数组的初始索引,在 Lua 里表的默认初始索引一般以 1 开始。Lua 中的变量全是全局变量,那怕是语句块或是函数里,除非用 local 显式声明为局部变量。 3 print(type("hello")); 4 print("hello".." world") 5 print(23 .. 43) 6 function fun(a,callback) 7 result = {}; 8 result['a']=0; 9 result['b']=0; 10 for k,v in pairs(a) do 11 --result['a']+=k; 12 --result['b']+=v; 13 callback(k .. " " .. v); 14 end 15 return 0;--callback(result); 16 end 17 tab = {a=1,b=2} 18 print(type(tab)) 19 result = fun(tab,print); 20 -------a. 变量个数 > 值的个数 按变量个数补足nilb. 变量个数 < 值的个数 多余的值会被忽略控制结构的条件表达式结果可以是任何值,Lua认为false和nil为假,true和非nil为真。要注意的是Lua中 0 为 true:for i,val in ipairs索引迭代~= 不等于,检测两个值是否相等,相等返回 false,否则返回 true其他运算符 —— #在获取表的长度时,根据的是表的最大索引的值:首先,使用gg调整光标到首行,然后使用dG命令即可。string.gsub(mainString,findString,replaceString,num)返回替换后的字符串string.char(arg) 和 string.byte(arg[,int])char 将整型数字转成字符并连接, byte 转换字符为整数值(可以指定某个字符,默认第一个字符)。string.gmatch(str, pattern)返回一个迭代器函数,每一次调用这个函数,返回一个在字符串 str 找到的下一个符合 pattern 描述的子串。如果参数 pattern 描述的字符串没有找到,迭代函数返回nil。string.match(str, pattern, init)string.match()只寻找源字串str中的第一个配对返回前段非汉子字符串local a = "23245023496830,!~#$$%汉字。。。。"print(string.match(a,"[%w%s%p]+"))去掉汉子 local a = "我23245023496830,!~#$$%汉字。。。。"s,n=string.gsub(a,"[^%w%s%p]+","")--------------table 长度相关----在求table的长度的时候,当索引不连续的时候,#table返回的值不会太准确1、在table中不要使用nil2、如果非要使用nil,必须用table.setn()函数去设置这个table表的长度。注意:新版本的lua已经不支持setn了。必须给你个结论:setn函数已过时,不要在lua的table中使用nil值,如果一个元素要删除,直接remove,不要用nil去代替。-------------数组-------------逻辑结构是线性表多维数组即数组中包含数组或一维数组的索引键对应一个数组。---------------模块与包--------------执行 require 后会返回一个由模块常量或函数组成的 table,并且还会定义一个包含该 table 的全局变量。---------------迭代器-----------------------------元表----------------setmetatable(table,metatable): 对指定table设置元表(metatable),如果元表(metatable)中存在__metatable键值,setmetatable会失败 。getmetatable(table): 返回对象的元表(metatable)。__index访问__newindex 更新__newindex 元方法用来对表更新,__index则用来对表访问 。当你给表的一个缺少的索引赋值,解释器就会查找__newindex 元方法:如果存在则调用这个函数而不进行赋值操作。以下实例演示了 __newindex 元方法的应用:__call__tostring------------------协程----------------
查看执行文件所需要的动态链接库:ldd /usr/bin/mysql
如果缺失某些库文件,在添加了链接库后,需要ldconfig来生效
ldconfig是一个动态链接库管理命令,为了让动态链接库为系统所共享,还需运行动态链接库的管理命令--ldconfig。 ldconfig 命令的用途,主要是在默认搜寻目录(/lib和/usr/lib)以及动态库配置文件/etc/ld.so.conf内所列的目录下,搜索出可共享的动态链接库(格式如前介绍,lib*.so*),进而创建出动态装入程序(ld.so)所需的连接和缓存文件,缓存文件默认为 /etc/ld.so.cache,此文件保存已排好序的动态链接库名字列表。
linux下的共享库机制采用了类似于高速缓存的机制,将库信息保存在/etc/ld.so.cache里边,程序连接的时候首先从这个文件里边查找,然后再到ld.so.conf的路径里边去详细找,这就是为什么修改了ld.so.conf要重新运行一下ldconfig的原因。
33.jstree插件使用
php代码://注意children节点的id不能有重,必须唯一,返回格式参考官网
public function tree()
{
$id = request()->param('id');
//不变的
$provinceList = (new ActivityProvince())->select();
$str = model("ActivityCategory")->where(['id'=>$id])->field('channel_id_str')->find();
$channelList = json_decode($str['channel_id_str'],true);
$channelList = !$channelList?array():$channelList;
$allChannel = (new ActivityChannel())->getChannelList();
foreach($allChannel as $k=>$v)
{
$item=[];
$item['id'] = $v['id'];
$item['text'] = $v['channel_name'];
$item['state']=[
'opened' => false,
'selected' => false
];
$province = isset($channelList[$v['channel_id']])?$channelList[$v['channel_id']]:array();
$selected = 0;
foreach($provinceList as $k1=>$v1)
{
if(in_array($v1['pno'],$province))
{
$selected++;
$item['children'][] = ['text'=>$v1['name'],'icon'=>'fa fa-folder tree-item-icon-color icon-lg','id'=>"{$v['channel_id']}-{$v1['pno']}",'state'=>['selected'=>true ]];
}else{
$item['children'][] = ['text'=>$v1['name'],'icon'=>'fa fa-folder tree-item-icon-color icon-lg','id'=>"{$v['channel_id']}-{$v1['pno']}",'state'=>['selected'=>false]];
}
}
if($selected == count($provinceList))
{
$item['state']['selected'] = true;
}else{
// $item['state']['selected'] = false;
}
$result[] = $item;
}
return json($result);
}
js代码:主要是初始化input,列表变化时更新input
var url = location.href.substr(0,location.href.indexOf("?"));
var arr = url.split("/");
$('#province-container').jstree({
'core': {
'data': {
"url" : "/activity/activitycategory/tree",
"dataType" : "json", // needed only if you do not supply JSON headers
"data":{"id":arr[arr.length-1]}
},
"themes": {
"dots": true, // no connecting dots between dots
"responsive": false //无响应
},
'multiple': true //设置其为没有多选
},
//"checkbox": {
// "keep_selected_style": false
//},
'types': { //这里就是图片的显示格式
"default": {
"icon": "fa fa-folder tree-item-icon-color icon-lg"
},
"file": {
"icon": "fa fa-file tree-item-icon-color icon-lg"
}
},
'plugins': [ //插件,下面是插件的功能
'types', //可以设置其图标,在上面的一样。
'wholerow', //
'unique', //独特----防止重复。(新添加的)
'checkbox',
]
});
//绑ready事件 ,初始化
$('#province-container').bind("ready.jstree", function (obj, e) {
// 处理代码
var checkedNodes = $('#province-container').jstree("get_all_checked");//获取选中节点和半选中节点
var channel_id_str={};
for(var i=0;i
HTML:
34.nfs安装配置
nfs安装和配置
https://www.cnblogs.com/alonones/p/6105586.html
参数详情:
http://blog.csdn.net/nirenxiaoxiao/article/details/17711969
35.链表操作
https://www.cnblogs.com/sky0917/p/3527505.html
总结:删除节点实质是对数据的删除,解决问题(环,交点,长度)是可以设置多个指针来解决
36.SVN更新
U:表示从服务器收到文件更新了
G:表示本地文件以及服务器文件都已更新,而且成功的合并了
A:表示有文件或者目录添加到工作目录
R:表示文件或者目录被替换了.
C:表示文件的本地修改和服务器修改发生冲突
37.mysql性能优化主要相关参数
存储引擎,log,buffer,trx,网络如skip_name_resolve,磁盘IO同步相关配置,表分区数量配置
38.mysql压力测试
mysqlslap -a -c 20 -i 10 --auto-generate-sql-load-type=read --create-schema=mysqlslap --number-of-queries=20 --engine=myisam,innodb --only-print -uroot -proot
39.redis RDB和AOF的选择策略
http://blog.csdn.net/chenleixing/article/details/50530419
http://blog.csdn.net/canot/article/details/52886923
40.requirejs
详细文档:http://requirejs.org/docs/api.html
AMD规范:https://www.jianshu.com/p/9b44a1fa8a96
requirejs.onError()
独立模块:define定义的模块可以返回任何值,不限于对象,define(function(){ return {method:function(){}}}); define({});
非独立模块:define的回调函数必须返回一个对象,这个对象就是你定义的模块
-jsonp 请求------
响应必须是用define()包装,返回json
require(["http://example.com/api/data.json?callback=define"],
function (data) {
//The data object will be the API response for the
//JSONP data call.
console.log(data);
}
);
41.统计数量
awk '{count[$0]++;n++} END{for(i in count)print i "\t" count[i]; }' c.txt
42.测试一个请求的响应时间,总时间
curl -s -w '%{time_connect}:%{time_starttransfer}:%{time_total}\n' -H "Content-Type: application/json" -d 'post内容' --request POST http://xsddz-and-web1.woaiwanpai.com/month-task/get-list
42.redis性能测试
redis-benchmark -h 172.17.16.7 -c 1 -n 400 -q -t get
43.lsof 使用
lsof -i:22
lsof -i tcp
lsof -i udp
lsof -p pid
lsof -n -a -p pid
ls -t -u uname -p
只有多个查询条件都满足, 用 "-a" 参数,默认是 -o 。
lsof|grep -i delete看看被删除的文件:有些删了文件,但是进程没 reload,那些空间还是占用的,你可以理解为类似 windows 下的进程句柄没释放的概念吧~
lsof /dev/tty1
指定目录、挂载点,可以看到有哪些进程打开了其下的文件:
lsof /data/
这在 umount 某个文件系统失败时非常有用(通常会报该 FS is busy)。
44.strace
打印进程的系统调用:strace -p pid
45.查看指定端口的网络连接数
命令:netstat -atln | grep
46.php redis的pconnect连接深入分析
-http://blog.csdn.net/qmhball/article/details/46988111
1. 当使用pconnect时,连接会被重用,连接的生命周期是fpm进程的生命周期,而非一次php的执行。
2.如果代码中使用pconnect, close的作用仅是使当前php不能再进行redis请求,但无法真正关闭redis长连接,连接在后续请求中仍然会被重用,直至php-cli或php-fpm进程生命周期结束。
而在cli模式下,pconnect和connect是没有区别的,因为是常驻内存的
46.nginx 文件下载配置
autoindex on;
autoindex_exact_size off;
autoindex_localtime on;
47.------------------vagrant报错------
Vagrant assumes that this means the command failed!
ARPCHECK=no /sbin/ifup eth1 2> /dev/null
Stdout from the command:
Device eth1 does not seem to be present, delaying initialization.
Stderr from the command:
解决方案:sudo rm -f /etc/udev/rules.d/70-persistent-net.rules
在持久网络设备udev规则(persistent network device udev rules)是被原VM设置好的,再用box生成新VM时,这些rules需要被更新。而这和Vagrantfile里对新VM设置private network的指令发生冲突。删除就好了。
48.安装php kafka扩展和zookeeper扩展
http://blog.csdn.net/u013713010/article/details/68947679
http://www.huangxiaobai.com/archives/1437
zookeeper(无需编译)下载地址:http://mirror.bit.edu.cn/apache/zookeeper/zookeeper-3.4.10/zookeeper-3.4.10.tar.gz
zookeeper:统一命名服务,统一配置管理,集群管理,共享锁,队列管理
WARN util.NativeCodeLoader: Unable to load native-hadoop library for your platform... using builtin-java classes where applicable
Stopping namenodes ..
解决: file lib/native/libhadoop.so.1.0.0 ,发现是64位。 ~/.bashrc在这个文件里面添加变量
export HADOOP_HOME=/home/hadoop/hadoop-2.6.4(这个按需修改)
export HADOOP_COMMON_LIB_NATIVE_DIR=$HADOOP_HOME/lib/native
export HADOOP_OPTS="-Djava.library.path=$HADOOP_HOME/lib:$HADOOP_COMMON_LIB_NATIVE_DIR"
source ~/.bashrc
49.IPTABLES相关知识
http://www.zsythink.net/archives/1199
https://www.cnblogs.com/bill1015/p/6847841.html
端口转发在forward链
负载在PREROUTING 链
50.phpize
使用:/usr/bin/phpize
出现下面错误提示
Can't find PHP headers in /usr/include/php
The php-devel package is required for use of this command
yum install php-devel 解决
如果是php5.6版本,yum install -y php56w-devel
apc is not compatible with PHP 5.6, you should use opcache, xcache.
51.压缩
tar -zcvf /data/www/activity_task-`date +%Y-%m-%d`.tar.gz /data/www/activity_task/ --exclude=/data/www/activity_task/Runtime
52.检测文件类型
/usr/share/misc/magic.mgc 是包含linux支持的文件类型的数据库文件
file -b --mime-type -m /usr/share/misc/magic.mgc /vagrant/poker/tmp/simple.log
53.vagrant UUID already exist
G:\virtualbox>VBoxManage internalcommands sethduuid "G:\VirtualBox VMs\node11\resized.vmdk"
UUID changed to: 94438933-612a-4fcf-9771-8d02073c3656
53vagrant up时遇到ARPCHECK=no /sbin/ifup eth1 2> /dev/null问题,导致在ipconfig时内网ip未配置
解决方案:rm -rf /etc/udev/rules.d/70-persistent-net.rules
53.php protobuf相关文档
https://github.com/allegro/php-protobuf
注意由于需要生成的php类继承ProtobufMessage,但这个类在别的protobuf扩展中没有,所以需要编译它提供的扩展,
54.redis pipe命令行操作
echo -ne '*3\r\n$4\r\nsadd\r\n$6\r\nkey_id\r\n$3\r\nggg\r\n' |redis-cli --pipe