bash中的管道和重定向

管道

管道命令操作符是:”|”,它仅能处理经由前面一个指令传出的正确输出信息,也就是 standard output 的信息,对于 stdandarderror 信息没有直接处理能力。然后,传递给下一个命令,作为标准的输入 standard input.

image

图 1

如图,command1正确输出,作为command2的输入 然后comand2的输出作为,comand3的输入 ,comand3输出就会直接显示在屏幕上面了。通过管道之后:comand1,comand2的正确输出不显示在屏幕上面。

 

注意:

1、管道命令只处理前一个命令正确输出,不处理错误输出。

2、管道命令右边命令,必须能够接收标准输入流命令才行。作用接收标准输入的命令才可以用作管道右边。否则传递过程中数据会抛弃。

    常用来作为接收数据管道命令(文本处理命令)有:

     sed,awk,cut,head,top,less,more,wc,join,sort,split 等。
3.  一般如果是命令间传递参数,还是管道的好,如果处理输出结果需要重定向到文件,还是用重定向输出比较好。

 

[root@s2 ~]# cat /etc/passwd |grep -n "var"
4:adm:x:3:4:adm:/var/adm:/sbin/nologin
5:lp:x:4:7:lp:/var/spool/lpd:/sbin/nologin
9:mail:x:8:12:mail:/var/spool/mail:/sbin/nologin
12:ftp:x:14:50:FTP User:/var/ftp:/sbin/nologin
19:libstoragemgmt:x:997:996:daemon account for libstoragemgmt:/var/run/lsm:/sbin/nologin
20:avahi:x:70:70:Avahi mDNS/DNS-SD Stack:/var/run/avahi-daemon:/sbin/nologin
21:avahi-autoipd:x:170:170:Avahi IPv4LL Stack:/var/lib/avahi-autoipd:/sbin/nologin
22:rpc:x:32:32:Rpcbind Daemon:/var/lib/rpcbind:/sbin/nologin
24:chrony:x:996:995::/var/lib/chrony:/sbin/nologin
26:pegasus:x:66:65:tog-pegasus OpenPegasus WBEM/CIM services:/var/lib/Pegasus:/sbin/nologin
27:colord:x:995:994:User for colord:/var/lib/colord:/sbin/nologin
31:rpcuser:x:29:29:RPC Service User:/var/lib/nfs:/sbin/nologin
32:nfsnobody:x:65534:65534:Anonymous NFS User:/var/lib/nfs:/sbin/nologin
34:pulse:x:171:171:PulseAudio System Daemon:/var/run/pulse:/sbin/nologin
35:gdm:x:42:42::/var/lib/gdm:/sbin/nologin
37:pcp:x:992:990:Performance Co-Pilot:/var/lib/pcp:/sbin/nologin
38:sshd:x:74:74:Privilege-separated SSH:/var/empty/sshd:/sbin/nologin
39:postfix:x:89:89::/var/spool/postfix:/sbin/nologin
40:oprofile:x:16:16:Special user account to be used by OProfile:/var/lib/oprofile:/sbin/nologin


[root@s2 ~]# cat /etc/passwd /etc/abc |grep -n "var"

cat: /etc/abc: No such file or directory
#不存在 abc,错误输出也到屏幕

4:adm:x:3:4:adm:/var/adm:/sbin/nologin
5:lp:x:4:7:lp:/var/spool/lpd:/sbin/nologin
9:mail:x:8:12:mail:/var/spool/mail:/sbin/nologin
12:ftp:x:14:50:FTP User:/var/ftp:/sbin/nologin
19:libstoragemgmt:x:997:996:daemon account for libstoragemgmt:/var/run/lsm:/sbin/nologin
20:avahi:x:70:70:Avahi mDNS/DNS-SD Stack:/var/run/avahi-daemon:/sbin/nologin
21:avahi-autoipd:x:170:170:Avahi IPv4LL Stack:/var/lib/avahi-autoipd:/sbin/nologin
22:rpc:x:32:32:Rpcbind Daemon:/var/lib/rpcbind:/sbin/nologin
24:chrony:x:996:995::/var/lib/chrony:/sbin/nologin
26:pegasus:x:66:65:tog-pegasus OpenPegasus WBEM/CIM services:/var/lib/Pegasus:/sbin/nologin
27:colord:x:995:994:User for colord:/var/lib/colord:/sbin/nologin
31:rpcuser:x:29:29:RPC Service User:/var/lib/nfs:/sbin/nologin
32:nfsnobody:x:65534:65534:Anonymous NFS User:/var/lib/nfs:/sbin/nologin
34:pulse:x:171:171:PulseAudio System Daemon:/var/run/pulse:/sbin/nologin
35:gdm:x:42:42::/var/lib/gdm:/sbin/nologin
37:pcp:x:992:990:Performance Co-Pilot:/var/lib/pcp:/sbin/nologin
38:sshd:x:74:74:Privilege-separated SSH:/var/empty/sshd:/sbin/nologin
39:postfix:x:89:89::/var/spool/postfix:/sbin/nologin
40:oprofile:x:16:16:Special user account to be used by OProfile:/var/lib/oprofile:/sbin/nologin


[root@s2 ~]# cat /etc/passwd /etc/abc 2 > err.txt |grep -n "var"
cat: /etc/abc: No such file or directory
cat: 2: No such file or directory
[root@s2 ~]# cat /etc/passwd /etc/abc 2> err.txt |grep -n "var"
4:adm:x:3:4:adm:/var/adm:/sbin/nologin
5:lp:x:4:7:lp:/var/spool/lpd:/sbin/nologin
9:mail:x:8:12:mail:/var/spool/mail:/sbin/nologin
12:ftp:x:14:50:FTP User:/var/ftp:/sbin/nologin
19:libstoragemgmt:x:997:996:daemon account for libstoragemgmt:/var/run/lsm:/sbin/nologin
20:avahi:x:70:70:Avahi mDNS/DNS-SD Stack:/var/run/avahi-daemon:/sbin/nologin
21:avahi-autoipd:x:170:170:Avahi IPv4LL Stack:/var/lib/avahi-autoipd:/sbin/nologin
22:rpc:x:32:32:Rpcbind Daemon:/var/lib/rpcbind:/sbin/nologin
24:chrony:x:996:995::/var/lib/chrony:/sbin/nologin
26:pegasus:x:66:65:tog-pegasus OpenPegasus WBEM/CIM services:/var/lib/Pegasus:/sbin/nologin
27:colord:x:995:994:User for colord:/var/lib/colord:/sbin/nologin
31:rpcuser:x:29:29:RPC Service User:/var/lib/nfs:/sbin/nologin
32:nfsnobody:x:65534:65534:Anonymous NFS User:/var/lib/nfs:/sbin/nologin
34:pulse:x:171:171:PulseAudio System Daemon:/var/run/pulse:/sbin/nologin
35:gdm:x:42:42::/var/lib/gdm:/sbin/nologin
37:pcp:x:992:990:Performance Co-Pilot:/var/lib/pcp:/sbin/nologin
38:sshd:x:74:74:Privilege-separated SSH:/var/empty/sshd:/sbin/nologin
39:postfix:x:89:89::/var/spool/postfix:/sbin/nologin
40:oprofile:x:16:16:Special user account to be used by OProfile:/var/lib/oprofile:/sbin/nologin
[root@s2 ~]# cat err.txt 
cat: /etc/abc: No such file or directory


#  ls命令不支持标准输入,所有未例会管道的输出文件名HBaseTestCase.java
[root@s2 ~]# cat /home/zpf/file.txt 
 HBaseTestCase.java

[root@s2 ~]# cat /home/zpf/file.txt |ls
1.pcap  anaconda-ks.cfg  Documents  dpi_log  err.txt       ftp.pcap              Music      pcap   Pictures  t1   tcpreplay-3.4.4         telnet_only.pcap  Templates  wcp_55_pcap_1452502359.pcap
a       Desktop          Downloads  eclipse  ftp_big.pcap  initial-setup-ks.cfg  nohup.out  perl5  Public    t60  tcpreplay-3.4.4.tar.gz  telnet.pcap       Videos     workspace

 

 

[root@s2 ~]# grep -n "root" < /etc/passwd
1:root:x:0:0:root:/root:/bin/bash
10:operator:x:11:0:operator:/root:/sbin/nologin


[root@s2 ~]# (sed -n "1,10p" | grep -n "var") < /etc/passwd
4:adm:x:3:4:adm:/var/adm:/sbin/nologin
5:lp:x:4:7:lp:/var/spool/lpd:/sbin/nologin
9:mail:x:8:12:mail:/var/spool/mail:/sbin/nologin
#
grep.需要将前面用"()"
运算符括起来。在单括号内的命令,可以把它们看作一个象一个命令样。#如果不加括号test.sh就是grep 的输入了,如下
[root@s2 ~]# sed -n "1,10p" | grep -n "var" < /etc/passwd
4:adm:x:3:4:adm:/var/adm:/sbin/nologin
5:lp:x:4:7:lp:/var/spool/lpd:/sbin/nologin
9:mail:x:8:12:mail:/var/spool/mail:/sbin/nologin
12:ftp:x:14:50:FTP User:/var/ftp:/sbin/nologin
19:libstoragemgmt:x:997:996:daemon account for libstoragemgmt:/var/run/lsm:/sbin/nologin
20:avahi:x:70:70:Avahi mDNS/DNS-SD Stack:/var/run/avahi-daemon:/sbin/nologin
21:avahi-autoipd:x:170:170:Avahi IPv4LL Stack:/var/lib/avahi-autoipd:/sbin/nologin
22:rpc:x:32:32:Rpcbind Daemon:/var/lib/rpcbind:/sbin/nologin
24:chrony:x:996:995::/var/lib/chrony:/sbin/nologin
26:pegasus:x:66:65:tog-pegasus OpenPegasus WBEM/CIM services:/var/lib/Pegasus:/sbin/nologin
27:colord:x:995:994:User for colord:/var/lib/colord:/sbin/nologin
31:rpcuser:x:29:29:RPC Service User:/var/lib/nfs:/sbin/nologin
32:nfsnobody:x:65534:65534:Anonymous NFS User:/var/lib/nfs:/sbin/nologin
34:pulse:x:171:171:PulseAudio System Daemon:/var/run/pulse:/sbin/nologin
35:gdm:x:42:42::/var/lib/gdm:/sbin/nologin
37:pcp:x:992:990:Performance Co-Pilot:/var/lib/pcp:/sbin/nologin
38:sshd:x:74:74:Privilege-separated SSH:/var/empty/sshd:/sbin/nologin
39:postfix:x:89:89::/var/spool/postfix:/sbin/nologin
40:oprofile:x:16:16:Special user account to be used by OProfile:/var/lib/oprofile:/sbin/nologin



[root@s2 ~]# sed -n "1,10p" </etc/passwd  | grep -n "var" < /etc/passwd
4:adm:x:3:4:adm:/var/adm:/sbin/nologin
5:lp:x:4:7:lp:/var/spool/lpd:/sbin/nologin
9:mail:x:8:12:mail:/var/spool/mail:/sbin/nologin
12:ftp:x:14:50:FTP User:/var/ftp:/sbin/nologin
19:libstoragemgmt:x:997:996:daemon account for libstoragemgmt:/var/run/lsm:/sbin/nologin
20:avahi:x:70:70:Avahi mDNS/DNS-SD Stack:/var/run/avahi-daemon:/sbin/nologin
21:avahi-autoipd:x:170:170:Avahi IPv4LL Stack:/var/lib/avahi-autoipd:/sbin/nologin
22:rpc:x:32:32:Rpcbind Daemon:/var/lib/rpcbind:/sbin/nologin
24:chrony:x:996:995::/var/lib/chrony:/sbin/nologin
26:pegasus:x:66:65:tog-pegasus OpenPegasus WBEM/CIM services:/var/lib/Pegasus:/sbin/nologin
27:colord:x:995:994:User for colord:/var/lib/colord:/sbin/nologin
31:rpcuser:x:29:29:RPC Service User:/var/lib/nfs:/sbin/nologin
32:nfsnobody:x:65534:65534:Anonymous NFS User:/var/lib/nfs:/sbin/nologin
34:pulse:x:171:171:PulseAudio System Daemon:/var/run/pulse:/sbin/nologin
35:gdm:x:42:42::/var/lib/gdm:/sbin/nologin
37:pcp:x:992:990:Performance Co-Pilot:/var/lib/pcp:/sbin/nologin
38:sshd:x:74:74:Privilege-separated SSH:/var/empty/sshd:/sbin/nologin
39:postfix:x:89:89::/var/spool/postfix:/sbin/nologin
40:oprofile:x:16:16:Special user account to be used by OProfile:/var/lib/oprofile:/sbin/nologin

##重定向运算符,在shell命令解析前,首先检查的(一个命令,执行前一定检查好它的输入,输出,也就是0,
1,2 设备是否准备好),所以优先级会最高。如下示例,"<"
运算符会优先,管道还没有发送数据前,grep绑定了testsh.sh输入,这样sed命令输出就被抛弃了。这里一定要小心使用

[root@s2 ~]# sed -n "1,10p" </etc/passwd  | grep -n "var" < /etc/passwd
4:adm:x:3:4:adm:/var/adm:/sbin/nologin
5:lp:x:4:7:lp:/var/spool/lpd:/sbin/nologin
9:mail:x:8:12:mail:/var/spool/mail:/sbin/nologin
12:ftp:x:14:50:FTP User:/var/ftp:/sbin/nologin
19:libstoragemgmt:x:997:996:daemon account for libstoragemgmt:/var/run/lsm:/sbin/nologin
20:avahi:x:70:70:Avahi mDNS/DNS-SD Stack:/var/run/avahi-daemon:/sbin/nologin
21:avahi-autoipd:x:170:170:Avahi IPv4LL Stack:/var/lib/avahi-autoipd:/sbin/nologin
22:rpc:x:32:32:Rpcbind Daemon:/var/lib/rpcbind:/sbin/nologin
24:chrony:x:996:995::/var/lib/chrony:/sbin/nologin
26:pegasus:x:66:65:tog-pegasus OpenPegasus WBEM/CIM services:/var/lib/Pegasus:/sbin/nologin
27:colord:x:995:994:User for colord:/var/lib/colord:/sbin/nologin
31:rpcuser:x:29:29:RPC Service User:/var/lib/nfs:/sbin/nologin
32:nfsnobody:x:65534:65534:Anonymous NFS User:/var/lib/nfs:/sbin/nologin
34:pulse:x:171:171:PulseAudio System Daemon:/var/run/pulse:/sbin/nologin
35:gdm:x:42:42::/var/lib/gdm:/sbin/nologin
37:pcp:x:992:990:Performance Co-Pilot:/var/lib/pcp:/sbin/nologin
38:sshd:x:74:74:Privilege-separated SSH:/var/empty/sshd:/sbin/nologin
39:postfix:x:89:89::/var/spool/postfix:/sbin/nologin
40:oprofile:x:16:16:Special user account to be used by OProfile:/var/lib/oprofile:/sbin/nologin

管道和重定向的区别

1、左边的命令应该有标准输出 | 右边的命令应该接受标准输入
   左边的命令应该有标准输出 > 右边只能是文件
   左边的命令应该需要标准输入 < 右边只能是文件

2、管道触发两个子进程执行"|"两边的程序;而定向是在一个进程内执行。

重定向

重定向和文件描述符有关。

      linux文件描述符:可以理解为linux跟踪打开文件,而分配的一个数字,这个数字有点类似c语言操作文件时候的句柄,通过句柄就可以实现文件的读写操作。 用户可以自定义文件描述符范围是:3-num,这个最大数字,跟用户的:ulimit –n 定义数字有关系,不能超过最大值。linux启动后,会默认打开3个文件描述符,分别是:标准输入standard input 0,正确输出standard output 1,错误输出:error output 2。以后打开文件后。新增文件绑定描述符 可以依次增加。 一条shell命令执行,都会继承父进程的文件描述符。因此,所有运行的shell命令,都会有默认3个文件描述符。

     文件输入输出由追踪为一个给定的进程所有打开文件的整数句柄来完成。这些数字值就是文件描述符。最为人们所知的文件米描述符是 stdin, stdoutstderr,文件描述符的数字分别是0,1和2。这些数字和各自的设备是保留的。一个命令执行前,先会准备好所有输入输出,默认分别绑定(stdin,stdout,stderr),如果这个时候出现错误,命令将终止,不会执行。命令解析过程。

     如下图:一个命令执行了:先有一个输入:输入可以从键盘,也可以从文件得到命令执行完成:成功了,会把成功结果输出到屏幕:standard output默认是屏幕。命令执行有错误:会把错误也输出到屏幕上面:standard error默认也是指的屏幕。

    根据应用的场景,改变1,2的默认输出,这就是重定向

    image

 

linux上的标准输入、输出、错误,如下:,&表示全部

[root@s2 ~]# ll /dev/std*
lrwxrwxrwx 1 root root 15 May 13 19:43 /dev/stderr -> /proc/self/fd/2
lrwxrwxrwx 1 root root 15 May 13 19:43 /dev/stdin -> /proc/self/fd/0
lrwxrwxrwx 1 root root 15 May 13 19:43 /dev/stdout -> /proc/self/fd/1

 

输出重定向

注意:

1、shell遇到”>”操作符,会判断右边文件是否存在,如果存在就先删除,并且创建新文件。不存在直接创建。 无论左边命令执行是否成功。右边文件都会变为空。

2、“>>”操作符,判断右边文件,如果不存在,先创建。以添加方式打开文件,会分配一个文件描述符[不特别指定,默认为1,2]然后,与左边的标准输出(1)或错误输出(2) 绑定。

3、当命令:执行完,绑定文件的描述符也自动失效。0,1,2又会空闲。

4、一条命令启动,命令的输入,正确输出,错误输出,默认分别绑定0,1,2文件描述符。

5、一条命令在执行前,先会检查输出是否正确,如果输出设备错误,将不会进行命令执行

 

几个示例如下:

[root@s2 zpf]# cat file.txt abc.txt  2> /dev/null | tee  all.txt |grep java
 HBaseTestCase.java
[root@s2 zpf]# cat all.txt 
 HBaseTestCase.java


#通过管道实现将结果存入文件,还需要借助命令tee,它会把管道过来标准输入写入文件test.txt ,然后将标准输入复制到标准输出(stdout),所以重定向到/dev/null 不显示输出
#">"输出重定向,往往在命令最右边,接收左边命令的,输出结果,重定向到指定文件。也可以用到命令中间。

[root@s2 zpf]# cat file.txt abc.txt  &> /dev/null | tee  all.txt |grep java
[root@s2 zpf]# 
#这次打印结果是空,&代表正确与错误输出 都输入给err.txt,通过管道继续往下面传递数据为空,所以没有什么显示的

#同样">"输出重定向符,优先级也是先解析,当一个命令有这个字符,它就会与左边命令标准输出绑定。准备好了这些,就等待命令执行输出数据,它就开始接收

 

[root@s2 zpf]# ll file.txt abc.txt 1>ok.txt 2>err.txt
[root@s2 zpf]# cat ok.txt 
-rw-r--r-- 1 root root 21 May 19 14:25 file.txt
[root@s2 zpf]# cat err.txt 
ls: cannot access abc.txt: No such file or directory


[root@s2 zpf]# ll file.txt abc.txt 1>>ok.txt 2>>err.txt
[root@s2 zpf]# 
[root@s2 zpf]# cat ok.txt 
-rw-r--r-- 1 root root 21 May 19 14:25 file.txt
-rw-r--r-- 1 root root 21 May 19 14:25 file.txt
[root@s2 zpf]# cat err.txt 
ls: cannot access abc.txt: No such file or directory
ls: cannot access abc.txt: No such file or directory

#如下,标准错误输出到null,正确输出先写到ok.txt ,.然后再标准输出
[root@s2 zpf]# ll file.txt abc.txt  2>/dev/null |tee ok.txt 
-rw-r--r-- 1 root root 21 May 19 14:25 file.txt
[root@s2 zpf]# cat ok.txt 
-rw-r--r-- 1 root root 21 May 19 14:25 file.txt



#关闭所有输出,效果等同于绑定到null
#&[n] 代表是已经存在的文件描述符,&1 代表输出 &2代表错误输出 &-代表关闭与它绑定的描述符

[root@s2 zpf]# ll file.txt abc.txt  1>&- 2>&-
[root@s2 zpf]# 
[root@s2 zpf]# ll file.txt abc.txt  1>/dev/null 2>/dev/null 
[root@s2 zpf]#

 

输入重定向

格式:command-line [n] <file或文件描述符&设备。命令默认从键盘获得的输入,改成从文件,或者其它打开文件以及设备输入。执行这个命令,将标准输入0,与文件或设备绑定。将由它进行输入。

[root@s2 zpf]# cat >out.txt
adsfafsd
1111111111
222222222222
3333333333
4444444444
[root@s2 zpf]# cat out.txt 
adsfafsd
1111111111
222222222222
3333333333


[root@s2 zpf]# cat >out.txt <file.txt 
[root@s2 zpf]# cat out.txt 
 HBaseTestCase.java

如下,#<< 这个连续两个小符号, 他代表的是『结束的输入字符』的意思。这样当空行输入eof字符,输入自动结束,不用ctrl+D

[root@s2 zpf]# cat >out.txt <<eof
> 11111
> 2222
> 33333
> 4444
> 555
> eof
[root@s2 zpf]# cat out.txt 
11111
2222
33333
4444
555

 

 

 

exec绑定重定向

几点说明:

(1)I/O重定向通常与 FD有关,shell的FD通常为10个,即 0~9;常用:0(stdin,标准输入)、1(stdout,标准输出)、2(stderr,标准错误输出),默认与keyboard、monitor、monitor有关。

(2)用 >  来改变送出的数据信道(stdout, stderr),使之输出到指定的档案

(3)在IO重定向 中,stdout 与 stderr 的管道会先准备好,才会从 stdin 读进资料;

(4)tee 命令是在不影响原本 I/O 的情况下,将 stdout 复制一份到档案去。

(5)bash(ksh)执行命令的过程:分析命令-变量求值-命令替代(``和$( ))-重定向-通配符展开-确定路径-执行命令;

(6)( ) 将 command group 置于 sub-shell 去执行,也称 nested sub-shell,它有一点重要的特性是:继承父shell的Standard input, output, and error plus any other open file descriptors。

(7)exec 命令:常用来替当前 shell 并重新启动一个 shell,换句话说,并没有启动子 shell。使用这一命令时任何现有环境都将会被清除。exec 在对文件描述符进行操作的时候,也只有在这时,exec 不会

       覆盖你当前的 shell 环境。

(8) n&- 表示将 n 号输出关闭

(9)  2>&1 表示:运行一个命令并把它的标准输出和输出合并。2>&1 也就是 FD2=FD1 ,这里并不是说FD2 的值 等于FD1的值,因为 > 是改变送出的数据信道,也就是说把 FD2 的 “数据输出通道” 改

         为 FD1 的 “数据输出通道”。如果仅仅这样,这个改变好像没有什么作用,因为 FD2 的默认输出和 FD1的默认输出本来都是 monitor,一样的。

(10) stdin, stdout, stderr 进行了重定向或关闭, 但没有保存原来的 FD(如果要保存, exec 9>&1,将fd1保存在fd9中), 恢复到 default 状态的方式:

         如果关闭了stdin,因为会导致退出,那肯定不能恢复。

         如关闭 stdout和stderr其中之一,可恢复,因他们默认均往monitor(但不知会否有其他影响)。如恢复重定向或关闭的 stdout: exec 1>&2 ,恢复重定向或关闭的stderr:exec 2>&1。

         如果stdout和stderr全部都关闭了,又没有保存原来的FD,可以用:exec 1>/dev/tty 恢复。

(11) cmd >a 2>&1 比 cmd >a 2>a更高效。

          cmd >a 2>a :stdout和stderr都直接送往文件 a ,a文件会被打开两遍,由此导致stdout和stderr互相覆盖。使用了两个互相竞争使用文件a的管道。

          cmd >a 2>&1 :stdout直接送往文件a ,stderr是继承了FD1的管道之后,再被送往文件a 。a文件只被打开一遍,就是FD1将其打开。

(12)  exec 1>outfilename # 打开文件outfilename作为stdout    。exec 2>errfilename # 打开文件 errfilename作为 stderr 。

 

下面的例子,将stdout(fd1)由屏幕重定向到文件,再恢复到屏幕。

#将fd9和stdout的fd1绑定,也即保存fd1的句柄资源信息到fd9
[root@s2 ~]# exec 9>&1

[root@s2 ~]# ll /proc/self/fd
total 0
lrwx------ 1 root root 64 May 19 17:45 0 -> /dev/pts/2
lrwx------ 1 root root 64 May 19 17:45 1 -> /dev/pts/2
lrwx------ 1 root root 64 May 19 17:45 2 -> /dev/pts/2
lr-x------ 1 root root 64 May 19 17:45 3 -> /proc/8138/fd
lrwx------ 1 root root 64 May 19 17:45 9 -> /dev/pts/2
[root@s2 ~]# touch /home/stdout
[root@s2 ~]# 

#将fd1的标准输出重定向到 /home/stdout文件
[root@s2 ~]# exec 1>/home/stdout

# ls的输出在屏幕上没有任何信息,全部在 /home/stdout中
[root@s2 ~]# ls

#恢复 fd1句柄资源的原来信息,即恢复默认的stdout输出
[root@s2 ~]# exec 1>&9
#恢复后,可以看到输出到屏幕
[root@s2 ~]# ls
1.pcap  anaconda-ks.cfg  Documents  dpi_log  err.txt       ftp.pcap              Music      pcap   Pictures  t1   tcpreplay-3.4.4         telnet_only.pcap  Templates  wcp_55_pcap_1452502359.pcap
a       Desktop          Downloads  eclipse  ftp_big.pcap  initial-setup-ks.cfg  nohup.out  perl5  Public    t60  tcpreplay-3.4.4.tar.gz  telnet.pcap       Videos     workspace

#  fd9任务完成,可以删除它啦
[root@s2 ~]# exec 9>&-

转载于:https://www.cnblogs.com/blue-sea-sky/p/5508189.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值