Bash snippet for killing a process until it's dead?
The problem with repeatedly killing a process is that you've got a race condition with new process creation. It's not particularly likely, but it's possible that the process will exit and a new process start up with the same PID while you're sleeping.
Why are you having to repeatedly kill the process? If it's because the process will exit, but it may take some time to quit after receiving the signal, you could use wait
:
kill $PID
wait $PID
In an ideal system, you'd never have to repeat a kill
or issue kill -9 $PID
. If you do have to, you might want to consider fixing whatever it is that you're running so you don't have to. In the meantime, you will probably not hit the race condition, and you can guard against it by (say) checking the timestamp of /proc/$PID/ just before killing the process. That's bad hackiness, though.
For everyone recommending the step from kill $PID
to kill -9 $PID
, I'd have to remind you of Useless use of kill -9.
No no no. Don't use kill -9.
It doesn't give the process a chance to cleanly:
shut down socket connections
clean up temp files
inform its children that it is going away
reset its terminal characteristics
and so on and so on and so on.
Generally, send 15, and wait a second or two, and if that doesn't work, send 2, and if that doesn't work, send 1. If that doesn't, REMOVE THE BINARY because the program is badly behaved!
Don't use kill -9. Don't bring out the combine harvester just to tidy up the flower pot.
Now, I don't agree with the "remove the binary part", but the progression seems less damaging than just a kill -9
.
I also agree with the care about race conditions on the creation of new processes with the same PID mentioned here.