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?
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?
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.
#!/bin/bash
trap "echo 5" SIGINT SIGTERM
tail -f nohup.out
You could just start the tail
in a new shell, like so:
#!/bin/bash
bash -i -c 'tail -f nohup.out'
echo 5
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)
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