Chinaunix首页 | 论坛 | 博客
  • 博客访问: 590508
  • 博文数量: 151
  • 博客积分: 3330
  • 博客等级: 中校
  • 技术积分: 1686
  • 用 户 组: 普通用户
  • 注册时间: 2011-01-08 02:41
文章存档

2011年(151)

分类: LINUX

2011-04-24 02:43:23

进程的相关属性:

父进程和父进程的ID(PPID);
进程ID(PID):是唯一的数值,用来区分进程;
启动进程的用户ID(UID)和所属的组(GID);
进程状态:状态分为运行R、休眠S、僵尸Z;
进程执行的优先级;
进程所连接的终端名;
进程资源占用:比如占用资源大小(内存、CPU占用量);

父进程和子进程:

他们的关系是管理和被管理的关系,当父进程终止时,子进程也随之而终止。但子进程终止,父进程并不一定终止。比如httpd服务器运行时,我们可以杀掉其子进程,父进程并不会因为子进程的终止而终止。

进程管理:

对于Linux进程的管理,是通过进程管理工具实现的,比如ps、kill、pgrep,pkill等工具;

ps 选项
-e 显示所有进程,环境变量
-f 全格式
-h 不显示标题
-l 长格式
-w 宽输出
-a 显示终端上地所有进程,包括其他用户地进程
-r 只显示正在运行地进程
-x 显示没有控制终端地进程
-ww 避免详细参数被截断;

常用的选项是组合是aux 或lax,还有参数f的应用;

ps aux 或lax输出的解释;

USER 进程的属主;
PID 进程的ID;
PPID  父进程;
%CPU 进程占用的CPU百分比;
%MEM 占用内存的百分比;
NI   进程的NICE值,数值大,表示较少占用CPU时间;
VSZ (virtual memory size)进程占用的虚拟交换分区大小;
RSS (resident set size):进程实际占用的物理内存
WCHAN 
TTY  终端ID
START 进程启动的时间 (月日)
TIME  进程占用的CPU时间
COMMAND 命令的名称和参数
WCHAN  正在等待的进程资源
STAT 进程状态
D    Uninterruptible sleep (usually IO)
R    正在运行可中在队列中可过行的; 
S    处于休眠状态;
T    停止或被追踪; 
W    进入内存交换(从内核2.6开始无效);
X    死掉的进程(从来没见过);
Z    僵尸进程;

<    优先级高的进程 
N    优先级较低的进程 
L    有些页被锁进内存; 
s    进程的领导者(在它之下有子进程);
l    is multi-threaded (using CLONE_THREAD, like NPTL pthreads do)
+    位于后台的进程组;



pgrep

常用参数

-l  列出程序名和进程ID;
-o  进程起始的ID;
-n  进程终止的ID;

pgrep -ln mysqld
pgrep -l mysqld
pgrep mysqld
范围从 -20 (最高优先级)到 19 (最低优先级)范围从 -20 (最高优先级)到 19 (最低优先级)范围从 -20 (最高优先级)到 19 (最低优先级)范围从 -20 (最高优先级)到 19 (最低优先级)

终止进程的工具 kill 、killall、pkill、xkill;

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

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

kill 的用法:

kill [信号代码]   进程ID
kill -9 mysqld   -9 表示强制杀死mysqld进程

killall 通过程序的名字,直接杀死所有进程
killall httpd  

pkill 也是直接杀进程名的工具
pkill firefox

xkill 用在图形界面下的专杀进程工具,需要启动他
在shell提示符下输入:xkill 即可调用启动它


top 监视系统任务的工具;

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

参数:

-b      以批量模式运行,但不能接受命令行输入;
-c      显示命令行,而不仅仅是命令名;
-d N    显示两次刷新时间的间隔,比如 -d 5,表示两次刷新间隔为5秒;
-i      禁止显示空闲进程或僵尸进程;
-n NUM  显示更新次数,然后退出。比如 -n 5,表示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命令显示的项目很多,默认值是每5秒更新一次,显示的各项目为:

  uptime 该项显示的是系统启动时间、已经运行的时间和三个平均负载值(最近1秒,5秒,15秒的负载值)。

  processes 自最近一次刷新以来的运行进程总数。当然这些进程被分为正在运行的,休眠的,停止的等很多种类。进程和状态显示可以通过交互命令t来实现。

  CPU states 显示用户模式,系统模式,优先级进程(只有优先级为负的列入考虑)和闲置等各种情况所占用CPU时间的百分比。优先级进程所消耗的时间也被列入到用户和系统的时间中,所以总的百分比将大于100%。

  Mem 内存使用情况统计,其中包括总的可用内存,空闲内存,已用内存,共享内存和缓存所占内存的情况。

  Swap 交换空间统计,其中包括总的交换空间,可用交换空间,已用交换空间。

  PID 每个进程的ID。

  PPID 每个进程的父进程ID。

  UID 每个进程所有者的UID 。

  USER 每个进程所有者的用户名。

  PRI 每个进程的优先级别。

  NI 该进程的优先级值。

  SIZE 该进程的代码大小加上数据大小再加上堆栈空间大小的总数。单位是KB。

  TSIZE 该进程的代码大小。对于内核进程这是一个很奇怪的值。

  DSIZE 数据和堆栈的大小。

  TRS 文本驻留大小。

  D 被标记为“不干净”的页项目。

  LIB 使用的库页的大小。对于ELF进程没有作用。

  RSS 该进程占用的物理内存的总数量,单位是KB。

  SHARE 该进程使用共享内存的数量。

  STAT 该进程的状态。其中S代表休眠状态;D代表不可中断的休眠状态;R代表运行状态;Z代表僵死状态;T代表停止或跟踪状态。

  TIME 该进程自启动以来所占用的总CPU时间。如果进入的是累计模式,那么该时间还包括这个进程子进程所占用的时间。且标题会变成CTIME。

  %CPU 该进程自最近一次刷新以来所占用的CPU时间和总时间的百分比。

  %MEM 该进程占用的物理内存占总内存的百分比。

  COMMAND 该进程的命令名称,如果一行显示不下,则会进行截取。内存中的进程会有一个完整的命令行。

进程的优先级:nice和renice;

优先级范围:其范围从 -20 (最高优先级)到 19 (最低优先级)

默认情况下,进程的优先级是 0 (“基本”调度优先级)。

nice 用于设置进程的优先级

nice -n 5 httpd

renice 用于改变进程的优先级

renice 优先级 [[-p] pid ...] [[-g] pgrp ...] [[-u] 用户名 ...]

renice +20 -u admin 




阅读(718) | 评论(0) | 转发(0) |
0

上一篇:MIME

下一篇:linux grep 命令

给主人留下些什么吧!~~