初学linux shell. 想写个脚本a.sh 分析另外一个脚本b.sh中某程序的执行输出结果.
./a.sh b.sh args
a.sh 如下:
#!/bin/sh
./$1 $2 > /tmp/log
#Search keyword
grep -l "keyword" /tmp/log
if [ $? -eq 0 ]
then
code=0
else
code=-1
fi
exit
但是在/tmp/log 里面总是只有部分输出, 另外一部分由于没有重定向成功而打印在了屏幕上.
解决方案:
修改第一行为
./$1 $2 > /tmp/log 2>&1
原因:
程序中有标准输出stdout也有错误输出stderr. 之前的写法只是重定向了stdout, 并未包含stderr.
以下内容转载自:http://apps.hi.baidu.com/share/detail/40331116
cmd > file 把 stdout 重定向到 file 文件中;
cmd >> file 把 stdout 重定向到 file 文件中(追加);
cmd 1> fiel 把 stdout 重定向到 file 文件中;
cmd > file 2>&1 把 stdout 和 stderr 一起重定向到 file 文件中;
cmd 2> file 把 stderr 重定向到 file 文件中;
cmd 2>> file 把 stderr 重定向到 file 文件中(追加);
cmd >> file 2>&1 把 stderr 和 stderr 一起重定向到 file 文件中(追加);