原文出处:http://blog.csdn.net/kaiwii/article/details/7308729
把/dev/null看作"黑洞". 它非常等价于一个只写文件. 所有写入它的内容都会永远丢失. 而尝试从它那儿读取内容则什么也读不到. 然而, /dev/null对命令行和脚本都非常的有用.
禁止标准输出.
1 cat $filename >/dev/null 2 # 文件内容丢失,而不会输出到标准输出. |
禁止标准错误
1 rm $badname 2>/dev/null 2 # 这样错误信息[标准错误]就被丢到太平洋去了. |
禁止标准输出和标准错误的输出.
1 cat $filename 2>/dev/null >/dev/null 2 # 如果"$filename"不存在,将不会有任何错误信息提示. 3 # 如果"$filename"存在, 文件的内容不会打印到标准输出. 4 # 因此Therefore, 上面的代码根本不会输出任何信息. 5 # 当只想测试命令的退出码而不想有任何输出时非常有用。 6 #-----------测试命令的退出 begin ----------------------# 7 # ls dddd 2>/dev/null 8 8 # echo $? //输出命令退出代码:0为命令正常执行,1-255为有出错。 9 #-----------测试命令的退出 end-----------# 10# cat $filename &>/dev/null 11 # 也可以, 由 Baris Cicek 指出. |
清除日志文件内容
1 cat /dev/null > /var/log/messages 2 # : > /var/log/messages 有同样的效果, 但不会产生新的进程.(因为:是内建的) 3 4 cat /dev/null > /var/log/wtmp |
例子 28-1. 隐藏cookie而不再使用
1 if [ -f ~/.netscape/cookies ] # 如果存在则删除. 2 then 3 rm -f ~/.netscape/cookies 4 fi 5 6 ln -s /dev/null ~/.netscape/cookies 7 # 现在所有的cookies都会丢入黑洞而不会保存在磁盘上了. |
FROM: Advanced Bash-Scripting Guide: An in-depth exploration of the art of shell scripting
原文出处:http://blog.sina.com.cn/s/blog_4d8b64120101atnt.html
在一些Shell脚本中,特别是Crontab的脚本中,经常会看到
其实这个很好理解。我们分两部分解释。
1.
大家知
比如:echo
那么
2.
这个其实是三个部分组成的:2,
#define
这是三种不同的流。
2代表stderr.
1代表sdtout.
而
2&>1
现在我们结合这两个部分来看。2&>1定义了把stderr做为标准的stdout流输出,然后stdout的内容全部写入/dev/null,也就是说被舍弃掉。
结论就是,无论执行的是什么命令,哪怕运行中出现了error都不会有回显。
UNIX有几种输入输出流,与数字的对应关系如下:
0-标准输入流(stdin)
1-标准输出流(stdout)
2-标准错误流(stderr)
命令的结果可以通过>的形式来定义输出。
1. /dev/null 代表空设备文件
2.重定向符号:> 重定向输出,覆盖文件;
>> 重定向输出,不覆盖文件;
1 表示stdout标准输出,系统默认值是1,所以">/dev/null"等同于"1>/dev/null",如果不加数字,那么默认的重定向动作是针对stdout(1)的,比如”ls -l > result”就等价于”ls -l 1 > result”。
& 表示“等同于”的意思,2>&1,表示2的输出重定向等同于1;
1>/dev/null 首先表示标准输出重定向到空设备文件,也就是不输出任何信息到终端,说白了就是不显示任何信息。
2>&1 标准错误输出重定向等同于 标准输出,因为之前标准输出已经重定向到了空设备文件,所以标准错误输出也重定向到空设备文件,即:是将stderr重定向至stdout,并一起在屏幕上显示出来。
cmd>/dev/null 2>/dev/null 与cmd>/dev/null 2>&1的区别:
1. cmd>/dev/null 2>/dev/null :将命令所产生的标准输出信息,和错误的输出信息送到/dev/null中,这样的写法,stdout和stderr都直接送到/dev/null中, /dev/null会被打开两次,这样stdout和stderr会互相覆盖,这样写相当使用了FD1和FD2两个同时去抢占/dev/null的管道.