linux命令重定向标准 linux各种重定向及其含义

LINUX 标准错误输出重定向用途:不挂断地运行命令 。
语法:nohup Command [ Arg … ] []
无论是否将 nohup 命令的输出重定向到终端,输出都将附加到当前目录的 nohup.out 文件中 。
如果当前目录的 nohup.out 文件不可写,输出重定向到 $HOME/nohup.out 文件中 。
如果没有文件能创建或打开以用于追加,那么 Command 参数指定的命令不可调用 。
退出状态:该命令返回下列出口值:
126 可以查找但不能调用 Command 参数指定的命令 。
127 nohup 命令发生错误或不能查找由 Command 参数指定的命令 。
否则 , nohup 命令的退出状态是 Command 参数指定命令的退出状态 。
用途:在后台运行
一般两个一起用
3.为什么呢 21 要写在后面?
首先是commandfile将标准输出重定向到file中,21 是标准错误拷贝了标准输出的行为,也就是同样被重定向到file中 , 最终结果就是标准输出和错误都被重定向到file中 。
21 标准错误拷贝了标准输出的行为,但此时标准输出还是在终端 。file 后输出才被重定向到file,但标准错误仍然保持在终端 。
用strace可以看到:
这个命令中实现重定向的关键系统调用序列是:
open(file) == 3
dup2(3,1)
dup2(1,2)
这个命令中实现重定向的关键系统调用序列是:
dup2(1,2)
open(file) == 3
dup2(3,1)
注意:0 是标准输入(STDIN),1 是标准输出(STDOUT),2 是标准错误输出(STDERR) 。
这里的2和之间不可以有空格 , 2是一体的时候才表示错误输出 。
linux bash的重定向 关于linux bash的重定向
所谓I/O重定向简单来说就是一个过程 , 这个过程捕捉一个文件 , 或者命令,程序,脚本,甚至脚本中的代码块(code block)的输出,然后把捕捉到的输出,作为输入发送给另外一个文件,命令,程序,或者脚本 。
如果谈到I/O重定向,就涉及到文件标识符(File Descriptor)的概念, 在Linux系统中,系统为每一个打开的文件指定一个文件标识符以便系统对文件进行跟踪,这里有些和C语言编程里的文件句柄相似,文件标识符是一个数字,不同数字代表不同的含义,默认情况下,系统占用了3个,分别是0标准输入(stdin),1标准输出(stdout), 2标准错误(stderr), 另外3-9是保留的标识符,可以把这些标识符指定成标准输入,输出或者错误作为临时连接 。通常这样可以解决很多复杂的重定向请求 。
标准输入通常指键盘的输入
标准输出通常指显示器的输出
标准错误通常也是定向到显示器
请看以下例子,来描述一下他们的关系
#ls /dev
这个命令列出/dev目录下的所有文件,在屏幕上输出结果 。
这里 /dev 就是作为命令ls的标准输入(从键盘输入),而打印在屏幕的结果就是标准输出(/dev目录中的内容)
还是回到标题,重定向就是把标准的`输入或者输出更改成其他的方式,请参看如下例子
或者等同于
#ls /dev 1filename #注意:"1"和""中间没有空格
以上命令会把命令的标准输出重新定向到一个文件filename,而不是显示到屏幕上,如果不指明文件标识符,系统默认的就是1, 因此1可以省略
如果把上面例子重的""改成""则表示把输出追加到filename文件的末尾 , 如果文件不存在则创建它 。如下
#ls /dev filename
也可以把标准错误重新定向到文件
#ls -qw /dev 2filename
显然 -qw是一个错误参数,通常会在显示器上报告一个错误信息 , 但由于把2标准错误(stderr)重新定向到了文件filename,因此显示器没有错误信息,而信息写到了文件里面
以下命令是把标准输出和错误都定向到文件
#ls /dev filename
""在这里代表标准输出和标准错误,这里无论是正常输出还是错误信息都写到filename中了 。
重新定义标准输入,输出,和错误的文件标识符
重新定义文件标识符可以用ij命令,表示把文件标识符i重新定向到j,你可以把""理解为"取地址"
请看以下例子
#exec 51
表示把文件标识符5定向到标准输出,这个命令通常用来临时保存标准输入 。
同样标准输入也是可以重新定向的 , 请参考下面例子
# grep search-word
一般来说grep命令在给定文件中搜索字符串,以上命令把文件filename作为grep命令的标准输入,而不是从键盘输入 。
前面曾经提到,系统为每一个打开的文件指定一个文件标识符以便系统对文件进行跟踪 , 那么默认的文件标识符是什么呢?答案是0 , 也就是标准输入,或者可以说从键盘输入 。当然这个文件标识符也可以自己指定 , 请参考下面例子
#echo 123456789 filename 把字符串写到文件filename中 #exec 3filename 把文件filename打开,并指定文件标识符为3 #read -n 4 3 从文件中读4个字符,句柄已经指到第四个字符末尾 #echo -n . 3 在第5个字符处写一个点,覆盖第5个字符 , -n表示不换行 #exec 3- 关闭文件标识符3
现在cat filename文件的结果就成了1234.6789
命令jfilename表示把文件打开 , 并指明文件标识符为j
"-"表示关闭文件标识符
有关关闭文件标识符的操作请参考下面
n- 关闭输入文件标识符n 0-或- 关闭标准输入stdin n- 关闭输出文件标识符n 1-或-关闭标准输出stdout
另外还有一些其他命令,如下参考
2. : filename 或者filename
表示把文件filename设置成空,也就是清空文件内容 , 如果文件不存在,则创建一个空文件,(等同于touch命令) :表示一个空输出 , 两个命令的唯一区别就是filename不是在所有shell都可以正常工作的 。
;
Linux标准输入输出与重定向详解|果断收藏 linux中的、、、、2、2、21、、 , 总归要面对的
为了更好的理解这个问题 , 我们需要追本溯源 。
执行一个shell命令行时通常会自动打开三个标准文件
(1) 、标准输入文件(stdin)
通常对应终端的键盘 。
(2)、标准输出文件(stdout) 。
(3)、标准错误输出文件(stderr) 。
(2)和(3)这两个文件都对应终端的屏幕 。
进程将从标准输入文件中得到输入数据 。
将正常输出数据输出到标准输出文件[显示器] 。
将错误信息送到标准错误文件中[显示器] 。
【linux命令重定向标准 linux各种重定向及其含义】 下图所示:
0、1、2表示一个文件描述符
但是 , 有时候我们不想把一些进程处理后信息输出到显示器 。
这时我们就引出了重定向 。
改变标准输入/输出的方向
三种重定向:
1、重定向标准输出 , 包括两种 。
(1)、(覆盖),等价1
将命令执行的结果输出到指定文件,非显示器 。
(2) 、(追加) , 等价1
将命令执行的结果追加到指定文件,非显示器 。
2、 重定向标准输入,包括两种 。
(1) 、
将命令中接收的输入途径 , 由键盘改为指定文件 。
(2) 、[Here Document]
命令序列传递到一个交互程序或者命令中 。
3、 重定向标准错误,包括两种 。
(1) 、2(覆盖)
将命令执行的结果输出到指定文件 。
(2) 、2(追加)
将命令执行的结果追加到指定文件 。
1、重定向标准输出和重定向标准错误到同一个文件中
有以下的几种方式
(1) 、21
(2) 、
(3) 、
2、 两个特殊文件
(1) 、/dev/nul
过滤标准错误信息
意思就是不想显示结果就输出到这里面 。
(2) 、/dev/zero
创建指定长度的文件
案例1:
测试 and
案例2:
测试 and
测试
测试
案例3:
测试2 and 2
案例4:
测试重定向标准输出和重定向标准错误到同一个文件中
(1)、
(2)、
与上面的案例类似 , 不做解释
(3) 、21
案例5:
使用/dev/nul文件
有时候我们使用命令,不想将输出的信息显示到界面
这时我们可以使用/dev/nul[常用]
简单测试修改demo 用户密码
关于linux命令重定向标准和linux各种重定向及其含义的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站 。

    推荐阅读