linuxshell中"2>&1"含义

linuxshell中"2>&1"含义

 

脚本是:

     nohup /mnt/Nand3/H2000G >/dev/null 2>&1 &

     对

    于& 1 更准确的说应该是文件描述符 1,而1

    一般代表的就是STDOUT_FILENO,实际上这个操作就是一个dup2(2)调用.他标准输出到all_result

    ,然后复制标准输出到文件描述符2(STDERR_FILENO),其后果就是文件描述符1和2指向同一个文件表项,也可以说错误的输出被合并了.其中0

    表示键盘输入 1表示屏幕输出

    2表示错误输出.把标准出错重定向到标准输出,然后扔到/DEV/NULL下面去。通俗的说,就是把所有标准输出和标准出错都扔到垃圾桶里面。

     command >out.file 2>&1 &

     command

    >out.file是将command的输出重定向到out.file文件,即输出内容不打印到屏幕上,而是输出到out.file文件中。

    2>&1

    是将标准出错重定向到标准输出,这里的标准输出已经重定向到了out.file文件,即将标准出错也输出到out.file文件中。最后一个&

    , 是让该命令在后台执行。

    

     试想2>1代表什么,2与>结合代表错误重定向,而1则代表错误重定向到一个文件1,而不代表标准输出;

    换成2>&1,&与1结合就代表标准输出了,就变成错误重定向到标准输出.

     你可以用

     ls 2>1测试一下,不会报没有2文件的错误,但会输出一个空的文件1;

     ls xxx 2>1测试,没有xxx这个文件的错误输出到了1中;

     ls xxx 2>&1测试,不会生成1这个文件了,不过错误跑到标准输出了;

     ls xxx >out.txt 2>&1, 实际上可换成 ls xxx 1>out.txt 2>&1;重定向符号>默认是1,错误和输出都传到out.txt了。

     为何2>&1要写在后面?

     command > file 2>&1

     首先是command > file将标准输出重定向到file中, 2>&1 是标准错误拷贝了标准输出的行为,也就是同样被重定向到file中,最终结果就是标准输出和错误都被重定向到file中。

     command 2>&1 >file

     2>&1 标准错误拷贝了标准输出的行为,但此时标准输出还是在终端。>file 后输出才被重定向到file,但标准错误仍然保持在终端。

    用strace可以看到:

    1. command > file 2>&1

    这个命令中实现重定向的关键系统调用序列是:

    open(file) == 3

    dup2(3,1)

    dup2(1,2)

    2. command 2>&1 >file

    这个命令中实现重定向的关键系统调用序列是:

    dup2(1,2)

    open(file) == 3

    dup2(3,1)

    可以考虑一下不同的dup2()调用序列会产生怎样的文件共享结构。请参考APUE 3.10, 3.12

------------------------------------------------------------------------------

 問題:请帮忙注解一下下边的shell命令,其中的 "1>” "2>" "2>&1" 具体什么意思,有什么含义?

cat account_qtr.doc account_end.doc 1>accounts.out 2>accounts.err   把两个文件合并到accounts.out中
grep "standard"* > grep.out 2>&1
cat >>filetest 2>&1 <<MAYDAY
另:   exec 4<&0 0<stock.txt  ,这里的4<&0是什么含义

 

 

>和>>都是重定向输出
1> 指标准信息输出路径(也就是默认的输出方式)
2> 指错误信息输出路径
2>&1 指将标准信息输出路径指定为错误信息输出路径(也就是都输出在一起)

补充问题4<&0:
<和<<都是重定向输入
<0指标准输入路径
4<&0 指的是将文件描述符4指定为标准输入(实际可选4到9之间任意一个数字)

不知下面两句是否写得有点问题,或者是断章取义,总觉得前面可能有“|”符号
grep "standard"* > grep.out 2>&1
指的是将包含"standard" 的行全部写入grep.out文件中,包括grep时发生错误的报错信息
cat >>filetest 2>&1 <<MAYDAY
如果前面没有“|” 没感觉和 cat MAYDAY >>filetest 2>&1 有什么差别
如果有的话,应该就是将前面得到的信息和MAYDAY 中信息一起写入filetest,包括执行命令时的报错信息,但我好像执行不通过。。。

习惯上
标准输入(standard input)的文件描述符是 0
标准输出(standard output)是 1
标准错误(standard error)是 2

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

 

1是标准输出
2是错误输出
> 和 >> 都是输出重定向符号。标准输出默认是打印到控制台,如果要导入到文件,就需要使用>或>>。> 会覆盖已有的文件内容,而>>会附加到已有内容之后。
< 和 << 是输入重定向符号。从文件中读取内容。
2>&1 是把错误输出导入(合并)到标准输出流中
  
grep "standard"* > grep.out 2>&1 就是将标准输出与错误输出一并送入grep.out文件中,写文件方式为覆盖写(>)。
cat >>filetest 2>&1 <<MAYDAY 就是从MAYDAY中读取文件内容,将标准输出与错误输出一并送入filetest文件中,写文件方式为附加写(>>)。

 

&lt;think&gt; 我们被要求解释Linux中io重定向的`2&gt;&amp;1`的含义,并说明为什么不是`&amp;2&gt;&amp;1`。 首先,我们需要回顾Linux中的文件描述符(File Descriptor, FD): 0: 标准输入(stdin) 1: 标准输出(stdout) 2: 标准错误(stderr) 重定向操作符: &gt; 或 1&gt; : 重定向标准输出 2&gt; : 重定向标准错误 &amp;&gt; : 重定向标准输出和标准错误(bash中的便捷写法) `2&gt;&amp;1` 的含义是将标准错误(文件描述符2)重定向到标准输出(文件描述符1)当前指向的位置。 注意:`2&gt;&amp;1` 必须写在重定向目标之后,因为在重定向时,顺序很重要。 例如: command &gt; file 2&gt;&amp;1 先是将标准输出重定向到file,然后将标准错误重定向到标准输出(此时标准输出已经指向file,所以标准错误也会到file)。 而如果写成: command 2&gt;&amp;1 &gt; file 则标准错误首先被重定向到标准输出的当前位置(也就是终端),然后将标准输出重定向到file。这样只有标准输出会到file,而标准错误还是在终端。 现在解释为什么不是`&amp;2&gt;&amp;1`: 在Linux的shell中,`&amp;`在重定向中有两种用法: 1. 放在文件描述符数字之后,表示重定向的目标是一个文件描述符,而不是文件。如`2&gt;&amp;1`,这里的`&amp;1`表示文件描述符12. 放在命令末尾,表示后台运行。 所以,`2&gt;&amp;1`中,`2&gt;`表示重定向标准错误,`&amp;1`表示重定向到文件描述符1。 而如果写成`&amp;2&gt;&amp;1`,首先开头的`&amp;`没有意义,因为重定向语法要求以文件描述符数字开头(或使用其他重定向符号)。而且,`&amp;2`本身也不是一个合法的重定向开始。 实际上,`&amp;2`单独使用在重定向中并不表示文件描述符2,而是`&amp;`后面跟一个数字,必须紧挨在重定向符号后面才表示重定向到文件描述符。例如: command &gt;&amp;2 # 这是将标准输出重定向到标准错误(等价于 1&gt;&amp;2) 所以,`2&gt;&amp;1`是正确的写法,而`&amp;2&gt;&amp;1`不符合重定向的语法规则。 总结: - `2&gt;&amp;1`:将标准错误重定向到标准输出(当前指向的位置)。 - 不能写成`&amp;2&gt;&amp;1`,因为`&amp;2`作为重定向的起始部分是不合法的。 下面我们按照要求回答问题,并在最后提出相关问题。 &lt;/think&gt; ### Linux 中 `2&gt;&amp;1` 的含义与原理 在 Linux I/O 重定向中,`2&gt;&amp;1` 是将**标准错误输出(stderr)重定向到标准输出(stdout)** 的标准语法。以下是详细解析: #### 一、文件描述符基础 | 描述符 | 名称 | 默认位置 | |--------|------------|----------| | `0` | 标准输入 | 键盘 | | `1` | 标准输出 | 终端屏幕 | | `2` | 标准错误 | 终端屏幕 | #### 二、`2&gt;&amp;1` 的语义解析 ```bash command &gt; output.log 2&gt;&amp;1 ``` 1. **`&gt;`** :重定向标准输出(FD 1)到文件 `output.log` 2. **`2&gt;&amp;1`** :将标准错误(FD 2)重定向到**当前 FD 1 指向的位置**(即 `output.log`) #### 三、为什么不是 `&amp;2&gt;&amp;1`? 1. **语法规则**: - `&amp;` 在重定向中有特定语义: - 用在右侧:表示目标为文件描述符(如 `&amp;1`) - 用在左侧:必须紧接数字(如 `2&gt;`) - `&amp;2&gt;&amp;1` 不符合语法树结构,会被解析为无效指令 2. **正确结构对比**: ```bash 2&gt;&amp;1 ✅ FD2 重定向到 FD1 的当前位置 &amp;2&gt;&amp;1 ❌ 无效语法(&amp;2 不是有效左侧表达式) ``` 3. **等效替代方案**: ```bash command &amp;&gt; output.log # Bash 简写(同时重定向 stdout+stderr) command &gt;&amp; output.log # 另一种等价形式 ``` #### 四、关键注意事项 1. **顺序敏感性**: ```bash # 错误示例:stderr 仍输出到屏幕 command 2&gt;&amp;1 &gt; file.log # 解析流程: # 1. 先将 FD2 指向 FD1 的当前目标(屏幕) # 2. 再将 FD1 重定向到文件 ``` 2. **特殊场景处理**: ```bash # 将 stdout 和 stderr 分离到不同文件 command &gt; stdout.log 2&gt; stderr.log ``` 3. **管道中的应用**: ```bash # 错误信息也参与管道传递 command 2&gt;&amp;1 | grep &quot;error&quot; ``` --- ### 图解执行流程 ```mermaid graph LR A[command] --&gt; B(stdout FD1) A --&gt; C(stderr FD2) B -- &gt; output.log --&gt; D[(output.log)] C -- 2&gt;&amp;1 --&gt; B ``` &gt; 💡 **总结**: &gt; `2&gt;&amp;1` 是基于文件描述符编号的标准语法,`&amp;2&gt;&amp;1` 因违反重定向语法规则而无效。实际使用时注意重定向顺序,或使用更简洁的 `&amp;&gt;` 语法。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值