linux进程管理(二)

王朝学院·作者佚名  2016-08-27
窄屏简体版  字體: |||超大  

接上【linux进程管理(一)】终止进程的工具kill、killall、pkill

终止一个进程或终止一个正在运行的程序,一般是通过 kill 、killall、pkill、xkill 等进行。比如一个程序已经死掉,但又不能退出,这时就应该考虑应用这些工具。

另外应用的场合就是在服务器管理中,在不涉及数据库服务器程序的父进程的停止运行,也可以用这些工具来终止。为什么数据库服务器的父进程不能用这些工具杀死呢?原因很简单,这些工具在强行终止数据库服务器时,会让数据库产生更多的文件碎片,当碎片达到一定程度的时候,数据库就有崩溃的危险。比如MySQL服务器最好是按其正常的程序关闭,而不是用pkill mysqld 或killall mysqld 这样危险的动作;当然对于占用资源过多的数据库子进程,我们应该用kill 来杀掉。

killkill的应用是和ps 或pgrep 命令结合在一起使用的;

kill的用法:

kill [信号代码] 进程ID

注:信号代码可以省略;我们常用的信号代码是 -9 ,表示强制终止;

举例:[root@localhost ~]# ps auxf |grep httpd

root49390.00.05160708pts/3S+13:100:00\_ grep httpd

root48300.11.32423210272? Ss13:020:00/usr/sbin/httpd

apache48330.00.6243644932? S13:020:00\_ /usr/sbin/httpd

apache48340.00.6243644928? S13:020:00\_ /usr/sbin/httpd

apache48350.00.6243644928? S13:020:00\_ /usr/sbin/httpd

apache48360.00.6243644928? S13:020:00\_ /usr/sbin/httpd

apache48370.00.6243644928? S13:020:00\_ /usr/sbin/httpd

apache48380.00.6243644928? S13:020:00\_ /usr/sbin/httpd

apache48390.00.6243644928? S13:020:00\_ /usr/sbin/httpd

apache48400.00.6243644928? S13:020:00\_ /usr/sbin/httpd

我们查看httpd 服务器的进程;您也可以用pgrep -l httpd 来查看;

我们看上面例子中的第二列,就是进程PID的列,其中4830是httpd服务器的父进程,从4833-4840的进程都是它4830的子进程;如果我们杀掉父进程4830的话,其下的子进程也会跟着死掉;

[root@localhost ~]# kill4840注:杀掉4840这个进程;

[root@localhost~]# ps -auxf |grep httpd 注:查看一下会有什么结果?是不是httpd服务器仍在运行?

[root@localhost~]# kill4830注:杀掉httpd的父进程;

[root@localhost~]# ps -aux |grep httpd 注:查看httpd的其它子进程是否存在,httpd服务器是否仍在运行?

对于僵尸进程,可以用kill -9 来强制终止退出比如一个程序已经彻底死掉,如果kill 不加信号强度是没有办法退出,最好的办法就是加信号强度 -9 ,后面要接杀父进程;比如;

[root@localhost ~]# ps aux |grep gaim

beinan50319.02.310499617484? S13:230:01gaim

root50360.00.05160724pts/3S+13:240:00grep gaim

[root@localhost~]# pgrep -l gaim5031gaim

[root@localhost~]# kill -95031

killall用法:killall 正在运行的程序名

killall 也和ps或pgrep 结合使用,比较方便;通过ps或pgrep 来查看哪些程序在运行;

举例:

[root@localhost beinan]# pgrep -l gaim2979gaim

[root@localhost beinan]# killall gaim

pkillpkill 和killall 应用方法差不多,也是直接杀死运行中的程序;如果您想杀掉单个进程,请用kill 来杀掉。

应用方法:

#pkill 正在运行的程序名

举例:

[root@localhost beinan]# pgrep -l gaim2979gaim

[root@localhost beinan]# pkill gaim

top 监视系统任务的工具:和ps 相比,top是动态监视系统任务的工具,top 输出的结果是连续的;

top调用方法:

top 选择参数

参数:

-b 以批量模式运行,但不能接受命令行输入;-c 显示命令行,而不仅仅是命令名;-d N 显示两次刷新时间的间隔,比如 -d5,表示两次刷新间隔为5秒;-i 禁止显示空闲进程或僵尸进程;-n NUM 显示更新次数,然后退出。比如 -n5,表示top更新5次数据就退出;-p PID 仅监视指定进程的ID;PID是一个数值;-q 不经任何延时就刷新;-s 安全模式运行,禁用一些效互指令;-S 累积模式,输出每个进程的总的CPU时间,包括已死的子进程;

交互式命令键位:

space 立即更新;

c 切换到命令名显示,或显示整个命令(包括参数);

f,F 增加显示字段,或删除显示字段;

h,?显示有关安全模式及累积模式的帮助信息;

k 提示输入要杀死的进程ID,目的是用来杀死该进程(默人信号为15)

i 禁止空闲进程和僵尸进程;

l 切换到显法负载平均值和正常运行的时间等信息;

m 切换到内存信息,并以内存占用大小排序;

n 提示显示的进程数,比如输入3,就在整屏上显示3个进程;

o,O 改变显示字段的顺序;

r 把renice 应用到一个进程,提示输入PID和renice的值;

s 改变两次刷新时间间隔,以秒为单位;

t 切换到显示进程和CPU状态的信息;

A 按进程生命大小进行排序,最新进程显示在最前;

M 按内存占用大小排序,由大到小;

N 以进程ID大小排序,由大到小;

P 按CPU占用情况排序,由大到小

S 切换到累积时间模式;

T 按时间/累积时间对任务排序;

W 把当前的配置写到~/.toPRc中;

top 应用举例:[root@localhost ~]# top

然后根据前面所说交互命令按个尝试一下就明白了,比如按M,就按内存占用大小排序

当然您可以把top的输出传到一个文件中;

[root@localhost ~]# top > mytop.txt

然后我们就可以查看mytop文件,以慢慢的分析系统进程状态;

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
 
 
© 2005- 王朝網路 版權所有 導航