重定向和文件的查找及软硬链接使用

本节所讲内容:

  • 文件描述符0 1 2
  • 重定向的含义
  • 管道的使用
  • tee命令
  • 文件查找
  • 命令判断
  • 文件的软硬链接
  • ln命令创建软硬链接

文件又可分为:普通文件、目录文件、链接文件、设备文件

Linux系统使文件来描述各种硬件设备资源:/dev/sda /dev/sdb /dev/sr0

文件描述符定义

文件描述符:是内核为了高效管理已被打开的文件所创建的索引,用于指向被打开的文件,所有执行I/O操作的系统调用都通过文件描述符;文件描述符是一个简单的非负整数,用于表明每一个进程所打开的文件,程序刚刚启动的时候,第一个打开的文件是0,第二个是1,以此内推,也可以理解是一个文件的身份ID

用户通过操作系统处理信息的过程中,使用的交互设备文件(键盘,鼠标,显示器)

NumberChannel nameDescriptionDefault connectionUsage
0stdinStandard inputKeyboardread only
1stdoutStandard outputTerminalwrite only
2stderrStandard errorTerminalwrite only
3+filenameOther filesnoneread and/or write

输入输出标准说明

STDIN标准输入默认的设备是键盘文件编号为:0
STDOUT标准输出默认的设备是显示器文件编号为:1也可以重定向到文件
STDERR标准错误默认的设备是显示器文件编号为:2也可以重定向到文件

标准说明 .assets/标准说明.png)

例:查看一个进程打开了哪些文件?

语法:ll /proc/进程ID/fd

vim /etc/passed
ps -aux | grep passwd

在另一个终端上执行

ll /proc/8175/fd

llprc .assets/llprc.png)

注:这些0,1,2,4就是文件的描述符,一个进程启动时,都会打开3个文件:标准输入、标准输出和标准出错处理,这3个文件分别对应文件描述符为0、1和2也就是宏替换STDIN_FILENO、STDOUT_FILENO和STDERR_FILENO

注:对文件描述符的操作就是对文件本身的操作,我们可以直接通过操作文件描述来修改文件

例2:查看和临时设置一个进程最多可以打开几个文件,即:一个进程可以打开的文件描述符限制

查看一个进程最多可以同时打开的文件数

ulimit -n

临时修改修改一个进程最多可以同时打开的文件数为2048

ulimit -n 2048

永久修改,会在系统调优时详细讲

重定向的含义

输出重定向

定义:将命令的正常输出结果保存到指定的文件中,而不是直接显示在显示器的屏幕上

重定向输出使用> >>操作符

语法:>文件名:表示将标准输出的内容,写到后面的文件中,如果此文件名已经存在,将会覆盖原文件中的内容

>>文件名:表示将标准输出的内容,追加到后面的文件中,若重定向的输出文件不存在,则会新建该文件

例1:查看当前主机的CPU的类型保存到cpu.txt文件中(而不是直接显示到屏幕上)

cat /proc/cpuinfo > cpu.txt

例2:将内核的版本信息追加到cpu.txt的末尾

uname -a >> cpu.txt

例3:清空一个文件

> cpu.txt

输入重定向

例1:将命令中接收输入的途径由默认的键盘改为其他文件,而不是等待从键盘输入

[root@master ~]# grep root < /etc/passwd
root:x:0:0:root:/root:/bin/bash
operator:x:11:0:operator:/root:/sbin/nologin

EOF

EOF本意是End Of File,表明到了文件默认,EOF通常与<<结合使用,<<EOF表示后续的输入作为子命令或子shell的输入,直到遇到EOF,再次返回到主调shell,可将其理解为分解符(delimiter),既然是分界符,那么形式自然是不固定的,这里可以将EOF进行自定义,但是前后的EOF必须成对出现且不能和shell命令冲突

例1:以<<EOF开始,以EOF结束

cat > a.txt << EOF

cat EOF .assets/cat EOF.png)

注:直到你输入EOF才为止

假如你想输入EOF或者eof不停止,那么也可以这样:

例2:以<<abc开始,以abc结束:

cat > a.txt << abc

cat abc .assets/cat abc.png)

例3.在脚本中我们可以通过重定向输入来打印消息菜单,在使用的时候需要在<<右边跟上一对终止符,终止符是可以自定义的

test.sh中 写入:

#/bin/bash



cat << EOF
======================================
1.mysql
2.httpd
3.oracle
======================================
EOF

然后执行:

chmod +x test.sh
 ./test.sh

可以看到:

chmode EOF .assets/chmode EOF.png)

错误重定向

将命令执行过程中出现的错误信息(选项或参数错误)保存到指定的文件,而不是直接显示到显示器

作用:错误信息保存到文件

操作符:错误重定向符号:2>

注:标准输入:1<或简写< 标准输出:0>或简写>

2指的是标准错误输出的文件描述符(在使用标准的输入和输出省略了1、0编号)

在实际应用中,错误重定向可以用来收集执行的错误信息,为排错提供依据,对于shell脚本还可以将无关紧要的错误信息重定向到空文件/dev/null,以保持脚本输出的简洁

例1:将错误显示的内容和正确显示的内容分开

ls /etc/passwd xxxx
ls /etc/passwd xxxx > a.txt

cat a .assets/cat a.png)

cat a.txt
ls /etc/passwd xxxx 2> a.txt

ls cannot .assets/ls cannot.png)

注:使用2>操作符时,会像使用>一样覆盖目标文件的内容,若追加而不覆盖文件的内容可以使用2>>操作符

null黑洞和zero空文件

/dev/null看作"黑洞",所有写入它的内容都会永久丢失,而尝试从它那儿读取内容则什么也读不到,然而/dev/null对命令和脚本都非常的有用

例1:

echo aaaa > /dev/null
cat /dev/null

echo aaaa .assets/echo aaaa.png)

例2:

rm aa.txt
rm aa.txt 2> /dev/null

rm aa .assets/rm aa.png)

2./dev/zero在类UNIX操作系统中,/dev/zero是一个特殊的文件,当你读它的时候,它会提供无限的空字符(NULL ASCII值为0x00),典型的用法是用它来产生一个特定大小的空白文件

例1:使用dd命令产生一个50M的文件

参数:

  • if代表输入文件,如果不指定if,默认就会从stdin中读取输入
  • of代表输出文件,如果不指定of,默认就会将stdout作为默认输出
  • bs代表字节为单位的块大小
  • count代表被复制的块数
dd if=/dev/zero of=b.txt bs=1M count=50
ll -h b.txt

ddb .assets/ddb.png)

例2:正确的内容写入一个文件,错误的写入一个文件

ls /tmp xxx >ok.txt 2>error.txt

okerror .assets/okerror.png)

&>和&符号

&表示等同于的意思

例1:把正确和错误的消息输入到相同的位置

1>&2:把标准输出重定向到标准错误

2>&1:把标准错误重定向到标准输出

如图:

错误到正确 .assets/错误到正确.png)

ls /tmp **** >1.txt 2>&1
ls /tmp **** 2>2.txt 1>&2

例2:工作中shell脚本中的>/dev/null 2>&1是什么意思?

cat /etc/passwd >/dev/null 2>&1

注:将标准输出和错误输出全部重定向到/dev/null中,也就是将产生的所有信息丢弃

管道|的使用

语法:command -a|command -b|command -c

管道 .assets/管道.png)

注:

  • 管道命令只处理前一个命令正确输出,不处理错误输出
  • 管道右边的命令,必须能够接收标准输入的数据流命令才行
  • 管道符可以把两条命令连起来,它可以连接多个命令使用

例:

ps -aux | grep sshd

tee命令(了解)

功能:读取标准输入的数据,并将其内容输出成文件

语法:tee [a] [--help] [--version] [文件]

参数:

  • -a --append内容追加到给定的文件而非覆盖
  • --help 在线帮助

tee指令会从标准输入设备读取数据,将其内容输出到标准输出设备,同时保存成文件

tee .assets/tee.png)

例1:将磁盘使用的信息写入文件

df -h | tee disk.log

例2:将磁盘使用的信息追加到文件

df -h | tee -a disk.log

注:可以用来记录日志

which-whereis-locate-grep-find查找命令

查找文件一般有有一下几个命令:

  • which 查看可执行文件的位置
  • whereis查看可执行文件的位置及相关文件
  • locate配合数据库缓存,快速查看文件位置
  • grep 过滤匹配,它是一个文件搜索工具
  • find 查看相关文件

例:

which

[root@master ~]# which cd
/usr/bin/cd

whereis:

[root@master ~]# whereis cd
cd: /usr/bin/cd /usr/share/man/man1/cd.1.gz /usr/share/man/mann/cd.n.gz

locate:

locate命令和find -name功能差不多,是它的另一种写法,但是要比这个find搜索快得多,因为find命令查找的是具体目录文件,而locate它搜索的是一个数据库/var/lib/mlocate/mlocate.db,这个数据库中存有本地所有的文件信息,这个数据库是Linux自动创建并每天自动更新维护,相关的配置信息在/etc/updatedb.conf,查看定时任务信息在/etc/cron.daily/mlocate

例:

[root@master ~]# locate  *.doc
/root/Python-3.7.3/Tools/scripts/dutree.doc
/usr/lib/kbd/keymaps/legacy/i386/qwerty/no-latin1.doc
/usr/lib64/python2.7/pdb.doc
/usr/share/doc/doxygen-1.8.5/examples/page.doc

注:如果对当天文件进行查找,需要手动更新数据库updatedb

updatedb

注:如果没有locate命令,则:

yum install mlocate

grep查找使用

作用:过滤,它能够使用正则表达式来搜索文本,并把结果打印出来

参数:

  • -v 取反
  • -i 忽略大小写
  • ^^开头
  • $$结尾
  • -n 对过滤的内容加上行号
  • | 或者的意思

例:

[root@master ~]# ps -aux | grep ssh
root       1006  0.0  0.2 112936  4324 ?        Ss   16:44   0:00 /usr/sbin/sshd -D
root       1533  0.0  0.3 158928  6032 ?        Ss   16:45   0:00 sshd: root@pts/0
root       1938  0.0  0.0 112812   968 pts/0    S+   17:37   0:00 grep --color=auto ssh

我们可以看到最后面还是有个grep,假如我们不想要这个grep,可以取反:

[root@master ~]# ps -aux | grep ssh | grep -v grep
root       1006  0.0  0.2 112936  4324 ?        Ss   16:44   0:00 /usr/sbin/sshd -D
root       1533  0.0  0.3 158928  6032 ?        Ss   16:45   0:00 sshd: root@pts/0

bash为结尾的:

[root@master ~]# grep bash$ /etc/passwd
root:x:0:0:root:/root:/bin/bash
testuser1:x:1000:1000::/home/testuser1:/bin/bash
testuser2:x:1001:1001::/home/testuser2:/bin/bash
testuser3:x:1002:1002::/home/testuser3:/bin/bash

|例:过滤nologin或者root,\是转义符

[root@master ~]# grep "nologin\|root" /etc/passwd
root:x:0:0:root:/root:/bin/bash
bin:x:1:1:bin:/bin:/sbin/nologin
daemon:x:2:2:daemon:/sbin:/sbin/nologin
adm:x:3:4:adm:/var/adm:/sbin/nologin
lp:x:4:7:lp:/var/spool/lpd:/sbin/nologin
mail:x:8:12:mail:/var/spool/mail:/sbin/nologin
operator:x:11:0:operator:/root:/sbin/nologin

如果不想加转义符号,则可以egrep:

[root@master ~]# egrep "nologin|root" /etc/passwd

find命令使用

格式:findpathname-options[-print]
命令字路径名称选项输出

参数:

pathnamefind命令所查找的目标路径,例如用.来表示当前路径,用/来表示系统根目录
-name按照文件名查找文件
-perm按照文件权限来查找文件,例如:644 755等
-prune使用这一选项可以使find命令不在当前指定的目录中查找(排除),如果同时使用-depth选项,那么-prune将被find命令忽略
-depth在查找文件时,首先查找当前目录中的文件,然后再在其子目录中查找
-user按照文件属主来查找文件
-group按照文件所属的组来查找文件
-mtime-n/+n 按照文件的更改时间来查找文件
-n表示文件更改时间距现在n天以内
+n表示文件更改时间距现在n天以前
-type查找某一类型的文件
b块设备文件
d目录
c字符设备文件
p管道文件
l符号链接文件
f普通文件
-size n查找符合指令的文件大小的文件
-exec对匹配的文件执行该参数所给出的其它Linux命令,相应命令的形式为{}\;,注意{}\之间的空格,{}代表查到的内容

例1:查看当前目录下所有的txt格式的文件

find ./ -name "*.txt"

例2:按照更改时间或访问时间等查找文件

  • mtime:文件最后次修改的时间
  • atime:最后一次访问的时间
  • ctime:文件的最后次变化的时间,也就是修改的时间

查找在root目录下更改时间在1天内的文件

find /root/ -mtime -1

例3:对查找内容执行相应命令

-exec这个选项参数后面可以自定义的shell命令,格式如下:

创建3个文件,分别名叫1.back 2.back 3.back

touch {1,2,3}.back

对找到的这3个文件执行ls -l操作:

find . -name "*.back" -exec ls -l {} \;

例4:查找多个类型文件

比较符的使用:

  • -a and和
  • -o or或者
  • + 超过
  • - 少于

创建一个a.pdfbach.sh

touch a.pdf bach.sh

查找这两个文件

find . -name ".sh" -o -name ".pdf"

例5:查找文件大小大于20k小于50k的文件

find /etc -size +20k -a -size -50k

例6:按照权限查找:-prem

查找等于755权限的文件或目录

find /bin/ -perm 755

查找至少有644权限的文件或目录

find /bin/ -perm -644
最后修改:2023 年 05 月 10 日
如果觉得我的文章对你有用,请随意赞赏