Linux-标准IO和管道

Linux

打开的文件都有一个fd:file description(文件描述符)

[root@centos7 data]#exec 8<>/data/hosts

[root@centos7 data]#ll /proc/$$/fd

total 0

lrwx——. 1 root root 64 Mar 30 14:22 0 -> /dev/pts/3

lrwx——. 1 root root 64 Mar 30 14:22 1 -> /dev/pts/3

lrwx——. 1 root root 64 Mar 30 14:22 2 -> /dev/pts/3

lrwx——. 1 root root 64 Mar 30 16:58 255 -> /dev/pts/3

lrwx——. 1 root root 64 Mar 30 17:17 8 -> /data/hosts

[root@centos7 data]#cat /proc/$$/fd/8

127.0.0.1   localhost localhost.localdomain localhost4 localhost4.localdomain4

::1         localhost localhost.localdomain localhost6 localhost6.localdomain6

其实就是软链接

 

Linux给程序提供三种I/O设备

标准输入(STDIN)-0 默认接受来自键盘的输入

标准输出(STDOUT)-1 默认输出到终端窗口

标准错误(STDERR)-2 默认输出到终端窗口

I/O重定向:改变默认位置

 

标准输出重定向:>,或者1>

ls > /dev/pts/5

ls > /data/ls.out

 

标准错误重定向:2>

 

追加不覆盖:>>

 

对的和错的分别重定向

ls /error /data >>/data/f1 2>>/data/f2

 

对的和错的放在一起

ls /error /data >all.log 2>&1

注意次序!

 

新写法:

ls /error /data &>all.log

(ls /error /data 2>&1)>all.log

 

set -C     不允许覆盖,但允许追加

|>          强制覆盖

set+C     允许覆盖

 

/dev/null      垃圾箱,无底洞,不希望输出和保存的数据可导到这里

 

cat 啥都不跟的话会回显,就既有标准输入,又有标准输出

 

tr命令

tr 转换和删除字符

tr [OPTION]… SET1 [SET2]

选项:

-c -C –complement:取字符集的补集

-d –delete:删除所有属于第一字符集的字符

-s –squeeze-repeats:把连续重复的字符以单独一个字符表示

-t –truncate-set1:将第一个字符集对应字符转化为第二字符集对应的字符[root@centos7 data]#tr ‘a-z’ ‘A-Z’

asdf1234

ASDF1234

 

[root@centos7 ~]#tr ‘a-z’ ‘A-Z’ < anaconda-ks.cfg > /data/log

[root@centos7 ~]#cat /data/log

 

[root@centos7 doc]#tr -dc ‘abc’

23423aabc3sff

aabc

 

[root@centos7 doc]#tr -s “abc”

aaabbbacde

abacde

 

[root@centos7 data]#hexdump -C win.txt

00000000  61 0d 0a 62 0d 0a 63                              |a..b..c|

00000007

[root@centos7 data]#tr -d ‘\15’ < win.txt >win2.txt

[root@centos7 data]#hexdump -C win2.txt

00000000  61 0a 62 0a 63                                    |a.b.c|

00000005

[root@centos7 data]#tr -d ‘\r’ < win.txt >win3.txt

[root@centos7 data]#hexdump -C win3.txt

00000000  61 0a 62 0a 63                                    |a.b.c|

00000005

 

[root@centos7 data]#cat win3.txt

a  b     c

[root@centos7 data]#tr -s ‘ ‘ <win3.txt

a b c

 

[root@centos7 data]#df > df.log

[root@centos7 data]#tr -s ‘ ‘ : < df.log

Filesystem:1K-blocks:Used:Available:Use%:Mounted:on

/dev/sda2:51474912:3405572:45431516:7%:/

devtmpfs:523248:0:523248:0%:/dev

tmpfs:537748:0:537748:0%:/dev/shm

tmpfs:537748:14544:523204:3%:/run

tmpfs:537748:0:537748:0%:/sys/fs/cgroup

/dev/sda1:999320:130824:799684:15%:/boot

/dev/sda3:20511312:45420:19400932:1%:/data

tmpfs:107552:12:107540:1%:/run/user/42

tmpfs:107552:0:107552:0%:/run/user/0

/dev/sr0:8490330:8490330:0:100%:/mnt

 

[root@centos7 qjy]#echo abcdef | tr ‘abcd’ ‘xyz’

xyzzef

[root@centos7 qjy]#echo abcdef | tr -t ‘abcd’ ‘xyz’

xyzdef

 

多行重定向

mail [-s] “hello” qjy@magedu.com << EOF

EOF

 

mail [-s] “hello” qjy@magedu.com < mail.txt

 

邮件里可用命令,如`hostname`

 

管道

 

cat mail.txt | mail -s ‘hello’ root

 

| 管道只处理标准输出STDOUT,不处理STDERR,所以要想处理错误信息的话要重定向错误成标准输出:

ls /boot /error 2>&1 | tr ‘a-z’ ‘A-Z’

或新写法:

ls /boot /error |& tr ‘a-z’ ‘A-Z

比较老的系统如RHEL 5.4等可能不支持’

 

例:计算从1+2+..+100

echo {1..100} | tr ‘ ‘ + | bc

seq -s + 100 | bc

也可用循环

 

less :一页一页地查看输入

ls -l /etc | less

mail:通过电子邮件发送输入

echo “test email” | mail -s “test” user@example.com

lpr:把输入发送给打印机

echo “test print” | lpr -P printer_name

 

管道中-符号

示例:

将/home里面的文件打包,但打包的数据不是记录到文件,而是传送到stdout,经过管道后,将tar -cvf – /home传送给后面的tar -xvf – ,后面的这个 – 则是取前一个命令的 stdout,因此,就不需要使用临时file了

tar -cvf – /home | tar -xvf –

 

重定向到多个目标(tee)

命令1 | tee [-a ] 文件名 | 命令2

把命令1的STDOUT保存在文件中,做为命令2的输入

-a 追加

使用:

保存不同阶段的输出

复杂管道的故障排除

同时查看和记录输出

 

 

例:创建随机小写字母文件名

[root@centos7 data]#touch `openssl rand -base64 12 | tr -dc ‘[:lower:]’`

本文来自投稿,不代表Linux运维部落立场,如若转载,请注明出处:http://www.178linux.com/94976

(0)
qjyqjy
上一篇 2018-04-05 13:48
下一篇 2018-04-05 15:31

相关推荐

  • d

    ““ function fun(){ echo “这是一句非常牛逼的代码”;}fun(); ““

    Linux笔记 2018-07-09
  • Linux系统日志管理

    Linux系统中的日志记录了系统每天发生的各种各样的事情,你可以通过它来检查错误发生的原因,或者受到攻击时攻击者留下的痕迹。日志对于安全来说,非常重要。

    2018-06-25
  • rsyslog、nsswitch、pam

    rsyslog: 日志:历史事件日志 历史事件: 时间,事件 事件级别(日志级别):事件的关键性程度; 事件:系统引导启动、应用程序启动、应用程序尤其是服务类应用程序运行过程中的一些事件; 系统日志服务: syslog: syslogd: system klogd:kernel 事件格式较为简单时,可统一由syslog进行记录: 事件产生的日期时间 主机 进…

    Linux笔记 2018-06-07
  • LVS负载均衡基础

    LVS负载均衡基础

    Linux笔记 2018-05-23
  • mysql数据库四

    备份和还原 主从复制,

    2018-06-11
  • centOS6.9 防火墙的关闭以及开启

    有的时候,我们需要对系统的防火墙进行操作,今天小编就给大家讲解一下如何开启以及关闭CentOS6.9系统下的防火墙。 输入:cat /etc/issue 查看版本 (一)通过service命令 service命令开启以及关闭防火墙为即时生效,下次重启机器的时候会自动复原。 查看防火墙状态:service iptables status ,记得在CentOS6…

    Linux笔记 2018-04-20