在下标中使用 exec 重定向标准输出
Redirect stdout using exec in subscript
我有一个作为服务启动的主脚本。
我不能修改这个主脚本,因为它经常更新。
此主脚本启动一个程序,将任何日志回显到标准输出。
所以我看不到这个程序的任何日志。
但是这个主脚本在开始时调用了一个钩子脚本,我可以修改它。
如果我将标准输出重定向到这个钩子脚本中的一个文件,它适用于该脚本,但不适用于主脚本。
是否可以更改整个过程的标准输出?
主要 (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
...
勾(enigma2_pre_start.sh)
exec > /tmp/`date +"%s"`.log
exec 2> /tmp/`date +"%s"`_error.log
编辑:
是否可以在主进程启动后附加一个 tee(或类似的)?
我知道主脚本只有 运行 一次。所以我可以使用 ps.
获取进程 ID
您必须获取 enigma_pre_start.sh
而不是执行它,以便 exec
命令 运行 在您要更改其文件句柄的同一进程中。
if [ -x enigma2_pre_start.sh ]; then
. enigma2_pre_start.sh
fi
否则,您将重定向执行挂钩脚本的进程的标准输出和错误,该脚本会在脚本完成后立即退出。
基于"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\. /g' /var/bin/enigma2.sh -i
pid=`/bin/ps -o ppid= $$` && /bin/kill $pid
fi
我有一个作为服务启动的主脚本。
我不能修改这个主脚本,因为它经常更新。 此主脚本启动一个程序,将任何日志回显到标准输出。
所以我看不到这个程序的任何日志。
但是这个主脚本在开始时调用了一个钩子脚本,我可以修改它。
如果我将标准输出重定向到这个钩子脚本中的一个文件,它适用于该脚本,但不适用于主脚本。
是否可以更改整个过程的标准输出?
主要 (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
...
勾(enigma2_pre_start.sh)
exec > /tmp/`date +"%s"`.log
exec 2> /tmp/`date +"%s"`_error.log
编辑:
是否可以在主进程启动后附加一个 tee(或类似的)? 我知道主脚本只有 运行 一次。所以我可以使用 ps.
获取进程 ID您必须获取 enigma_pre_start.sh
而不是执行它,以便 exec
命令 运行 在您要更改其文件句柄的同一进程中。
if [ -x enigma2_pre_start.sh ]; then
. enigma2_pre_start.sh
fi
否则,您将重定向执行挂钩脚本的进程的标准输出和错误,该脚本会在脚本完成后立即退出。
基于"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\. /g' /var/bin/enigma2.sh -i
pid=`/bin/ps -o ppid= $$` && /bin/kill $pid
fi