zoukankan      html  css  js  c++  java
  • 进程和计划任务管理2

    uptime

    uptime

    以下显示输入uptime的信息:

    04:03:58 up 10 days, 13:19, 1 user, load average: 0.54, 0.40, 0.20
    1. 当前时间 04:03:58
    2. 系统已运行的时间 10 days, 13:19
    3. 当前在线用户 1 user
    4. 平均负载:0.54, 0.40, 0.20,最近1分钟、5分钟、15分钟系统的负载

    另外还有一个参数 -V(大写),是用来查询版本的

    procps是一个实用程序包,主要包括ps top kill等程序主要用来显示与控制一些系统信息,进程状态之类的内容。

    top

    top命令是Linux下常用的性能分析工具,能够实时显示系统中各个进程的资源占用状况,类似于Windows的任务管理器。下面详细介绍它的使用方法。

    top表头解释 内容如下:

    top - 16:58:24 当前系统时间
    1:54 系统已经运行1小时54分钟
    2 users 当前登录2个用户
    load average:0.00,0.00,0.00 系统平均负载:1分钟的,5分钟的,15分钟的
    Tasks: 108 total 任务:108个总进程
    1 running 1个进程正在运行
    107 sleeping 107个进程睡眠
    0 stoppd 0个进程停止
    0 zombie 0个僵尸进程(冻结进程)
    Cpu(s):0.0%us 用户控件占用CPU百分比
    0.0%sy 内核空间占用CPU百分比
    0.0%ni 用户进程控件内改变过优先级的进程占用CPU百分比
    100.0%id 空闲CPU百分比
    0.0%wa 等待输入输出的CPU时间百分比
    0.0%hi 硬件中断(Software Interrupts)占用CPU的百分比
    0.0%si 软件中断(Software Interrupts)占用CPU的百分比
    Mem: 191272k total 物理内存总量 191272k
    173656k used 使用了 173656k 的物理内存
    17616k free 空闲 17616k 的物理内存
    22052k buffers 22052k 用作内核缓存
    Swap: 192772k total 交换分区总量 192772k
    0k used 使用的交换分区总量(没有使用交换分区)
    192772k free 空闲的交换分区总量  192772k
    123988k cached 缓冲的交换分区总量 123988k。
    内存中的内容被换出到交换区,而后又被换入到内存,但使用过的交换区尚未被覆盖,
    该数值即为这些内容已存在于内存中的交换区的大小。
    相应的内存再次被换出时可不必再对交换区写入。

    进程信息区

    统计信息区域的下方显示了各个进程的详细信息。首先来认识一下各列的含义。

    序号 列名 含义
    a PID 进程id
    b PPID 父进程id
    c RUSER Real user name
    d UID 进程所有者的用户id
    e USER 进程所有者的用户名
    f GROUP 进程所有者的组名
    g TTY 启动进程的终端名。不是从终端启动的进程则显示为 ?
    h PR 优先级
    i NI nice值。负值表示高优先级,正值表示低优先级
    j P 最后使用的CPU,仅在多CPU环境下有意义
    k %CPU 上次更新到现在的CPU时间占用百分比
    l TIME 进程使用的CPU时间总计,单位秒
    m TIME+ 进程使用的CPU时间总计,单位1/100秒
    n %MEM 进程使用的物理内存百分比
    o VIRT 进程使用的虚拟内存总量,单位kb。VIRT=SWAP+RES
    p SWAP 进程使用的虚拟内存中,被换出的大小,单位kb。
    q RES 进程使用的、未被换出的物理内存大小,单位kb。RES=CODE+DATA
    r CODE 可执行代码占用的物理内存大小,单位kb
    s DATA 可执行代码以外的部分(数据段+栈)占用的物理内存大小,单位kb
    t SHR 共享内存大小,单位kb
    u nFLT 页面错误次数
    v nDRT 最后一次写入到现在,被修改过的页面数。
    w S 进程状态。
    D=不可中断的睡眠状态
    R=运行
    S=睡眠
    T=跟踪/停止
    Z=僵尸进程
    x COMMAND 命令名/命令行
    y WCHAN 若该进程在睡眠,则显示睡眠中的系统函数名
    z Flags 任务标志,参考 sched.h

    默认情况下仅显示比较重要的 PID、USER、PR、NI、VIRT、RES、SHR、S、%CPU、%MEM、TIME+、COMMAND 列。可以通过下面的快捷键来更改显示内容。

    更改显示内容

    通过 键可以选择显示的内容。按 f 键之后会显示列的列表,按 a-z 即可显示或隐藏对应的列,最后按回车键确定。

    按 o 键可以改变列的显示顺序。按小写的 a-z 可以将相应的列向右移动,而大写的 A-Z 可以将相应的列向左移动。最后按回车键确定。

    按大写的 F 或 O 键,然后按 a-z 可以将进程按照相应的列进行排序。而大写的 R 键可以将当前的排序倒转。

    命令使用

    1. 工具(命令)名称
    top
    2.工具(命令)作用
    显示系统当前的进程和其他状况; top是一个动态显示过程,即可以通过用户按键来不断刷新当前状态.如果在前台执行该命令,它将独占前台,直到用户终止该程序为止. 比较准确的说,top命令提供了实时的对系统处理器的状态监视.它将显示系统中CPU最“敏感”的任务列表.该命令可以按CPU使用.内存使用和执行时间对任务进行排序;而且该命令的很多特性都可以通过交互式命令或者在个人定制文件中进行设定. 
    3.环境设置
    在Linux下使用。
    4.使用方法
    4.1使用格式
    top [-] [d] [p] [q] [c] [C] [S] [s] [n] 
    4.2参数说明
    d 指定每两次屏幕信息刷新之间的时间间隔。当然用户可以使用s交互命令来改变之。
    p 通过指定监控进程ID来仅仅监控某个进程的状态。
    q该选项将使top没有任何延迟的进行刷新。如果调用程序有超级用户权限,那么top将以尽可能高的优先级运行。
    S 指定累计模式
    s 使top命令在安全模式中运行。这将去除交互命令所带来的潜在危险。
    i 使top不显示任何闲置或者僵死进程。
    c 显示整个命令行而不只是显示命令名
    4.3其他
      下面介绍在top命令执行过程中可以使用的一些交互命令。从使用角度来看,熟练的掌握这些命令比掌握选项还重要一些。这些命令都是单字母的,如果在命令行选项中使用了s选项,则可能其中一些命令会被屏蔽掉。
      Ctrl+L 擦除并且重写屏幕。
      h或者? 显示帮助画面,给出一些简短的命令总结说明。
      k 终止一个进程。系统将提示用户输入需要终止的进程PID,以及需要发送给该进程什么样的信号。一般的终止进程可以使用15信号;如果不能正常结束那就使用信号9强制结束该进程。默认值是信号15。在安全模式中此命令被屏蔽。
      i 忽略闲置和僵死进程。这是一个开关式命令。
      q 退出程序。
      r 重新安排一个进程的优先级别。系统提示用户输入需要改变的进程PID以及需要设置的进程优先级值。输入一个正值将使优先级降低,反之则可以使该进程拥有更高的优先权。默认值是10。
      S 切换到累计模式。
      s 改变两次刷新之间的延迟时间。系统将提示用户输入新的时间,单位为s。如果有小数,就换算成m s。输入0值则系统将不断刷新,默认值是5 s。需要注意的是如果设置太小的时间,很可能会引起不断刷新,从而根本来不及看清显示的情况,而且系统负载也会大大增加。
      f或者F 从当前显示中添加或者删除项目。
      o或者O 改变显示项目的顺序。
      l 切换显示平均负载和启动时间信息。
      m 切换显示内存信息。
      t 切换显示进程和CPU状态信息。
      c 切换显示命令名称和完整命令行。
      M 根据驻留内存大小进行排序。
      P 根据CPU使用百分比大小进行排序。
      T 根据时间/累计时间进行排序。
         W 将当前设置写入~/.toprc文件中。这是写top配置文件的推荐方法。

    ps

    要对进程进行监测和控制,首先必须要了解当前进程的情况,也就是需要查看当前进程,ps命令就是最基本进程查看命令。使用该命令可以确定有哪些进程正在运行和运行的状态、进程是否结束、进程有没有僵尸、哪些进程占用了过多的资源等等.总之大部分信息都是可以通过执行该命令得到。ps是显示瞬间进程的状态,并不动态连续;如果想对进程进行实时监控应该用top命令。

    具体命令如下:

    • ps -A: 显示所有程序,与 -e 具有同样的效用;
    • ps a : 显示当前终端下的所有进程信息,包括其他用户的进程;
    • ps u :使用以用户为主的格式输出进程信息;
    • ps x :通常与 a 这个参数一起使用,显示当前用户在所有终端下的进程信息
    • ps c :列出程序时,显示每个程序真正的指令名称,而不包含路径,参数或常驻服务的标示。

    • ps e :列出程序时,显示每个程序所使用的环境变量。

    • ps f :用ASCII字符显示树状结构,表达程序间的相互关系。

    • ps -H :显示树状结构,表示程序间的相互关系。

    • ps -N :显示所有的程序,除了执行ps指令终端机下的程序之外。

    • ps s :采用程序信号的格式显示程序状况。

    • ps S :列出程序时,包括已中断的子程序资料。

    • ps -t:<终端机编号> 指定终端机编号,并列出属于该终端机的程序的状况。

    • ps x:显示所有程序,不以终端机来区分。

    • ps -e :显示系统内的所有进程信息;
    • ps -l  :使用长(long)格式显示进程信息;
    • ps j :工作的格式 (jobs format)
    • ps -f :使用完整的(full)格式显示进程信息。

    最常用的方法是 ps aux 和 ps -elf ,然后再利用一个管道符号导向到grep去查找特定的进程,然后再对特定的进程进行操作。

    特别说明:
      由于 ps 能够支持的系统类型相当的多,所以他的参数多的离谱,而且有没有加上 - 差很多!
    1.将目前属于您自己这次登入的 PID 与相关信息列示出来

     各相关信息的意义为:

    • F 代表这个程序的旗标 (flag), 4 代表使用者为 superuser;
    • S 代表这个程序的状态 (STAT);
    • UID 代表执行者身份
    • PID 进程的ID号!
    • PPID 父进程的ID;
    • C CPU使用的资源百分比
    • PRI指进程的执行优先权(Priority的简写),其值越小越早被执行;
    • NI 这个进程的nice值,其表示进程可被执行的优先级的修正数值。
    • ADDR 这个是内核函数,指出该程序在内存的那个部分。如果是个执行 的程序,一般就是『 - 』
    • SZ 使用掉的内存大小;
    • WCHAN 目前这个程序是否正在运作当中,若为 - 表示正在运作;
    • TTY 登入者的终端机位置;
    • TIME 使用掉的 CPU 时间。
    • CMD 所下达的指令名称

    2.列出目前所有的正在内存当中的程序

    • USER:该进程属于那个使用者账号。
    • PID :该进程的进程ID号。
    • %CPU:该进程使用掉的 CPU 资源百分比;
    • %MEM:该进程所占用的物理内存百分比;
    • VSZ :该进程使用掉的虚拟内存量 (Kbytes)
    • RSS :该进程占用的固定的内存量 (Kbytes)
    • TTY :该进程是在那个终端机上面运作,若与终端机无关,则显示 ?。另外, tty1-tty6 是本机上面的登入者程序,若为 pts/0 等等的,则表示为由网络连接进主机的程序。
    • STAT:该程序目前的状态,主要的状态有:
    1. R :该程序目前正在运作,或者是可被运作;
    2. S :该程序目前正在睡眠当中,但可被某些讯号(signal) 唤醒。
    3. T :该程序目前正在侦测或者是停止了;
    4. Z :该程序应该已经终止,但是其父程序却无法正常的终止他,造成 zombie (疆尸) 程序的状态
    • START:该进程被触发启动的时间;
    • TIME :该进程实际使用 CPU 运作的时间。
    •  COMMAND:该程序的实际指令。                                   

    pgrep 和  pkill 

    pgrep, pkill – 查找或者发信号给进程通过名称和其它属性。

    语法

    pgrep [-flvx] [-n | -o] [-d delim] [-P ppidlist] [-g pgrplist] [-s sidlist] [-u euidlist] [-U uidlist] [-G gidlist] [-J projidlist] [-t termlist] [-T taskidlist] [-c ctidlist] [-z zoneidlist] [pattern]

    pkill [-signal] [-fvx] [-n | -o] [-P ppidlist] [-g pgrplist] [-s sidlist] [-u euidlist] [-U uidlist] [-G gidlist] [-J projidlist] [-t termlist] [-T taskidlist] [-c ctidlist] [-z zoneidlist] [pattern]


    说明
    pgrep程序检查在系统的中活动进程,报告进程属性匹配命令行上指定条件的进程的ID。每一个进程ID以一个十进制数表示,通过一个分割字符串和下一个ID分开,默认的分割字符串是一个新行。对于每个属性选项,用户可以在命令行上指定一个以逗号分割的可能值的集合。例如,
    pgrep -G other,daemon
    匹配真实组ID是other或者是daemon的进程。如果多个条件被指派,这些匹配条件按逻辑与”AND”规则运算。例如,
    pgrep -G other,daemon -U root,daemon
    匹配进程它的属性是:
    (真实的组ID是other或者是daemon) 与 (真实的用户ID是root或者是daemon)
    pkill函数和pgrep相同,除了匹配的进程被信号通知就像用kill(1)替代了pgrep的进程ID的输出。一个信号名称或者数字可以作为pkill的第一个命令行选项。

    选项
    支持下面的选项:The following options are supported:
    -c ctidlist:仅匹配列表中列出的ID的进程。
    -d delim:指定每一个匹配的进程ID之间分割字符串。如果没有 -d 选项指定,默认的是新行字符。-d 选项仅在pgrep命令中有效。
    -f:正则表达式模式将执行与完全进程参数字符串 (从/proc/nnnnn/psinfo文件的pr_psargs字段获得)匹配。如果没有 -f 选项,表达式仅对执行文件名称(从/proc/nnnnn/psinfo文件pr_fname字段获得)匹配。
    -g pgrplist:仅匹配进程组ID在给定列表中的进程。如果组0包括在列表中,这个被解释为pgrep或者pkill进程的组ID。
    -G gidlist:仅匹配真实组ID在给定列表中的进程。每一个组ID可以使用组名称或者数字的组ID指定。
    -J projidlist:匹配项目ID在给定列表中的进程。每一个项目ID可以使用项目的名称或者数字项目ID来指定。
    -l:长格式输出。输出每一个匹配进程的名称连同进程ID。进程名称从pr_psargs 或者 pr_fname字段获得,依赖于-f选项是否指定。-l选项仅在pgrep命令中有效。
    -n:匹配最新(最近生成的)符合所有其它匹配条件的进程。不能和-o选项一起使用。
    -o:匹配最旧(最早生成的)符合所有其它匹配条件的进程。不能和-n选项一起使用。
    -P ppidlist :仅匹配给定列表中父进程ID的进程。
    -s sidlist :仅匹配进程会话ID在给定列表中的进程。如果ID 0在列表中,这个解释为pgrep或者pikill进程的会话ID。
    -t termlist:仅匹配与给定列表中终端关联的进程。每一个终端指定为在/dev中终端设备路径名称的后缀。例如term/a 或者 pts/0。
    -T taskidlist: 仅匹配在给定列表中任务ID的进程。如果ID 0包括在列表中,这个解释为pgrep或者pikill进程的会话ID。
    -u euidlist: 仅匹配有效用户ID在给定列表中的进程。每个用户ID可以通过一个登录名称或者数字的用户ID指定。
    -U uidlist: 仅匹配真实的用户ID在给定列表中的进程。每个用户ID可以通过一个登录名称或者数字的用户ID指定。
    -v :反向匹配。匹配所有的进程除了符合匹配条件的。
    -x :仅认为进程其参数字符串或者执行文件名称正确匹配规定模式是匹配的进程。模式被认为是准确的当所有在进程参数字符串或者可执行文件名称的字符匹配模式。
    -z zoneidlist: 仅匹配区域ID在给定列表中的进程。每一个区域ID可以使用一个区域名称或者一个数字的区域ID指定。这个选项仅在全局区域中执行有效。如果pkill程序用来往其它区域的进程发信号,进城必须宣称{PRIV_PROC_ZONE}特权。
    -signal :指定发往每一个匹配进程的信号。如果没有指定,SIGTERM 是默认的信号。-signal仅在pkill命令中作为第一个选项有效。信号可以是在signal.h中定义的没有SIG前缀的一个符号名字,也可是一个相应的信号数值。

    操作

    支持如下操作:
    pattern
    指定一个扩展正则表达式(Extended Regular Expression (ERE))模式来匹配可执行文件名称或者完整的进程参数字符串。ERE语法的完整描述参看regex(5)。

    例子

    例子1 获得一个进程ID

    获得sendmail的进程ID:

    example% pgrep -x -u root sendmail
    283

    例子2 终止一个进程

    终止最近生成的xterm:

    example% pkill -n xterm

    Exit Status

    如下退出值被返回:

    0 一个或者多个进程被匹配。
    1 没有进程被匹配。
    2 指定了无效的命令行参数。

    3 出现一个致命的错误。

    pstree

    查看进程树,使用pstree

    可以知道各进程之间的调用关系

    所有进程的开始是systemd

    (注:Centos6是initd)

    也可以加上选项,如下

    1. -a:显示每个程序的完整指令,包含路径,参数或是常驻服务的标示;
    2. -c:不使用精简标示法;
    3. -G:使用VT100终端机的列绘图字符;
    4. -h:列出树状图时,特别标明现在执行的程序;
    5. -H:<程序识别码>:此参数的效果和指定"-h"参数类似,但特别标明指定的程序;
    6. -l:采用长列格式显示树状图;
    7. -n:用程序识别码排序。预设是以程序名称来排序;
    8. -p:显示程序识别码;
    9. -u:显示用户名称;
    10. -U:使用UTF-8列绘图字符;
    11. -V:显示版本信息。

    常用的格式是 pstree -auhp

    使用进程树查看的目的,主要是用来kill掉进程数

    因为有一些(病毒)进程,会由父进程,不断的监控子进程,如果子进程被kill掉,就会马上启动新的子进程,所以,需要找到父子进程

    进程的启动方式

     当我们在终端或控制台工作时,可能不希望由于运行一个作业而占住了屏幕,因为可能还有更重要的事情要做,比如阅读电子邮件。对于密集访问磁盘的进程,我们更希望它能够在每天的非负荷高峰时间段运行(例如凌晨)。为了使这些进程能够在后台运行,也就是说不在终端屏幕上运行,有几种选择方法可供使用。

    当在前台运行某个作业时,终端被该作业占据;可以在命令后面加上& 实现后台运行。例如:sh test.sh & 

    适合在后台运行的命令有f i n d、费时的排序及一些s h e l l脚本。在后台运行作业时要当心:需要用户交互的命令不要放在后台执行,因为这样你的机器就会在那里傻等。不过,作业在后台运行一样会将结果输出到屏幕上,干扰你的工作。如果放在后台运行的作业会产生大量的输出,最好使用下面的方法把它的输出重定向到某个文件中:

         command >out.file2 >&1&         (ps:command 为 命令)

        这样,所有的标准输出和错误输出都将被重定向到一个叫做out.file 的文件中。

         PS:当你成功地提交进程以后,就会显示出一个进程号,可以用它来监控该进程,或杀死它。(ps -ef | grep 进程号 或者 kill -9 进程号)

    nohup 

    使用&命令后,作业被提交到后台运行,当前控制台没有被占用,但是一但把当前控制台关掉(退出帐户时),作业就会停止运行。nohup命令可以在你退出帐户之后继续运行相应的进程。nohup就是不挂起的意思( no hang up)。该命令的一般形式为:

          nohup command &

         如果使用nohup命令提交作业,那么在缺省情况下该作业的所有输出都被重定向到一个名为nohup.out的文件中,除非另外指定了输出文件:

          nohup command > myout.file2 > &1&

          使用了nohup之后,很多人就这样不管了,其实这样有可能在当前账户非正常退出或者结束的时候,命令还是自己结束了。所以在使用nohup命令后台运行命令之后,需要使用exit正常退出当前账户,这样才能保证命令一直在后台运行。

    ctrl + z 

    可以将一个正在前台执行的命令放到后台,并且处于暂停状态。

    Ctrl+c 

    终止前台命令。

    jobs 

    查看当前有多少在后台运行的命令。 

    jobs -l选项可显示所有任务的PID,jobs的状态可以是running, stopped, Terminated。但是如果任务被终止了(kill),shell 从当前的shell环境已知的列表中删除任务的进程标识。

    fg

    将后台进程恢复到前台运行,可指定任务序列号

    bg

    将后台暂停的进程调至后台运行

    kill、killall 命令

     kill 用于终止指定PID号的进程

    killall 用于终止指定名称的所有进程

    -9 选项用于强制终止

     

  • 相关阅读:
    C#扩展方法学习
    如何用PS快速做出3D按钮效果的图片
    比较C#中几种常见的复制字节数组方法的效率[转]
    GUID的学习
    委托与事件的区别
    利用Marshal.AllocHGlobal申请非托管内存,unsafe代码
    JAVASE(十三) 异常处理
    JAVASE(十二) Java常用类: 包装类、String类、StringBuffer类、时间日期API、其他类
    JAVASE(十一) 高级类特性: abstract 、模板模式、interface、内部类、枚举、注解
    面试题: SpringBoot 的自启动原理
  • 原文地址:https://www.cnblogs.com/2567xl/p/11323645.html
Copyright © 2011-2022 走看看