由kill 和 kill -9 引发的Linux signal 学习

本文探讨了Linux中kill命令发送的SIGTERM(15)和SIGKILL(9)信号的区别。SIGTERM允许进程优雅退出,而SIGKILL则是强制立即终止进程,无法被捕获或忽略。文章还列举了其他常见的Linux信号,如SIGHUP、SIGINT、SIGQUIT等,并简述了各自的作用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

kill -15

默认参数下,kill 发送SIGTERM(15)信号给进程,告诉进程你需要被关闭,请自行停止运行并退出


kill -9

发送SIGKILL信号给进程,告诉进程你被终结了,请立刻退出。TERM(或数字9)表示“无条件终止”;


因此 kill - 9 (TERM)表示强制杀死该进程,与kill -15(SIGTERM)相比。

       1、这个信号不能被捕获或忽略。

       2、接收这个信号的进程在收到这个信号时不能执行任何清理。

       3、SIGTERM 比较友好,进程能捕捉这个信号,根据您的需要来关闭程序。在关闭程序之前,您可以结束打开的记录文件和完成正在做的任务。在某些情况下,假如进程正在进行作业而且不能中断,那么进程可以忽略这个SIGTERM信号。

        4、对于 SIGKILL 信号,进程是不能忽略的。这是一个 “我不管您在做什么,立刻停止”的信号。假如您发送SIGKILL信号给进程,Linux就将进程停止在那里。

 

sigaddset       将信号signo 加入到信号集合之中;

sigdelset       将信号从信号集合中删除;

sigemptyset     函数初始化信号集合set,将set 设置为空;

sigfillset      也初始化信号集合,只是将信号集合设置为所有信号的集合;

 

### Linux 中 `kill -9` `kill -15` 的区别及用法 #### 信号定义 在 Linux 系统中,`kill` 命令用于向指定的进程发送信号。默认情况下,如果没有指定信号编号,则会发送 SIGTERM (信号 15)[^1]。 - **SIGTERM (信号 15)**:这是一个可以被捕获、处理忽略的信号。当进程接收到此信号时,它有机会执行清理操作并优雅地退出[^1]。 - **SIGKILL (信号 9)**:这是不可捕获、不可处理且不可忽略的信号。一旦发送到目标进程,操作系统将强制终止该进程,而不允许任何清理操作[^1]。 #### 使用场景 - 当使用 `kill -15` 或不带参数的 `kill` 时,系统会给目标进程一个机会来完成资源释放或其他必要的清理工作后再退出。这对于大多数正常运行的应用程序来说是非常重要的,因为它能防止数据丢失或损坏[^1]。 - 如果某个进程忽略了 SIGTERM 或者由于某些原因未能响应,此时可以考虑使用 `kill -9` 来强行终止该进程。然而需要注意的是,这种方式可能会导致未保存的数据丢失以及文件系统的不稳定状态,因此应谨慎使用[^1]。 #### 实际案例分析 对于一些特殊类型的程序,比如 Web 应用、数据库管理系统或者涉及长时间事务的操作环境,推荐优先尝试通过发送 SIGTERM 让它们自行关闭业务逻辑之后再结束进程;只有确认这些方法都失败后才应该转向更为激进的方式即利用 SIGKILL 进行强制销毁。 以下是两个简单的 Python 脚本例子展示两种不同方式下行为差异: ```python import signal import sys import time def handle_sigterm(signum, frame): print("Received SIGTERM. Cleaning up...") cleanup() sys.exit(0) def cleanup(): with open("/tmp/cleanup.log", 'a') as f: f.write(f"Cleanup at {time.strftime('%Y-%m-%d %H:%M:%S', time.localtime())}\n") signal.signal(signal.SIGTERM, handle_sigterm) while True: time.sleep(1) ``` 在这个脚本里我们注册了一个 handler 函数用来监听 SIGTERM 并做相应的日志记录动作。当我们对该进程发起 `kill -15 PID` 后将会看到终端打印消息并且生成新的 `/tmp/cleanup.log` 文件条目[^2]。 另一方面如果我们直接采用 `kill -9 PID`, 则不会触发上述自定义处理器函数调用链路,也就意味着没有任何形式的事先通知机制存在从而可能导致潜在风险如前述提到过的那些情况发生[^3]. ### 总结 综上所述,在日常运维工作中应当养成良好习惯尽量依赖标准途径实现平滑过渡而非贸然采取极端措施除非万不得已之时确实需要如此行事才行.
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值