linux基础⑧-输入与输出

标准输入输出和错误输出

一个程序运行起来最少会打开三个文件,分别是标准输入(0)\标准输出(1)\错误输出(2)
三个文件都是fd(文件描述符)管理。

linux下使用标准输入文件stdin和标准输出文件stdout,来表示每个命令的输入和输出,还使用一个标准错误输出文件stderr用于输出错误信息。这三个标准输入输出系统缺省与控制终端设备相联系在一起。

因此,在标准情况下,每个命令通常从它的控制终端中获取输入,将输出打印到控制终端的屏幕上。但是也可以重新定义程序的标准输入文件stdin和标准输出文件stdout,将它们重新定向。最基本的用法是将它们重新定义到一个文件上,从一个文件获取输入,输出到另外的文件中等。标准输入文件stdin,通常对应终端的键盘;标准输出文件stdout和标准错误输出文件stderr,这两个文件都对应终端的屏幕。进程将从标准输入文件中得到输入数据,将正常输出数据输出到标准输出文件,而将错误信息送到标准错误文件中。

文件描述符

文件描述符是从0开始的整数,指向与进程相关的特定数据流。当进程启动时,通常打开三个文件描述符,分别对应三种标准的I/O:标准输入(文件描述符0),标准输出(文件描述符1),标准错误(文件描述符2)。

1)标准输入(STDIN):它是命令的输入,缺省和终端的键盘关联

2)标准输出(STDOUT):它是命令的输出,缺省和终端的屏幕关联

3)标准错误(STDERR):它是命令的错误信息输出,缺省也和终端的屏幕关联

4)如果进程打开了额外的文件进行输入和输出,则其被设置为下一个可用的文件描述符,从3到9

文件重重定向

标准覆盖输出重定向 1> 将程序输出的正确结果输出到指定的文件中,会覆盖文件原有的内容
标准追加输出重定向 1>> 将程序输出的正确结果以追加的方式输出到指定文件,不会覆盖原有文件
错误覆盖输出重定向 2> 将程序的错误结果输出到执行的文件中,会覆盖文件原有的内容
错误追加输出重定向 2>> 将程序输出的错误结果以追加的方式输出到指定文件,不会覆盖原有文件
标准输入重定向 << 将命令中接收输入的途径由默认的键盘更改为指定的文件或命令

实例

1.将正确的输出和错误的输出,分别打印到不同的文件中
su - lamp
find /etc/ > a.txt 2>b.txt

2.混合输出,无论是正确的输出还是错误的输出都定向到一个文件中
$ find /etc/ &>abc
$ find /etc/ >aa.txt 2>&1 #

3.合并两个文件,将两个文件的输出重新定向到一个新的文件中.
$ cat a.txt b.txt > c.txt

4.为了避免错误的输出大量显示在屏幕产生干扰,可以直接丢弃,
$ find /etc/ >bbbb.txt #将正确的输出写入bbbb文件,错误的输出直接输出到屏幕
$ find /etc/ >bbbb.txt 2>/dev/null #正确的输出写入到bbbb文件,错误的直接丢弃
$ find /etc/ 2>/dev/null #正确的输出到屏幕,错误的丢弃

5.[root@lsy~]# vim ping.sh
ping -W1 -c1 10.0.0.1
if [ $? -eq 0 ];then
echo “10.0.0.1 is up.”
else
echo “10.0.0.1 is down.”
fi
[root@lsy~]# chmod +x ping.sh
root@lsy~]# ./ping.sh

#改进后版,屏蔽掉ping命令产生所有输出,无论正常还是异常,都不看
[root@lsy~]# vim ping.sh
ping -W1 -c1 10.0.0.1 &>/dev/null
if [ $? -eq 0 ];then
echo “10.0.0.1 is up.”
else
echo “10.0.0.1 is down.”
fi

#改进后版,将人为定义的正确输出和错误输出定向到不同的文件中
[root@lsy~]# vim ping2.sh
ping -c1 10.0.0.1 &>/dev/null
if [ $? -eq 0 ];then
echo “10.0.0.1 is up.” >>up.txt
else
echo “10.0.0.1 is down.” >>down.txt
fi
[root@lsy~]# chmod +x ping2.sh
[root@lsy~]# ./ping2.sh #没有+x 则bash ping2.sh

6.如何把程序放入后台(screen)
(while :; do date; sleep 2; done) & #&表示将程序放置后台
(while :; do date; sleep 2; done) &>date.txt &
表示执行的程序和&>date.txt 视为一个命令, 然后将这一个命令使用&放置后台

7.在子shell中运行程序
[root@lsy~]# cd /boot; ls #分号都执行,|前面成功才执行后面, ||失败才执行后面
#subshell 中执行
[root@lsy~]# (cd /boot; ls)

8.将/etc/passwd 中的用户按 UID 大小排序
[root@lsy~]# sort -t":" -k3 -n /etc/passwd
[root@lsy~]# sort -t":" -k3 -n /etc/passwd -r
[root@lsy~]# sort -t":" -k3 -n /etc/passwd |head

8.统计当前/etc/passwd 中用户使用的 shell 类型
#思路:取出第七列(shell) | 排序(把相同归类)| 去重
[root@lsy~]# awk -F: ‘{print $7}’ /etc/passwd
[root@lsy~]# awk -F: ‘{print $7}’ /etc/passwd |sort
[root@lsy~]# awk -F: ‘{print $7}’ /etc/passwd |sort |uniq
[root@lsy~]# awk -F: ‘{print $7}’ /etc/passwd |sort |uniq -c

9.统计网站的访问情况 top 2
#思路: 打印所有访问的连接 | 过滤访问网站的连接 | 打印用户的 IP | 排序 | 去重
[root@lsy~]# yum -y install httpd
[root@lsy~]# systemctl start httpd
[root@lsy~]# systemctl stop firewalld
[root@lsy~]# ss -an |grep :80 |awk -F":" ‘{print $8}’ |sort |uniq -c
[root@lsy~]# ss -an |grep :80 |awk -F":" ‘{print $8}’ |sort |uniq -c |sort -k1 -rn |head -n 20

10.打印当前所有 IP
[root@lsy~]# ip addr |grep 'inet ’ |awk ‘{print $2}’ |awk -F"/" ‘{print $1}’

11.打印根分区已用空间的百分比(仅打印数字)
[root@lsy~]# df |grep ‘/$’ |awk ‘{print $5}’ |awk -F"%" ‘{print $1}’
[root@lsy~]# ip addr |grep 'inet ’ |tee ip.txt |awk -F"/" ‘{print $1}’ |awk ‘{print $2}’

12.重定向与 tee 区别
[root@lsy~]# date > date.txt #直接将内容写入date.txt文件中
[root@lsy~]# date |tee date.txt #命令执行会输出至屏幕,但会同时保存一份至date.txt文件中

13.xargs参数传递,主要让一些不支持管道的命令可以使用管道技术
which cat|xargs ls- l
ls |xargs rm -fv
ls |xargs cp -rvt /tmp/ -或-> ls | xargs -I {} cp -rv {} /tmp/ #t目标 源
ls |xargs mv -t /tmp/ -或-> ls | xargs -I {} mv {} /tmp

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章