`
jak47
  • 浏览: 72042 次
  • 性别: Icon_minigender_1
  • 来自: 火星
社区版块
存档分类
最新评论

shell里面用tee写log时return code问题

阅读更多

shell里面,常出现程序执行结果既要往终端输出,又要往log文件输出的情况,这时候一般都使用tee。

例如:

#!/bin/sh

command | tee -a out.txt

ST=$?

 

但是现在变量ST里设置的返回值是tee命令的返回值,而不是command的返回值, 所以出现即使command执行结果出错,可变量ST的值仍是正常0的情况。

 

解决办法是使用环境变量PIPESTATUS, 这个数组型变量里面存放用"|" 隔开的各个命令的执行结果。

上例是想取缔一个命令的执行结果,所以代码应该如下

#!/bin/sh

command | tee -a out.txt

ST=${PIPESTATUS[0]}

 

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics