本文不是我写的。纯复制粘贴,主要我也只是准备做个笔记。
知其然要知其所以然,平时只是这么写习惯了,也没有去深究过,当然这次也不准备深究,只是先copy一下。
原文地址:http://www.cnblogs.com/caolisong/archive/2007/04/25/726896.html
- 脚本是:
- nohup /mnt/Nand3/H2000G >/dev/null 2>&1 &
- 对于& 1 更准确的说应该是文件描述符 1,而1 一般代表的就是STDOUT_FILENO,实际上这个操作就是一个dup2(2)调用.他标准输出到all_result ,然后复制标准输出到文件描述符2(STDERR_FILENO),其后果就是文件描述符1和2指向同一个文件表项,也可以说错误的输出被合并了.其中0表示键盘输入 1表示屏幕输出 2表示错误输出.把标准出错重定向到标准输出,然后扔到/DEV/NULL下面去。通俗的说,就是把所有标准输出和标准出错都扔到垃圾桶里面。
- command >out.file 2>&1 &
- command >out.file是将command的输出重定向到out.file文件,即输出内容不打印到屏幕上,而是输出到out.file文件中。2>&1 是将标准出错重定向到标准输出,这里的标准输出已经重定向到了out.file文件,即将标准出错也输出到out.file文件中。最后一个& , 是让该命令在后台执行。
-
- 试想2>1代表什么,2与>结合代表错误重定向,而1则代表错误重定向到一个文件1,而不代表标准输出;
- 换成2>&1,&与1结合就代表标准输出了,就变成错误重定向到标准输出.
-
- 你可以用
- ls 2>1测试一下,不会报没有2文件的错误,但会输出一个空的文件1;
- ls xxx 2>1测试,没有xxx这个文件的错误输出到了1中;
- ls xxx 2>&1测试,不会生成1这个文件了,不过错误跑到标准输出了;
- ls xxx >out.txt 2>&1, 实际上可换成 ls xxx 1>out.txt 2>&1;重定向符号>默认是1,错误和输出都传到out.txt了。
- 为何2>&1要写在后面?
- command > file 2>&1
- 首先是command > file将标准输出重定向到file中, 2>&1 是标准错误拷贝了标准输出的行为,也就是同样被重定向到file中,最终结果就是标准输出和错误都被重定向到file中。
- command 2>&1 >file
- 2>&1 标准错误拷贝了标准输出的行为,但此时标准输出还是在终端。>file 后输出才被重定向到file,但标准错误仍然保持在终端。
-
- 用strace可以看到:
- 1. command > file 2>&1
- 这个命令中实现重定向的关键系统调用序列是:
- open(file) == 3
- dup2(3,1)
- dup2(1,2)
-
- 2. command 2>&1 >file
- 这个命令中实现重定向的关键系统调用序列是:
- dup2(1,2)
- open(file) == 3
- dup2(3,1)
-
- 可以考虑一下不同的dup2()调用序列会产生怎样的文件共享结构。请参考APUE 3.10, 3.12
新初装服务器的时候,有时候打开vim后中文是乱码,怎么处理呢?
最简单的办法:
XML/HTML代码
- 编辑~/.vimrc文件,加上如下几行:
-
- set fileencodings=utf-8,ucs-bom,gb18030,gbk,gb2312,cp936
- set termencoding=utf-8
- set encoding=utf-8
OK,重新打开,搞定
2.2升到2.4的小坑应该就出在权限上了
具体查看:https://httpd.apache.org/docs/current/upgrading.html
即,凡是遇到Order allow,deny allow from all等与Order相关的,最好看一下上面的链接。
比如我们用rewrite的时候,都是
XML/HTML代码
- Options Indexes FollowSymLinks
- AllowOverride All
- Order allow,deny
- allow from all
在2.4下面,上面的代码不报错,但不起作用。如果你的目录下面有.htaccess文件,那么,网站是打不开的,上面的代码改成
XML/HTML代码
- <Directory /var/www/>
- Options Indexes FollowSymLinks
- AllowOverride All
- Require all granted
- </Directory>
OK,再次打开就正常了
find的用法太多了。比如:
1、find . -name "*.php"|grep xxxx 这是判断文件名
2、find . -name "*.php"|xargs -n 50 grep "eval" 这是判断文件中是否有eval字符串,并列出来
还有更多,比如:
XML/HTML代码
- ====================================================
- $find ~ -name "*.txt" -print #在$HOME中查.txt文件并显示
- $find . -name "*.txt" -print
- $find . -name "[A-Z]*" -pri26nbsp; #对匹配的文件使用cpio命令,将他们备份到磁带设备中
- -prune #忽略某个目录
-
- =====================================================
- $find ~ -name "*.txt" -print #在$HOME中查.txt文件并显示
- $find . -name "*.txt" -print
- $find . -name "[A-Z]*" -print #查以大写字母开头的文件
- $find /etc -name "host*" -print #查以host开头的文件
- $find . -name "[a-z][a-z][0–9][0–9].txt" -print #查以两个小写字母和两个数字开头的txt文件
- $find . -perm 755 -print
- $find . -perm -007 -exec ls -l {} \; #查所有用户都可读写执行的文件同-perm 777
- $find . -type d -print
- $find . ! -type d -print
- $find . -type l -print
-
- $find . -size +1000000c -print #查长度大于1Mb的文件
- $find . -size 100c -print # 查长度为100c的文件
- $find . -size +10 -print #查长度超过期作废10块的文件(1块=512字节)
-
- $cd /
- $find etc home apps -depth -print | clio -ivcdC65536 -o /dev/rmt0
- $find /etc -name "passwd*" -exec grep "cnscn" {} \; #看是否存在cnscn用户
- $find . -name "yao*" | xargs file
- $find . -name "yao*" | xargs echo "" > /tmp/core.log
- $find . -name "yao*" | xargs chmod o-w
如果用find + sed就可以很方便的修改文件。比如:
XML/HTML代码
- find ./ -exec grep "xxx:80" '{}' \; -exec sed -i 's/xxx:80/\*:80/g' {} \;
由于以前是直接写死IP的,文件也比较多,所以用find直接全文处理一下,轻松好多。
git将最后一次更新打包,这个命令在网上都是这样写的:
XML/HTML代码
- git archive -o update.zip HEAD $(git diff --name-only HEAD^)
看起来没有什么问题,但事实上,如果你有一些unversion的文件,它也会打包进去,所以我是这样处理的:
XML/HTML代码
- git archive -o update.zip HEAD $(git diff $(git log --pretty=format:"%h" -1) --name-only HEAD^)
嗯,将最后一次提交的内容进行打包。为什么会有这样的需求?是因为自己有git,客户那边没有,所以需要将最后一次,或者最后几次的内容进行打包输出
参考 :
1、https://git-scm.com/book/zh/v1/Git-%E5%9F%BA%E7%A1%80-%E6%9F%A5%E7%9C%8B%E6%8F%90%E4%BA%A4%E5%8E%86%E5%8F%B2
2、http://netkiller.github.io/project/git/ch13s02.html 导出指定版本区间的文件
3、http://blog.sae.sina.com.cn/archives/3003