使用下标中的exec重定向stdout

时间:2015-06-18 07:58:58

标签: linux bash redirect command-line sh

我有一个主要脚本作为服务启动。

我无法修改此主脚本,因为它经常更新。 这个主脚本启动一个程序,它将任何日志回显到stdout。

所以我看不到这个程序的任何日志。

但是这个主脚本在开头调用了一个钩子脚本,我可以修改它。

如果我将stdout重定向到此hook-script中的文件,它适用于该脚本,但不适用于主脚本。

是否可以更改整个过程的标准输出?

main(enigma2.sh):

# hook to execute scripts always before enigma2 start
if [ -x enigma2_pre_start.sh ]; then
  enigma2_pre_start.sh
fi

...

#this logs to stdout
/usr/bin/enigma2

...

hook(enigma2_pre_start.sh)

exec > /tmp/`date +"%s"`.log
exec 2> /tmp/`date +"%s"`_error.log

编辑:

是否可以在开始后将主动(或类似)连接到主过程? 我知道主脚本只运行一次。所以我可以用ps获得进程id。

2 个答案:

答案 0 :(得分:1)

您必须使用enigma_pre_start.sh而不是执行它,以便exec命令在您想要更改其文件句柄的同一进程中运行。

if [ -x enigma2_pre_start.sh ]; then
    . enigma2_pre_start.sh
fi

否则,您将重定向标准输出和执行钩子脚本的进程的错误,该脚本在脚本完成后立即退出。

答案 1 :(得分:0)

基于来自" Zaboj Campula"的评论的解决方案:

if /bin/grep -q "^[[:space:]]/usr/bin/enigma2_pre_start.sh$" /var/bin/enigma2.sh
then
        echo Unpatched > /tmp/enigma.sh
        /bin/sed -e 's/^\t\(\/usr\/bin\/enigma2_pre_start.sh\)$/\t\. \1/g' /var/bin/enigma2.sh -i
        pid=`/bin/ps -o ppid= $$` && /bin/kill $pid
fi