how to continue run script after tail -f command

2020-04-05 09:58发布

I have the following script:

tail -f nohup.out
echo 5

When I press Ctrl+C on tail -f, the script stops running: the 5 is not printed. How can I run the command echo 5 after I stop the tail command?

5条回答
我命由我不由天
2楼-- · 2020-04-05 10:29
#!/bin/bash
trap "echo 5" SIGINT SIGTERM
tail -f nohup.out
查看更多
贼婆χ
3楼-- · 2020-04-05 10:38

Ctrl+C sends the SIGINT signal to all the processes in the foreground process group. While tail is running, the process group consists of the tail process and the shell running the script.

Use the trap builtin to override the default behavior of the signal.

trap " " INT
tail -f nohup.out
trap - INT
echo 5

The code of the trap does nothing, so that the shell progresses to the next command (echo 5) if it receives a SIGINT. Note that there is a space between the quotes in the first line; any shell code that does nothing will do, except an empty string which would mean to ignore the signal altogether (this cannot be used because it would cause tail to ignore the signal as well). The second call to trap restores the default behavior, so that after the third line a Ctrl+C will interrupt the script again.

查看更多
Deceive 欺骗
4楼-- · 2020-04-05 10:41

You could just start the tail in a new shell, like so:

#!/bin/bash
bash -i -c 'tail -f nohup.out'
echo 5
查看更多
趁早两清
5楼-- · 2020-04-05 10:41

As mentioned by rwos , but adding inline trapping.

bash -i -c "trap ' ' SIGINT; tail -F '$1'; trap - SIGINT"

This would work without closing putty session when issuing subsequent SIGINT signals (that was my problem)

查看更多
Anthone
6楼-- · 2020-04-05 10:49

Look up File:Tail in perl, have used this a few times on different projects to automate tailing logs and carrying out a specific action for log output.

google ftp-upload-mon a project I uploaded to sourceforge which uses File:Tail to tail -f xferlogs

查看更多
登录 后发表回答