Linux重定向

Linux重定向,第1张

输出重定向

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

格式

command-line [n]>文件

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

实例

输入重定向

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

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

格式:

command-line [n] <文件

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

实例:

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

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

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

再解释 2>&1 >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文件中。

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

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

如果在命令中直接改变重定向的位置,那么命令执行结束的时候描述符会自动还原。正如上面的ls /boot 2>&1 >/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值的描述符。

1、将标准输出重定向到文件:

>

ls -l >ls-l.txt

2、将标准错误重定向到文件:

2> 

grep da * 2>grep-errors.txt

3、将标准输出重定向到标准错误:

1>&2

grep da * 1>&2

4、将标准错误重定向到标准输出:

2>&1

grep * 2>&1

5、重定向标准错误和标准输出到文件:

&> 

rm -f $(find / -name core) &>/dev/null

标准输入、输出和错误

当我们在shell中执行命令的时候,每个进程都和三个打开的文件相联系,并使用文件描述符来引用这些文件。由于文件描述符不容易记忆,shell同时也给饥雀出了相应的文件名。

文件文件描述符

输入文件—标准输入0:它是命令的输入,缺省是键盘,也可以是文件或其他命令烂历早的输出。

输出文件—标准输出1:它是命令的输出,缺省是屏幕,也可以是文件。

错误输出文件—标准错误2:这是命令错误的输出,缺省是屏幕,同样烂历也可以是文件。

一个进程默认会打开标准输入、标准输出、错误输出三个文件描述符

文件描述符为0,小于号表示数据由文件流入命令

usage:

命令 <file

#加入输入重定向,对输入文件进行计数

wc -l </etc/passwd

文件描述符为1,大于号表述数据由命令流入文件

所以: echo "hello" >t.log 也可以写成 echo "hello" 1 >t.log

> 会把文件的内容清空,再输入到新的文件

>> 会把当前内容保持不变,然后在下一行进行追加

2> 错误重定向,如果当前命令产生了错误,会把错误重定向到文件中,而不会打印到屏幕

&> 无论内容正确还是错误都会把文件输出到文件中。

stderr的文件描述符为2,Unix程序会向stderr流中写入错误信息。

默认情况下, command >file 将stdout 重定向到首手备 file, command <file 将stdin 重定向到 file。

如果希望 stderr 重定向到 file,可以这样写:

$ command 2>file

如果希者毁望 stderr 追加到 file 文件末尾,可以这样写:

$ command 2>>file 2 表示标准错误文件(stderr)

如果希望将 stdout 和 stderr 合并后重定向到 file,可以这样写:

$ command >file 2>&1 或者 $ command >>file 2>&1

如果希望对 stdin 和 stdout 都薯野重定向,可以这样写:

$ command <file1 >file2

command 命令将 stdin 重定向到 file1,将 stdout 重定向到 file2。

含义:将标准错误输出 重定向到 标准输出。

符号>&是一个整体,不可分开,分开后就不是上述含义了。

比如有些人可能会这么想:2是标准错误输入,1是标准输出,>是重定向符号,那么"将标准错误输出重定向到标准输出"是不是就应该写成"2>1"就行了?是这样吗? 如果是尝试过,你就知道2>1的写法其实是将标准错误输出重定向到名为"1"的文件里去了


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/tougao/12236411.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-22
下一篇 2023-05-22

发表评论

登录后才能评论

评论列表(0条)

保存