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

如何找到并杀死Linux数据中心服务器上的僵尸进程?

【51CTO.com快译】Linux进程经常误入歧途,什么都不做,甚至不耗用CPU周期。虽然僵尸进程不像运行中的流氓应用程序那样占用宝贵资源,但可能会构成威胁。如何构成威胁?某个进程成为僵尸进程时,它保留其进程ID(PID)。由于Linux系统的PID数量有限(不过数量很大),如果足够的PID沦为僵尸,其他进程就无法启动。

发生这种情况的可能性非常小。然而更重要的是,僵尸进程表明应用程序出现了岔子,某个程序中可能存在着错误。不应容忍数据中心软件上的错误,需要加以解决。你可能需要检查并杀死僵尸进程,才能解决问题。

因此,某个进程成为僵尸进程时,你怎么做?你要找到并杀死那些僵尸进程。下面教你怎么做。

找出僵尸进程

首先要做的是找出僵尸进程。幸好,由于ps命令,这很简单。通过grep显示ps命令的输出,列出STAT是Z(代表僵尸)的任何进程。打开终端窗口,执行下列命令:

ps aux | grep 'Z'

上述命令的输出将列出输出中包含Z的任何进程(图A)。

图A

如你所见,许多运行中的进程呈僵尸状态。该命令还将列出输出中包含字母Z的任何进程,因此你要忽略STAT列中没有Z的任何进程。

杀死僵尸进程

我们想要使用kill命令来终结那些僵尸进程。第一个命令的输出将包括所有僵尸进程的PID,因此想终结其中一个,只要执行命令:

kill PID

其中PID是相关进程的进程ID。因此,如果你想终终结沦为僵尸的thunderbird进程(其PID是20589),命令是:

kill 20589

就是这样。

你完全可以编写一个bash脚本来自动处理这项任务,不过可能会杀死必要进程。由于存在这个风险,我总是建议你手动处理此任务。考虑到我们面对的是生产级数据中心服务器(不过我在桌面系统上进行了演示),尤其应该这样。

如果你发现服务和应用程序崩溃,应该检查有无僵尸进程,并终结它们。一旦你知道了哪些进程是僵尸进程,应提交错误报告,或者联系并告知开发人员(如果应用程序常常崩溃,更应如此)。

原文标题:How to find and kill zombie processes on your Linux data center servers,作者:Jack Wallen

【51CTO译稿,合作站点转载请注明原文译者和出处为51CTO.com】

  • 发表于:
  • 原文链接https://kuaibao.qq.com/s/20190509A07DW100?refer=cp_1026
  • 腾讯「腾讯云开发者社区」是腾讯内容开放平台帐号(企鹅号)传播渠道之一,根据《腾讯内容开放平台服务协议》转载发布内容。
  • 如有侵权,请联系 cloudcommunity@tencent.com 删除。

扫码

添加站长 进交流群

领取专属 10元无门槛券

私享最新 技术干货

扫码加入开发者社群
领券