linux 重定向,重定向符号

老铁们,大家好,相信还有很多朋友对于linux 重定向和重定向符号的相关问题不太懂,没关系,今天就由我来为大家分享分享linux 重定向以及重定向符号的问题,文章篇幅可能偏长,希望可以帮助到大家,下面一起来看看吧!

Linux重定向

输出重定向:

我们使用>或者>>对输出进行重定向。符号的左边表示文件描述符,如果没有的话表示1,也就是标准输出,符号的右边可以是一个文件,也可以是一个输出设备(Linux中万物皆文件,即设备也是文件)。当使用>时,会判断右边的文件存不存在,如果存在的话就先删除,然后创建一个新的文件,不存在的话则直接创建。但是当使用>>进行追加时,则不会删除原来已经存在的文件。

格式:

command-line [n]>文件

这条命令意思是:将一条命令执行结果(标准输出,或者错误输出,本来都要打印到屏幕上面的)重定向其它输出设备(文件)1,2分别是标准输出,错误输出。

实例:

输入重定向

在理解了输出重定向之后,理解输入重定向就会容易得多。对输入重定向的基本命令如下:

我们使用<对输入做重定向,如果符号左边没有写值,那么默认就是0。

格式:

command-line [n]<文件

命令默认从键盘获得的输入,使用输入重定向改成从文件,或者其它打开文件以及设备输入。执行这个命令,将标准输入0,与文件或设备绑定,将由它进行输入。

实例:

文件描述符的复制表示复制文件描述符到另一个文件描述符中,也就是将该文件描述符重定向到另一个文件描述符所绑定的文件,使用”&”进行复制。

想必很多人都知道>file 2>&1的作用,它等价于&>file,表示标准输出和标准错误都重定向到file中。那它和 2>&1>file有什么区别呢?

首先解释>file 2>&1。这里分两个过程:先打开file,再将fd=1重定向到file文件上,这样file文件就成了标准输出的输出目标;之后再将fd=2复制于fd=1,而fd=1此时已经重定向到file文件上,因此fd=2也重定向到file上。所以,最终的结果是标准输出重定向到file上,标准错误也重定向到file上。

再解释 2>&1>file。这里也分两个过程:先将fd=2复制于fd=1,而此时fd=1重定向的文件是默认的/dev/stdout,所以fd=2也重定向到/dev/stdout;之后再将fd=1重定向到file文件上。也就是说,这里的标准错误和标准输出仍然是分开输出的,只不过是使用/dev/stdout替代了/dev/stderr,使用file替代了/dev/stdout。所以,最终的结果是标准错误输出到/dev/stdout,即屏幕上,而标准输出将输出到file文件中。

可以使用下面的命令来测试 2>&1>file。第一个ls命令是正确的,结果输出到/tmp/fff.log中,第二个ls命令是错误的,结果将直接输出到屏幕上。

最后需要说明的是一种特殊情况,如果是>&[word],且word不是一个数值,比如 echo haha>&/tmp/fff.log,那么>&word和&>word是等价的,都表示>word 2>&1,即标准错误和标准输出都重定向同一个目标。参考man bash的”Redirecting Standard Output and Standard Error”段落。

如果在命令中直接改变重定向的位置,那么命令执行结束的时候描述符会自动还原。正如上面的ls/boot 2>&1>/tmp/fff.log命令,在ls执行结束后,fd=2还原回默认的/dev/stderr,fd=1还原回默认的/dev/stdout。

但是我们可以通过exec程序直接在当前的shell环境下改变重定向目标,只有在当前shell退出的时候才会释放描述符的绑定。

Tips:shell的内建命令exec将并不启动新的shell,而是用要被执行命令替换当前的shell进程,并且将老进程的环境清理掉,而且exec命令后的其它命令将不再执行。

不过,要注意一个例外,当exec命令来对文件描述符操作的时候,就不会替换shell,而且操作完成后,还会继续执行接下来的命令。

例如:下面的命令将标准错误fd=2指向fd=3对应的文件上。

因此,我们可能在一段程序执行结束后,需要将描述符还原到原来的位置,并关闭不再需要的描述符。毕竟描述符也是资源,是有限的(ulimit-n)。

[n]<> filename:打开filename,并指定其文件描述符为n,该描述符是可读、可写的描述符。若不指定n则默认为0,若filename文件不存在,则先创建filename文件。

文件描述符的移动表示将文件描述符1移动到描述符2上,同时关闭文件描述符1。

[n]>&digit-:将文件描述符digit代表的输出文件移动到n上,并关闭digit值的描述符。

[n]<&digit-:将文件描述符digit代表的输入文件移动到n上,并关闭digit值的描述符。

简述linux系统中有哪些重定向的方式

重定向能够实现Linux命令的输入输出与文件之间重定向,以及实现将多个命令组合起来实现更加强大的命令。这部分涉及到的比较多的命令主要有:

cat:连接文件 sort:排序文本行 uniq:忽略或者报告重复行

wc:统计文件的行数、词数、字节数

grep:打印匹配制定模式的行

head:输出文件的头部 tail:输出文件的尾部

tee:从标准输入读,并往标准输出或者文件写

重定向标准输出

使用>可以将本来出现在屏幕的标准输出信息重定向到一个文件中。

使用>>可以在实现重定向时不覆盖原有内容,而是在文件末尾追加内容。

重定向标准错误信息到文件

使用文件描述符,在shell中,默认用数字0,1,2分别代表标准输入、标准输出、标准错误。

屏蔽不想看到的信息

Linux中有一个特殊的文件/dev/null,这个文件叫做bit bucket,可以接受输入信息但是什么都不做。例如:ls/usr/>/dev/null

重定向标准输入

cat命令可以接受一组文件为参数,将这些文件复制到标准输出。我们前面的例子中已经多次使用到cat命令来将文本文件的内容读取到屏幕上。cat还有一个很重要的功能:接受一组文件,然后通过重定向将他们重新组合到一个文件中。

cat ls1 ls2> ls这个命令将ls1和ls2文件中的内容合并到ls文件中了。cat命令的这种功能不仅仅适用于文本文件,同样对二进制文件有效。这个场景主要在将多个压缩包文件合并到一个压缩包中用到。

cat也可以不传递参数,这种情况下,cat会重定向标准输入到标准输出。

管道

Linux提供|操作符,该操作符可以将一个命令的输出作为另一个命令的输入,这样通过多个命令的协作来完成一些比较复杂的内容。比如,我们可以通过uniq命令来排除重复的行。但是uniq命令往往需要和sort命令配合使用。因为uniq接收一组排好序的文本,而刚好sort可以将文本行排序。

实践技巧学习Linux中的IP重定向linux的ip重定向

IP重定向是Linux中的一种技术,主要用于将收到的来自特定源的数据包发送到另一端的目的地。它能够有效地将来自同一网络中同一个入口地址的数据包重新定向到另一个网络中的目的地。学习Linux中的IP重定向可以帮助优化网络的性能。

要学习Linux中的IP重定向,首先需要了解iptables命令。iptables是一个用于管理Linux内核中的Netfilter防火墙的命令行工具,它可以创建筛选规则用于改变网络报文如何穿越内核。

在使用iptables命令前,我们必须了解系统当前的iptables配置。可以使用以下命令来查看系统中的iptables规则:

`iptables-L`

此命令将返回当前的iptables规则列表,这样您就可以开始添加或删除重定向规则了。

要添加重定向规则,可以使用以下命令:

`iptables-t nat-A PREROUTING-d-j DNAT–to `

该命令将源地址重定向到目的地址。

最后,我们需要保存我们当前添加的规则,可以使用以下命令:

`/sbin/iptables-save`

这将会将 IPtables配置保存到/etc/sysconfig/iptables文件中。

综上所述,学习Linux中的IP重定向可以帮助优化网络的性能。首先要了解iptables命令,接下来可以使用iptables命令来创建和管理与重定向相关的筛选规则。最后,使用/sbin/iptables-save命令将规则写入磁盘。通过学习和熟练掌握使用IP重定向,可以帮助您更好地优化网络性能。

阅读剩余
THE END