本篇内容介绍了“如何理解Linux base shell重定向”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!
一、标准输入,标准输出与标准错误输出
在linux shell执行命令时,每个进程都和三个打开的文件相联系,并使用文件描述符来引用这些文件。由于文件描述符不容易记忆,shell同时也给出了相应的文件名:
文件 | 文件描述符 |
输入文件—标准输入 | 0(缺省是键盘,为0时是文件或者其他命令的输出) |
输出文件—标准输出 | 1(缺省是屏幕,为1时是文件) |
错误输出文件—标准错误 | 2(缺省是屏幕,为2时是文件) |
系统中实际上有12个文件描述符,我们可以任意使用文件描述符3到9.
标准输入:从键盘输入数据,即从键盘读入数据。
标准输出:把数据输出到终端上。
标准错误输出:把标准错误输出到终端上。
默认的标准输入指的是键盘,默认的标准输出与标准错误输出指的是屏幕或者是终端。
系统为这三个文件分配了文件标识符fd(file descripter).
在Linux系统下,一切皆是文件,对文件的操作,一般要用到文件标识符。它们的文件标识符,分别为0,1,2。他们的关系如下表:
文件描述符 | 名称 | 通用缩写 | 默认值 |
---|---|---|---|
0 | 标准输入 | stdin | 键盘 |
1 | 标准输出 | stdout | 屏幕 |
2 | 标准错误 | stderr | 屏幕 |
二.文件重定向:改变程序运行的输入来源和输出地点
1.输出重定向:
Command > filename | 把标准输出重定向到一个新文件中 |
Command >> filename | 把标准输出重定向到一个文件中(追加) |
Command > filename | 把标准输出重定向到一个文件中 |
Command > filename 2>&1 | 把标准输出和错误一起重定向到一个文件中 |
Command 2 > filename | 把标准错误重定向到一个文件中 |
Command 2 >> filename | 把标准输出重定向到一个文件中(追加) |
Command >> filename2>&1 | 把标准输出和错误一起重定向到一个文件(追加) |
2.输入重定向:
Command < filename > filename2 | Command命令以filename文件作为标准输入,以filename2文件作为标准输出 |
Command < filename | Command命令以filename文件作为标准输入 |
Command << delimiter | 从标准输入中读入,知道遇到delimiter分界符 |
3.绑定重定向
Command >&m | 把标准输出重定向到文件描述符m中 |
Command < &- | 关闭标准输入 |
Command 0>&- | 同上 |
三、使用实例
代码如下:
cmd > file
#说明: 将 cmd 的输出发送到 file 文件(覆盖模式)
cmd >> file
#说明: 将 cmd 的输出发送到 file 文件(追加模式)
cmd < file
#说明: 以 file 文件的内容作为 cmd 的输入
cmd << text
#说明: 嵌入文件(here document, 类似于PHP语法)形式的输入
#shell 可在行内输入中做变量、命令和算术替换
cmd <<- text
#说明: 作用同上, 不过会自动删除here document中每行开头的制表符Tab
cmd <<< word
#说明: here string 格式的输入
#参见: http://bash.cyberciti.biz/guide/Here_strings
#参见: http://linux.die.net/abs-guide/x15683.html
cmd <> file
#说明: 以读写方式打开文件 file
cmd >| file
#说明: 强制以覆盖方式将 cmd 的输出发送到 file 文件
#即便 shell 设置了 noclobber 选项也是如此
cmd >&n
#说明: 将 cmd 的输出发送到文件描述符 n
cmd m>&n
#说明: 作用同上。将本该输出到文件描述符 m 的内容, 发送到文件描述符 n
cmd >&-
#说明: 关闭标准输出
cmd <&n
#说明: 从文件描述符 n 处获取内容作为 cmd 命令的输入
cmd m<&n
#说明: 作用同上。除了本该从文件描述符 m 处获取输入,改为从文件描述符 n 处获取
cmd <&-
#说明: 关闭标准输入
cmd <&n-
#说明: 通过复制移动文件操作符 n 为标准输入并且关闭原始输入
cmd >&n-
#说明: 通过复制移动文件操作符 n 为标准输出并且关闭原始输出
cmd 2>file
#说明: 将标准错误输出发送到文件 file
cmd > file 2>&1
#说明: 将标准输出发送到文件 file, 将标准错误发送到文件描述符 1, 也即 file 文件
cmd >& file
#说明: 将标准输出和标准错误都发送到文件 file (作用同上)
cmd &> file
#说明: 作用同上, 更好的格式
cmd &>> file
#说明: 将标准错误和标准输出发送到文件 file (追加模式)
cmd > f1 2> f2
#说明: 将标准输出发送到文件 f1, 将标准错误发送到文件 f2
cmd | tee files
#说明: 发送 cmd 的输出到标准输出 (通常为终端) 和 文件 files
cmd 2>&1 | tee files
#说明: 发送 cmd 的输出和错误到标准输出 (通常为终端) 和 文件 files
cmd |& tee files
#说明: 作用同上
四、shell重定向的一些高级用法
1.重定向标准错误
例子1:
代码如下:
command 2> /dev/null
如果command执行出错,将错误的信息重定向到空设备
例子2:
代码如下:
command > out.put 2>&1
将command执行的标准输出和标准错误重定向到out.put(也就是说不管command执行正确还是错误,输出都打印到out.put)。
2.exec用法
exec命令可以用来替代当前shell;换句话说,并没有启动子shell,使用这一条命令时任何现有环境变量将会被清除,并重新启动一个shell(重新输入用户名和密码进入)。
代码如下:
exec command
其中,command通常是一个shell脚本。
对文件描述符操作的时候用(也只有再这时候),它不会覆盖你当前的shell
例子1:
代码如下:
#!/bin/bash
#file_desc
exec 3<&0 0<name.txt
read line1
read line2
exec 0<&3
echo $line1
echo $line2
其中:
首先,exec 3<&0 0<name.txt的意思是把标准输入重定向到文件描述符3(0表示标准输入),然后把文件name.txt内容重定向到文件描述符0,实际上就是把文件name.txt中的内容重定向到文件描述符3。然后通过exec打开文件描述符3;
然后,通过read命令读取name.txt的第一行内容line1,第二行内容line2,通过Exec 0<&3关闭文件描述符3;
最后,用echo命令输出line1和line2。最好在终端运行一下这个脚本,亲自尝试一下。
例子2:
代码如下:
exec 3<>test.sh;
#打开test.sh可读写操作,与文件描述符3绑定
while read line<&3
do
echo $line;
done
#循环读取文件描述符3(读取的是test.sh内容)
代码如下:
exec 3>&-
exec 3<&-
#关闭文件的,输入,输出绑定
五、bash shell 重定向的几个特殊文件
文件 | 说明 |
---|---|
/dev/stdin | 文件描述符 0 的复制品 |
/dev/stdout | 文件描述符 1 的复制品 |
/dev/stderr | 文件描述符 2 的复制品 |
/dev/fd/n | 文件描述符 n 的复制品 |
/dev/tcp/host/port | Bash 在 port 打开到 host 的 TCP 连接 |
/dev/udp/host/port | Bash 在 port 打开到 host 的 UDP 连接 |
“如何理解Linux base shell重定向”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注编程网网站,小编将为大家输出更多高质量的实用文章!