linux重定向日志命令 linux定位日志命令

Linux重定向

输出重定向 :

目前创新互联已为近千家的企业提供了网站建设、域名、网站空间成都网站托管、企业网站设计、上栗网站维护等服务,公司将坚持客户导向、应用为本的策略,正道将秉承"和谐、参与、激情"的文化,与客户和合作伙伴齐心协力一起成长,共同发展。

我们使用 或者 对输出进行重定向。 符号的左边表示文件描述符,如果没有的话表示1,也就是标准输出, 符号的右边可以是一个文件,也可以是一个输出设备(Linux中万物皆文件,即设备也是文件)。当使用时,会判断右边的文件存不存在,如果存在的话就先删除,然后创建一个新的文件,不存在的话则直接创建。但是当使用进行追加时,则不会删除原来已经存在的文件。

格式 :

command-line [n] 文件

这条命令意思是:将一条命令执行结果(标准输出,或者错误输出,本来都要打印到屏幕上面的) 重定向其它输出设备(文件)1,2分别是标准输出,错误输出。

实例 :

输入重定向

在理解了输出重定向之后,理解输入重定向就会容易得多。对输入重定向的基本命令如下:

我们使用 对输入做重定向, 如果符号左边没有写值,那么默认就是0。

格式:

command-line [n] 文件

命令默认从键盘获得的输入,使用输入重定向改成从文件,或者其它打开文件以及设备输入。执行这个命令,将标准输入0,与文件或设备绑定,将由它进行输入。

实例:

文件描述符的复制表示复制文件描述符到另一个文件描述符中,也就是将该文件描述符重定向到另一个文件描述符所绑定的文件,使用””进行复制。

想必很多人都知道 file 21 的作用,它等价于 file ,表示标准输出和标准错误都重定向到file中。那它和 21 file 有什么区别呢?

首先解释 file 21 。这里分两个过程:先打开file,再将fd=1重定向到file文件上,这样file文件就成了标准输出的输出目标;之后再将fd=2复制于fd=1,而fd=1此时已经重定向到file文件上,因此fd=2也重定向到file上。所以,最终的结果是标准输出重定向到file上,标准错误也重定向到file上。

再解释 21 file 。这里也分两个过程:先将fd=2复制于fd=1,而此时fd=1重定向的文件是默认的/dev/stdout,所以fd=2也重定向到/dev/stdout;之后再将fd=1重定向到file文件上。也就是说,这里的标准错误和标准输出仍然是分开输出的,只不过是使用/dev/stdout替代了/dev/stderr,使用file替代了/dev/stdout。所以,最终的结果是标准错误输出到/dev/stdout,即屏幕上,而标准输出将输出到file文件中。

可以使用下面的命令来测试 21 file 。第一个ls命令是正确的,结果输出到/tmp/fff.log中,第二个ls命令是错误的,结果将直接输出到屏幕上。

最后需要说明的是一种特殊情况,如果是 [word] ,且word不是一个数值,比如 echo haha /tmp/fff.log ,那么 word 和 word 是等价的,都表示 word 21 ,即标准错误和标准输出都重定向同一个目标。参考man bash的”Redirecting Standard Output and Standard Error”段落。

如果在命令中直接改变重定向的位置,那么命令执行结束的时候描述符会自动还原。正如上面的ls /boot 21 /tmp/fff.log命令,在ls执行结束后,fd=2还原回默认的/dev/stderr,fd=1还原回默认的/dev/stdout。

但是我们可以通过exec程序直接在当前的shell环境下改变重定向目标,只有在当前shell退出的时候才会释放描述符的绑定。

Tips :shell的内建命令exec将并不启动新的shell,而是用要被执行命令替换当前的shell进程,并且将老进程的环境清理掉,而且exec命令后的其它命令将不再执行。

不过,要注意一个例外,当exec命令来对文件描述符操作的时候,就不会替换shell,而且操作完成后,还会继续执行接下来的命令。

例如:下面的命令将标准错误fd=2指向fd=3对应的文件上。

因此,我们可能在一段程序执行结束后,需要将描述符还原到原来的位置,并关闭不再需要的描述符。毕竟描述符也是资源,是有限的(ulimit -n)。

[n] filename :打开filename,并指定其文件描述符为n,该描述符是可读、可写的描述符。若不指定n则默认为0,若filename文件不存在,则先创建filename文件。

文件描述符的移动表示将文件描述符1移动到描述符2上,同时关闭文件描述符1。

[n]digit- :将文件描述符digit代表的输出文件移动到n上,并关闭digit值的描述符。

[n]digit- :将文件描述符digit代表的输入文件移动到n上,并关闭digit值的描述符。

LINUX 标准错误输出重定向

用途:不挂断地运行命令。

语法:nohup Command [ Arg … ] [  ]

无论是否将 nohup 命令的输出重定向到终端,输出都将附加到当前目录的 nohup.out 文件中。

如果当前目录的 nohup.out 文件不可写,输出重定向到 $HOME/nohup.out 文件中。

如果没有文件能创建或打开以用于追加,那么 Command 参数指定的命令不可调用。

退出状态:该命令返回下列出口值:

126 可以查找但不能调用 Command 参数指定的命令。

127 nohup 命令发生错误或不能查找由 Command 参数指定的命令。

否则,nohup 命令的退出状态是 Command 参数指定命令的退出状态。

用途:在后台运行

一般两个一起用

3.为什么呢 21 要写在后面?

首先是command file将标准输出重定向到file中, 21 是标准错误拷贝了标准输出的行为,也就是同样被重定向到file中,最终结果就是标准输出和错误都被重定向到file中。

21 标准错误拷贝了标准输出的行为,但此时标准输出还是在终端。file 后输出才被重定向到file,但标准错误仍然保持在终端。

用strace可以看到:

这个命令中实现重定向的关键系统调用序列是:

open(file) == 3

dup2(3,1)

dup2(1,2)

这个命令中实现重定向的关键系统调用序列是:

dup2(1,2)

open(file) == 3

dup2(3,1)

注意:0 是标准输入(STDIN),1 是标准输出(STDOUT),2 是标准错误输出(STDERR)。

这里的2和之间不可以有空格,2是一体的时候才表示错误输出。

”?'>如何像测试人员介绍linux中的重定向命令“>”?

你好

在linux中,一切都是文件,对于控制台程序,这意味着:- 键盘表示为一个文件,bash从中读取你的输入。- 显示器表示为一个文件,bash把输出写入它。重定向是一种机制,即可将来自键盘的输入或显示器的输出,重定向到另一个文件。 :用文件替换标准输入(即用文件代替键盘) :用文件替换标准输出(即用文件代替显示器) :与相同,但不是覆盖原有文件,而是追加到原有文件的末尾比如,我们调用ping 的命令,来测试本机与头条服务器之间网络的连通性。屏幕会不断输出网络的延时。


当前标题:linux重定向日志命令 linux定位日志命令
转载来源:http://scyanting.com/article/hjcdpp.html