进程终止命令:kill 与 kill -9 的区别

编辑于:2021年12月12日
进程终止命令:kill 与 kill -9 的区别

kill 和 kill -9 是常用的命令,都可以用来杀死进程。那 kill 与 kill -9 有什么区别呢?

kill

kill 命令默认的信号就是 15,也就是 kill -15 ,被称为优雅的退出。当使用 kill -15 时,系统会发送一个SIGTERM的信号给对应的程序。当程序接收到该信号后,具体要如何处理是自己可以决定的。

这时候,应用程序可以选择:

  • ⭕立即停止程序
  • ⭕释放响应资源后停止程序
  • ⭕忽略该信号,继续执行程序

因为 kill -15 信号只是通知对应的进程要进行"安全、干净的退出",程序接到信号之后,退出前一般会进行一些"准备工作",如资源释放、临时文件清理等等,如果准备工作做完了,再进行程序的终止。但是,如果在"准备工作"进行过程中,遇到阻塞或者其他问题导致无法成功,那么应用程序可以选择忽略该终止信号。

这也就是为什么我们有的时候使用kill命令是没办法"杀死"应用的原因,因为默认的 kill 信号是 SIGTERM(15),而 SIGTERM(15)的信号是可以被阻塞和忽略的。

大部分程序接收到 SIGTERM 信号后,会先释放自己的资源,然后在停止。但是也有程序可以在接受到信号量后,做一些其他的事情,并且这些事情是可以配置的。如果程序正在等待 IO,可能就不会立马做出相应,或者等待其他项目的响应。

kill -9

我们常碰到一些 java 项目就是如此,发送 kill 命令,程序不会退出,要等到 几十秒之后才会退出,一般没耐心等待,所以这个时候,我们就会用 kill -9 必杀命令。

和 kill -15 相比,kill -9 就相对强硬一点,系统会发出 SIGKILL 信号,他要求接收到该信号的程序应该立即结束运行,不能被阻塞或者忽略。

所以,相比 于kill -15 命令,kill -9 在执行时,应用程序是没有时间进行"准备工作"的,所以这通常会带来一些副作用,数据丢失或者终端无法恢复到正常状态等。

相关推荐