shell脚本重定向输出

时间:2014-06-10 03:31:53

标签: shell redirect output

我有一个shell脚本来监视进程,因为它阻止了进程关闭。 如果进程已关闭,该脚本将重新启动它。 顺便说一句,当系统启动时,crontab将自动运行脚本。 如何获取由shell脚本启动的进程的输出?

#!/bin/bash
PATH=/bin:/sbin:/usr/bin:/usr/sbin:/usr/local/bin:/usr/local/sbin:~/bin
export PATH
while :
do
if [ -z "$(ps -ef | grep -v grep | grep 225.0.6.4)" ]; then
        date +"%m-%d-%y %T" >> /home/andy/log/stream.log
        echo  "225.0.6.4 - 103 not worked and restart process" >> /home/andy/log/stream.log
         echo "225.0.6.4 - 103 not worked and restart process"

/usr/bin/tzap -a 1 -c /home/andy/channels.conf -o - -r -p "D" | /home/andy/ffmpeg -f mpegts -i pipe:0 -c:v libx264 -preset medium -crf 23 -bufsize 3000K -minrate 1200k -maxrate 1200k -pix_fmt yuv420p -g 50 -s 1024x768 -acodec libmp3lame -b:a 128k -ac 2 -ar 44100 -f mpegts udp://225.0.6.4:50000 &

fi
sleep 1
done

1 个答案:

答案 0 :(得分:1)

看起来您希望管道的输出也转到日志文件。如果是,那么:

#!/bin/bash
PATH=/bin:/sbin:/usr/bin:/usr/sbin:/usr/local/bin:/usr/local/sbin:~/bin
export PATH

exec >> /home/andy/log/stream.log

while :
do
    if [ -z "$(ps -ef | grep -v grep | grep 225.0.6.4)" ]; then
       date +"%m-%d-%y %T" >> /home/andy/log/stream.log
       echo "225.0.6.4 - 103 not worked and restart process"
       echo "225.0.6.4 - 103 not worked and restart process" >&2

       /usr/bin/tzap -a 1 -c /home/andy/channels.conf -o - -r -p "D" |
       /home/andy/ffmpeg -f mpegts -i pipe:0 -c:v libx264 -preset medium -crf 23 \
           -bufsize 3000K -minrate 1200k -maxrate 1200k -pix_fmt yuv420p -g 50 \
           -s 1024x768 -acodec libmp3lame -b:a 128k -ac 2 -ar 44100 -f mpegts \
           udp://225.0.6.4:50000 &

    fi
    sleep 1
done

exec >> /home/andy/log/stream.log确保所有标准输出都转到日志文件。我通过安排事情稍微作弊,以便以前用于标准输出的日志消息现在转为标准错误。如果必须将其转到原始标准输出,则:

exec 3>&1 >> /home/andy/log/stream.log

…

       echo "225.0.6.4 - 103 not worked and restart process" >&3

这样做。它实际上并不困难。 3>&1使文件描述符3引用标准输出引用的相同位置(并且该行的其余部分立即使标准输出引用日志文件)。 >&3将输出重定向到文件描述符3,它与原始标准输出相同。