Linux系统启动一个进程(该进程可能用于执行Shell命令)时,将自动为该进程打开三个文件:标准输入、标准输出、标准错误输出。默认分别绑定stdin,stdout,stderr,这些默认的输出输入都是linux系统内定的,我们在使用过程中有时并不希望执行结果输出到屏幕。我想输出到文件或其它设备。这个时候我们就需要进行输入/输出重定向了。
linux shell下常用输入输出操作符是:
1. 标准输入 (stdin) :代码为 0 ,使用 < ; /dev/stdin -> /proc/self/fd/0 0代表/dev/stdin <:输入重定向 ;系统默认是从键盘输入
2. 标准输出 (stdout):代码为 1 ,使用 > 或 >> ; /dev/stdout -> /proc/self/fd/1 1代表/dev/stdout ;>:覆盖输出 ;>>:追加输出;系统默认输出到显示器
3. 标准错误输出(stderr):代码为 2 ,使用 2> 或 2>> ; /dev/stderr -> /proc/self/fd/2 2代表/dev/stderr ;2>:重定向错误输出 ; 2>>:追加方式重定向错误输出;系统默认输出到显示器
----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
输出重定向:
格式:command-line1 [1-n] > file或文件操作符或设备
上面命令意思是:将一条命令执行结果(标准输出,或者错误输出,本来都要打印到屏幕上面的) 重定向其它输出设备(文件,打开文件操作符,或打印机等等)1,2分别是标准输出,错误输出。
注意:
1、shell遇到”>”操作符,会判断右边文件是否存在,如果存在就先删除,并且创建新文件。不存在直接创建。 无论左边命令执行是否成功。右边文件都会变为空。
2、“>>”操作符,判断右边文件,如果不存在,先创建。以添加方式打开文件,会分配一个文件描述符[不特别指定,默认为1,2]然后,与左边的标准输出(1)或错误输出(2) 绑定。
3、当命令:执行完,绑定文件的描述符也自动失效。0,1,2又会空闲。
4、一条命令启动,命令的输入,正确输出,错误输出,默认分别绑定0,1,2文件描述符。
5、一条命令在执行前,先会检查输出是否正确,如果输出设备错误,将不会进行命令执行
------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
输入重定向
command-line [n] <file或文件描述符&设备
命令默认从键盘获得的输入,改成从文件,或者其它打开文件以及设备输入。执行这个命令,将标准输入0,与文件或设备绑定。将由它进行输入。
-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
exec绑定重定向
exec 文件描述符[n] <或> file或文件描述符或设备
在上面讲的输入,输出重定向 将输入,输出绑定文件或设备后。只对当前那条指令是有效的。如果需要在绑定之后,接下来的所有命令都支持的话。就需要用exec命令
说明:使用前先将标准输入保存到文件描述符6,这里说明下,文件描述符默认会打开0,1,2 还可以使用自定义描述符 。然后对标准输出绑定到文件,接下来所有输出都会发生到文件。 使用完后,恢复标准的输出,关闭打开文件描述符6。
有趣事情:
可能有朋友会这样用:exec 1>suc.txt ,接下来所有输出都绑定到suc.txt 文件,那么怎么样恢复原来的呢? 试试你就会发现问题所在……
复杂一点的实例:
exec 3<tt.logwhile read -u3 t1 t2 t3 t4doecho $t2 $t4rexec lshas$t1 "ls -lt $t3|awk '{print \$5,\$9}' "doneexec 3<&-
exec 3<urfilewhile read var <&3do....done