在linux下实现重定向和文件查找

本文详细解读Linux系统中的文件类型,包括普通文件、目录文件、链接文件和设备文件,并介绍文件描述符的概念及作用。此外,深入讲解了标准输入输出重定向的原理和应用场景,如输出重定向到文件、错误重定向及使用`ulimit-n`控制文件描述符数量。
摘要由CSDN通过智能技术生成

LINUX下一切皆文件

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

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

文件描述符定义

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

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

输入输出标准说明

STDIN 标准输入 默认的设备是键盘 文件编号为:0

STDOUT 标准输出 默认的设备是显示器 文件编号为:1 ,也可以重定向到文件

STDERR 标准错误 默认的设备是显示器 文件编号为:2 ,也可以重定向到文件

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

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

例:

# vim /etc/passwd

# ps -axu | grep passwd

root 4602 2.1 0.2 151600 5300 pts/2 S+ 15:30 0:00 vim /etc/passwd

# ll /proc/4602/fd #查看打开的文件

总用量 0

lrwx------ 1 root root 64 5月 14 15:30 0 -> /dev/pts/2

lrwx------ 1 root root 64 5月 14 15:30 1 -> /dev/pts/2

lrwx------ 1 root root 64 5月 14 15:30 2 -> /dev/pts/2

lrwx------ 1 root root 64 5月 14 15:30 4 -> /etc/.passwd.swp

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

/proc/进程ID/fd #这个fd目录下,专门存文件描述符

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

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

1024

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

# ulimit -n

2048

永久修改,会在第三阶段讲系统调优时讲。

重定向的含义

输出重定向

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

重定向输出使用”>” “>>” 操作符号

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

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

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

# cat /proc/cpuinfo > cpu.txt

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

# uname -a >> cpu.txt

例3:清空一个文件

# > cpu.txt

输入重定向

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

# grep root /etc/passwd

root:x:0:0:root:/root:/bin/bash

operator:x:11:0:operator:/root:/sbin/nologin

# grep root < /etc/passwd

root:x:0:0:root:/root:/bin/bash

operator:x:11:0:operator:/root:/sbin/nologin

例2:mysql中数据导入

例: # mysql -uroot -p123456 < xuegod.sql #将xuegod.sql导入mysql数据库中。这个命令现在不能执行,大家先知道有这种写法就可以了。后期在第二阶段讲mysql时,会讲。

EOF

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

例1:以<<EOF开始,以EOF结尾 。

# cat > a.txt <<eof< span=""></eof<>

> dfsd

> sdfs

> sdf

> dfs

> EOF

# cat a.txt

dfsd

sdfs

sdf

dfs

例2:以ccc作为分界符

[root@localhost ~]# cat a.txt <<ccc< span=""></ccc<>

> eof

> EOF

> ccc

[root@localhost ~]# cat a.txt

eof

EOF

例3:在脚本中我们可以通过重定向输入来打印消息菜单

在使用的时候需要在”<< “右边跟一对终止符。终止符是可以自定义

# vim p.sh #写入以下内容

#!/bin/bash

cat <<efo< span=""></efo<>

========================

1.mysql

2.httpd

3.oracle

=======================

efo

# chmod +x

# p.sh #查看效果

错误重定向

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

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

操作符: 错误重定向符号:2> ; 标准输入:1< 或简写 < ; 标准输出:0> 或 >

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

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

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

# ls /etc/passwd xxx

ls: 无法访问xxx: 没有那个文件或目录

/etc/passwd

# ls /etc/passwd xxx > a.txt

ls: 无法访问xxx: 没有那个文件或目录

# cat a.txt

/etc/passwd

# ls /etc/passwd xxx 2> a.txt

/etc/passwd

# cat a.txt

ls: 无法访问xxx: 没有那个文件或目录

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

null黑洞和zero空文件

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

# echo aaaa > /dev/null

# cat /dev/null #什么信息也看不到

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

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

参数:if 代表输入文件。如果不指定if,默认就会从stdin中读取输入。

of 代表输出文件。如果不指定of,默认就会将stdout作为默认输出。

bs 代表字节为单位的块大小。

count 代表被复制的块数。

# dd if=/dev/zero of=b.txt bs=1M count=50

50+0 records in

50+0 records out

52428800 bytes (52 MB) copied, 0.228653 s, 229 MB/s

# du -sh b.txt

50M b.txt

# cat b.txt #什么也不显示

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

# ls /tmp xxxx >ok.txt 2> err.txt

&>和>&符号

&表示等同于的意思

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

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

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

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

# ls /tmp xxxx >1.txt 2>&1

或:

# ls /tmp xxxx 2>2.txt 1>&2

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

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值