首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

还有kill -9不掉进程kill命令详解

我们很多人对kill -9 非常熟悉,在工作中也经常用到。特别是你去重启服务的时候。但是所有的服务都能用kill -9来处理吗?kill -9能杀掉所有的进程吗?...kill -l(查看Linux/Unix的信号变量) 下面先说一下SIGKILL(kill -9)和SIGTERM(kill -15) kill -9、kill -15 kill -9 PID 是操作系统从内核级别强制杀死一个进程...kill -9不掉的怎么办 用ps和grep命令寻找僵尸进 ps -A -ostat,ppid,pid,cmd | grep -e '^[Zz]' 命令注解: -A 参数列出所有进程 -o 自定义输出字段...ps -A -ostat,ppid,pid,cmd | grep -e '^[Zz]' 来确认是否已经将僵尸进程杀死 如果kill进程无效,可以尝试kill 其父进程来解决问题,例如上面例子父进程...pid是 12334,那么我们就运行 kill -HUP 12334 来解决问题 一般可以用top命令发现动态进程表 其中zombie是僵尸进程 附录: linux signals

11.3K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    面试官:kill -9 进程不掉,怎么办?

    -o 自定义输出字段 我们设定显示字段为 stat(状态), ppid(进程父id), pid(进程id),cmd(命令)这四个参数 因为状态为 z或者Z的进程为僵尸进程。...所以我们使用grep抓取stat状态为zZ进程,运行结果参考如下: Z 12334 12339 /path/cmd 这时,我们可以使用 kill -HUP 12339来杀掉这个僵尸进程 运行后,可以再次运行...ps -A -ostat,ppid,pid,cmd | grep -e '^[Zz]' 来确认是否已经将僵尸进程杀死 如果kill进程的无效,可以尝试kill 其父进程来解决问题,例如上面例子父进程...pid是 12334,那么我们就运行 kill -HUP 12334 来解决问题 一般可以用top命令发现动态进程表 ?...其中zombie是僵尸进程 end

    1.1K20

    kill不掉的僵尸进程~

    看到一个有意思的名字“僵尸进程”,然后看了下他的含义 百度百科:僵尸进程是当子进程比父进程先结束,而父进程又没有回收子进程,释放子进程占用的资源,此时子进程将成为一个僵尸进程。...ID,然后先杀死父进程即可 二 .怎样来清除僵尸进程 1.改写父进程,在子进程死后要为它收尸。...父进程死后,僵尸进程成为"孤儿进程",过继给1号进程init,init始终会负责清理僵尸进程,关机或重启后所有僵尸进程都会消失。...三 .如何避免僵尸进程 僵尸进程的避免 ⒈父进程通过wait和waitpid等函数等待子进程结束,这会导致父进程挂起。...子进程终止后,这N个僵尸进程失去了父进程B,所以成为了孤儿进程,被init进程收养,从而寿终正寝。这种做法本质还是和我之前的实验中手动kill进程一样。

    2.6K20

    如何查找僵尸进程Kill之,不掉的要查看父进程

    用ps和grep命令寻找僵尸进程 #ps -A -ostat,ppid,pid,cmd | grep -e '^[Zz]' 命令注解: -A 参数列出所有进程 -o 自定义输出字段 我们设定显示字段为...stat(状态), ppid(进程父id), pid(进程id),cmd(命令)这四个参数 因为状态为 z或者Z的进程为僵尸进程,所以我们使用grep抓取stat状态为zZ进程 运行结果参考如下...Z 12334 12339 /path/cmd 这时,我们可以使用 kill -HUP 12339来杀掉这个僵尸进程 运行后,可以再次运行ps -A -ostat,ppid,pid,cmd | grep...-e '^[Zz]'来确认是否已经将僵尸进程杀死 如果kill进程的无效,可以尝试kill 其父进程来解决问题,例如上面例子父进程pid是 12334,那么我们就运行 #kill -HUP 12334...来解决问题 一般可以用top命令发现动态进程表 #top ?

    2.3K20

    MySQL 为什么Kill不掉线程

    mysql kill命令 -- 终止线程正在执行的语句 kill query 线程ID; -- 断开线程的连接,connection可以省略 -- 如果该线程有正在执行的语句,会先停止正在执行的语句 kill...connection 线程ID; kill的执行逻辑 被kill的线程不会立即停止,因为当我们对表做增删改查时,会在表上加MDL读锁,因此如果立即停止,MDL读锁将会无法释放。...对于kill query 线程ID来说: 会把线程运行状态改成THD::KILL_QUERY(对于kill connection来说是改成KILL_CONNECTION) 给线程发送一个信号 为什么需要发送信号...对于因为锁等待的线程并不知道自己状态的变化,还是会继续等待,因此对线程发送一个信号,可以让线程退出等待,处理THD::KILL_QUERY状态。 kill不掉的情况有几种?...线程没有执行到判断线程状态的逻辑 终止逻辑耗时比较长 线程没有执行到判断线程状态的逻辑导致kill不掉 在线程并发查询数达到innodb_thread_concurrency设置时,如果执行kill query

    2.3K10

    MySQL为什么还有kill不掉的语句?

    不知道你在使用 MySQL 的时候,有没有遇到过这样的现象:使用了 kill 命令,却没能断开这个连接。...其实,这跟 Linux 的 kill 命令类似,kill -N pid 并不是让进程直接停止,而是给进程发一个信号,然后进程处理这个信号,进入终止逻辑。...只是对于 MySQLkill 命令来说,不需要传信号量参数,就只有“停止”这个命令 实现上,当用户执行 kill query thread_id_B 时,MySQL 里处理 kill 命令的线程做了两件事...总结 MySQL 中,有些语句和连接“kill 不掉”的情况。...这些“kill 不掉”的情况,其实是因为发送 kill 命令的客户端,并没有强行停止目标线程的执行,而只是设置了个状态,并唤醒对应的线程。

    7.2K30

    MySQL 案例:为什么 kill 不掉线程

    背景 在日常的使用过程中,时不时会遇到个别,或者大量的连接堆积在 MySQL 中的现象,这时一般会考虑使用 kill 命令强制杀死这些长时间堆积起来的连接,尽快释放连接数和数据库服务器的 CPU 资源。...掉 Session 2 的查询: Session 1: mysql> select sleep(3600) from sbtest.sbtest1; Session 2: mysql> select...> kill 46; Query OK, 0 rows affected (0.00 sec) mysql> show processlist; +----+------+--------------...> 可以看到,kill 命令执行之后,Session 2 的连接马上就断开了,但是 Session 2 发起的查询仍旧残留在 MySQL 中。...总结一下 MySQLkill 操作并不是想象中的直接强行终止数据库连接,只是发送了一个终止的信号,如果 SQL 自身的执行效率过慢,或者受到其他的因素影响(服务器负载高,触发大量数据回滚)的话,那么这个

    4.1K60

    故障分析 | 一个 Kill 不掉MySQL 会话

    开启流量入口(绑定 VIP) 我们公司自研的数据库集群管理平台 云树® DMP[1] 大概也是这么个切换过程,而这个切换过程跟本文的关联点,就在主库 Kill 掉残留连接上。...偶然间发现,DMP 在切换过程中 Kill 残留连接时,日志中有时会出现 warn 信息:[warn] kill process warning:Error 1094:Unknown thread id...3为什么 Kill 不掉? 了解 event_scheduler 大概是什么之后,我们再来看看,为什么 Kill 时,会报 Unknown thread id。...因为这类会话并不是由用户直接发起的连接,而是 MySQL 内部的线程,所以无法像普通会话一样被 Kill 掉。 官方文档中,给出的信息较少,大家有兴趣的可以自己翻下代码。 4如何使用定时任务?...5总结 show processlist 中看到的 User 为 event_scheduler 的会话为 MySQL 内部线程,无法被 Kill 掉。

    34720

    进程kill问题

    背景 今天用jps查看进程时发现了几个进程,我希望把他们批量删除了 kill 尝试用kill -9删除,但是一个一个删除太麻烦了,我换了个方法 管道 先用ps命令查出所有进程,然后grep找到我想要的进程...,awk用于取出第二列的进程号 ,再用xargs传递参数kill ps -aux | grep java | awk '{print $2}' | xargs kill -9 无法kill 再用jps...查看下,好家伙,一个没删掉 原因一:这是个僵尸进程(父进程因为某种原因没有接收到子进程的Exit信号),等待父进程的回收 原因二:这个进程处于核心态,不接受信号 /proc 为了排查问题,我进入了/proc...目录,这里保存了每一个运行进程的对应目录 选择进入13547进程目录,cat status文件 可以发现该进程的父进程是13546,再kill掉这个父进程就会发现这个子进程也被kill掉啦

    1.4K30

    kill命令详解_linux杀死进程kill

    绝大多数人对 kill 命令的理解就是结束一个进程,除了这个 kill 其实还有其它的功能。 kill 的作用是向一个进程发送指定信号,而不仅仅是结束一个进程哦!...一、常用参数 语法格式: kill [参数] […] 常用参数如下: -l, –list [信号] :列出信号名称; – , -s, –signal :指定要发送的信号;...为了进程测试,我们启动了一个程序 kill-test ,进程号为 3756,如下所示: linuxy@linuxy:~$ ps -ef | grep kill-test linuxy 3756...在不带参数情况下,kill 默认发送 TERM 信号到指定进程,TERM 是终止进程信号,程序没有被结束的原因是程序捕获了该信号,当然,可以杀死不能捕获该信号的进程。...信号时会重新读取配置文件; SIGCHLD : 在一个进程终止或停止时,SIGCHLD 信号被发送给父进程; SIGCONT : 该信号发送给需要继续运行,但当前处于停止状态的进程; SIGGIO :

    5.7K60

    MySQL实战第三十二讲-为什么还有kill不掉的语句?

    其实,这跟 Linux 的 kill 命令类似,kill -N pid 并不是让进程直接停止,而是给进程发一个信号,然后进程处理这个信号,进入终止逻辑。...接下来,我们再看一个 kill 不掉的例子,也就是我们在前面 第 29 篇文章 中提到的 innodb_thread_concurrency 不够用的例子。...小结 在今天这篇文章中,我首先和你介绍了 MySQL 中,有些语句和连接“kill 不掉”的情况。...这些“kill 不掉”的情况,其实是因为发送 kill 命令的客户端,并没有强行停止目标线程的执行,而只是设置了个状态,并唤醒对应的线程。...如果你碰到一个被 killed 的事务一直处于回滚状态,你认为是应该直接把 MySQL 进程强行重启,还是应该让它自己执行完成呢?为什么呢?

    1.1K10

    【Android 应用开发】Android 杀进程总结 ( 后台进程 | 前台进程 | 其它进程 )

    文章目录 一、Android 后台进程 二、Android 前台进程 三、Android 其它进程 一、Android 后台进程 ---- 使用 Android 的进程 api 类 android.os.Process..., 应用进程会重新启动 ; 二、Android 前台进程 ---- 关闭了所有的 Activity 界面窗口 , 应用进程自然就被杀死了 ; activity.finishAffinity(); 上述代码可以关闭所有的本任务栈内的...使用 Java 的进程 api 类 `java.lang.System` 杀死进程 java.lang.System.exit(0); 三、Android 其它进程 ---- 获取 ActivityManager...Context.ACTIVITY_SERVICE); activityManager.killBackgroundProcesses("com.google.example"); 需要使用 android.permission.KILL_BACKGROUND_PROCESSES...权限 ; 在清单文件中配置该权限 :

    2.6K30

    centos批量kill进程

    ps -ef|grep php|grep -v grep|cut -c 9-15|xargs kill -9 管道符"|"用来隔开两个命令,管道符左边命令的输出会作为管道符右边命令的输入。..."grep mcfcm_st"的输出结果是,所有含有关键字"mcfcm_st"的进程,这是Oracle数据库中远程连接进程的共同特点。..."grep -v grep"是在列出的进程中去除含有关键字"grep"的进程。 "cut -c 9-15"是截取输入行的第9个字符到第15个字符,而这正好是进程号PID。..."xargs kill -9"中的xargs命令是用来把前面命令的输出结果(PID)作为"kill -9"命令的参数,并执行该令。..."kill -9"会强行杀掉指定进程,这样就成功清除了oracle的所有远程连接进程。其它类似的任务,只需要修改"grep php"中的关键字部分就可以了。

    96220
    领券