[转帖]如何自动杀死UNIX僵死的进程_VMware, Unix及操作系统讨论区_Weblogic技术|Tuxedo技术|中间件技术|Oracle论坛|JAVA论坛|Linux/Unix技术|hadoop论坛_联动北方技术论坛  
网站首页 | 关于我们 | 服务中心 | 经验交流 | 公司荣誉 | 成功案例 | 合作伙伴 | 联系我们 |
联动北方-国内领先的云技术服务提供商
»  游客             当前位置:  论坛首页 »  自由讨论区 »  VMware, Unix及操作系统讨论区 »
总帖数
1
每页帖数
101/1页1
返回列表
0
发起投票  发起投票 发新帖子
查看: 3396 | 回复: 0   主题: [转帖]如何自动杀死UNIX僵死的进程        下一篇 
赖文婷
注册用户
等级:少校
经验:1094
发帖:81
精华:0
注册:2012-11-5
状态:离线
发送短消息息给赖文婷 加好友    发送短消息息给赖文婷 发消息
发表于: IP:您无权察看 2012-11-12 14:24:50 | [全部帖] [楼主帖] 楼主

人保系统的计算机应用,已从单机运行方式过渡到以公司为中心的集中处理方式,各县级支公司通过广域网、

远程telnet登录到市公司主机。由于网络的原因,有些进程会突然僵死。这些僵死的进程,会消耗系统大量的资源,

直接影响机器的正常运行。为了实时地、自动地杀死这些僵死的进程,本人编写了 Shell程序Autokill

Autokill程序脚本

#
# autokill
#
ps -ef | awk ‘{ print $1,$2,$7,$8 }‘ |
awk ‘/[0-9][0-9]:[0-9][0-9]:[1-9][0-9]/ { print $1,$2,$3,$4 }‘ |
awk ‘!/root/ { print "kill -9 " $2}‘> /tmp/k_kill
chmod 777 /tmp/k_kill
/tmp/k_kill


Autokill程序解释

  首先,用UNIX 命令 ps -ef 查看进程状态,通过管道传送给 awk 进行处理。

在第一个 awk 中,获取进程的用户标识(UID)、进程号(PID)、进程占用CPU时间(Time)、进程执行命令

CMD)四个字段的值。

在第二个awk 中,通过模式匹配,选取所有匹配模式的行。在awk 中,[0-9]匹配09中任一个数字,[1-9]匹配

19中任何一个数字,连用两个[0-9][0-9]则匹配一个任意两位数,因此[0-9][0-9][0-9][0-9][1-9][0-9]则匹

 Time时间字段值,查找占用 CPU 时间超过 10 秒的进程;如果要查找占用 CPU 时间超过半小时的进程,则把模式

改成 [0-9][0-9][3-9][0-9][0-9][0-9]

在第三个 awk 中,用!/root/ ”过滤掉由 Root用户生成的进程,并进行Shell语言拼装,并将最终结果定向到

文件 /tmp/k_kill。在 /tmp/k_kill 文件中,都是形如 kill -9 123 Shell命令。

Autokill程序的最后,执行 /tmp/k_kill 杀死进程。

查看中间结果

Autokill程序采用了管道处理方式,如要查看中间结果,则可以依次断开管道。

第一步执行:ps -ef 

第二步执行:ps -ef | awk { print $1,$2,$7,$8 }

第三步执行:ps -ef | awk { print $1,$2,$7,$8 } | 

awk ‘/[0-9][0-9]:[0-9][0-9]:[1-9][0-9]/ { print $1,$2,$3,$4 }‘


第四步执行:ps -ef | awk { print $1,$2,$7,$8 } | 

awk ‘/[0-9][0-9]:[0-9][0-9]:[1-9][0-9]/ { print $1,$2,$3,$4 }‘ |
awk ‘!/root/ { print "kill -9 " $2}‘> /tmp/k_kill


最终查看 /tmp/k_kill 文件。

再有,如只想自动杀死由某一用户执行的进程(如jdc3206),只要将模式“!/root/”改成/jdc3206/”即可;

如只想杀死执行某一命令的进程(如 xinmu ,只要将模式“!/root/改成“/xinmu/”即可。

最后用 crontab -e 增加一个 cron 作业。

0,30 * * * * /tmp/autokill


Kill命令失灵怎么办

经过以上步骤,系统每隔半小时执行一次/tmp/autokill。但在UNIX系统中,有些僵死的进程会莫名其妙地不能用

    Kill 命令杀死,这就需要重新引导机器,一方面清除系统垃圾,另一方面需要对资源重新分配。采用中心运行模式,

机器不能随意开关机,总要等到夜晚没有用户使用机器时,才能重新开关机。为此编写一个Shell程序,让机器自动

开关机。以下是Autoreboot 程序脚本。

#
# autoreboot
#
PATH=/bin:/etc:/usr/bin:/tcb/bin:/usr/informix/bin
INFORMIXDIR=/usr/informix
INFORMIXSERVER=da3206a
ONCONFIG=onconfig.yca
export PATH INFORMIXDIR INFORMIXSERVER ONCONFIG
onmode -ky
sync
sync
reboot


Autoreboot程序前 5 行,是设置 Informix系统环境,命令 onmode -ky 是关闭 Informix Online数据库,命令

sync UNIX 文件系统超级块回写,命令 reboot UNIX 系统中的系统重新启动命令。

 crontab -e 命令,增加一行 cron 作业30 6 * * * /tmp/auto_boot

该命令使系统每天630 重新开关机。如果使用的是双机系统,则要在两台机器上,都要进行重新开关机,时间定成一致。




赞(0)    操作        顶端 
总帖数
1
每页帖数
101/1页1
返回列表
发新帖子
请输入验证码: 点击刷新验证码
您需要登录后才可以回帖 登录 | 注册
技术讨论