Linux 进程管理

Posted ranran1203

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Linux 进程管理相关的知识,希望对你有一定的参考价值。

进程管理

一.基础知识

  1.内存空间分为:线性空间和物理空间
  线性空间:内存被划分成页框,固定的存储空间
      虚拟内存 指令、数据、堆区、栈区
      常驻内存 系统的指定和数据

  2.进程上下文切换:进程的切换,保存将要退出的进程的现场,装载下一个要运行的进程
  进程的属性:
    进程号
    内存空间
    启动用户
    父进程
    占用CPU时间
     3.因为有了线程,一个进程才能工作于多个CPU,并发执行

     4. 进程状态
    运行状态
            Uninterrutible sleep 不可中断睡眠:需要I/O资源的中断,
            interrutible sleep 可中断睡眠:不是因为I/O产生的中断

    僵尸进程:进程结束了,占据的内存空间不释放

     5.进程是有父子关系的
    所有进程都是init的子进程

     6.进程有优先级的0-139 数字越小优先级越高
        0-99:内核调整的
        100-139:用户可控制的

   进程的查找时间大O标准
          O(1)
          O(n)
          O(logn)
          O(n^2)
          O(2^x)
  优先级高的进程
      1).获得更多CPU运行时间
      2)更优先获得运行的机会  nice 值:优雅的友好的  -20--19:nice值越小,优先级越高

  100-139:对应的进程优先级号
  默认进程的nice的值为0
  普通用户只能调大自己的进程的nice
  管理员可以随意调节

   7.PID:进程号
    /proc 下的每一个数字目录对应一个进程,内核映射的文件,伪文件系统
    init的进程号永远为1

二.进程命令
  1.ps process state
          
BSD风格:

  a:显示所有跟终端有关的进程
  u:显示用户的启动
  x:显示所有跟终端无关的进程
    进程的分类:
      跟终端相关的进程
      跟终端无关的进程
    进程状态:
      D:不可中断的睡眠
      R:运行或就绪
      S:可中断的睡眠
      T:停止
      Z:僵死

      <:高优先级进程
      N:低优先级进程
      +:前台进程组的进程
      l:多线程进程
      s:会话进程首进程
    VSZ:虚拟内存集
    RSS:常驻内存集

  COMMAND [] 标识内核进程

sys风格的
  ps -ef
  ps -eF
  ps -elF

ps -o pid,comm,ni 只显示前台进程
ps -axo pid,comm,ni 显示所有进程
2.pstree 显示进程树

3.pgrep 以grep查看进程,只显示进程号
  pgrep -u root

4.pidof 查看指定进程的pid
pidof init

5.top:监控每个进程,每隔5秒钟刷新一次

 

01:06:48 当前时间
up 1:22 系统运行时间,格式为时:分
1 user 当前登录用户数
load average: 0.06, 0.60, 0.48 系统负载,即任务队列的平均长度。
三个数值分别为 1分钟、5分钟、15分钟前到现在的平均值。

第二、三行为进程和CPU的信息。当有多个CPU时,这些内容可能会超过两行。内容如下:

Tasks: 29 total 进程总数
1 running 正在运行的进程数
28 sleeping 睡眠的进程数
0 stopped 停止的进程数
0 zombie 僵尸进程数
Cpu(s): 0.3% us 用户空间占用CPU百分比
1.0% sy 内核空间占用CPU百分比
0.0% ni 用户进程空间内改变过优先级的进程占用CPU百分比
98.7% id 空闲CPU百分比
0.0% wa 等待输入输出的CPU时间百分比
0.0% hi  
0.0% si  

最后两行为内存信息。内容如下:

Mem: 191272k total 物理内存总量
173656k used 使用的物理内存总量
17616k free 空闲内存总量
22052k buffers 用作内核缓存的内存量

Swap: 192772k total

交换区总量
0k used 使用的交换区总量
192772k free 空闲交换区总量
123988k cached 缓冲的交换区总量。
内存中的内容被换出到交换区,而后又被换入到内存,但使用过的交换区尚未被覆盖,
该数值即为这些内容已存在于内存中的交换区的大小。
相应的内存再次被换出时可不必再对交换区写入。


选项,可以在显示时交互输入
M: 根据驻留内存大小进行排序
P:根据CPU使用百分比进行排序
T: 根据累计时间进行排序

l: 是否显示平均负载和启动时间
t: 是否显示进程和CPU状态相关信息
m: 是否显示内存相关信息

c: 是否显示完整的命令行信息
q: 退出top
k: 终止某个进程

top
-d: 指定延迟时长,单位是秒
-b: 批模式
-n #:在批模式下,共显示多少批

6.进程间通信(IPC)
  共享内存
  信号:signal
  Semaphore:旗语

  kill -l 所有可用信号
    重要的信号
  1)SIGHUP 让一个进程不用重启,就能重读配置文件,并让配置信息生效
  2)SIGINT 中断一个进程
  9)SIGKILL 杀死一个进程,强行杀死
  15)SIGTERM 终止一个进程 kill 的默认信号

  指定一个信号
  信号号码:kill -1
  信号名称:kill -SIGKILL
  信号名称简写: kill -KILL

  kill 进程号 杀死进程
  killall COMMAND

7.调整nice
调整已经启动的nice值
   renice 新的nice PID

在启动时指定nice
nice -n NI COMMAND
nice -n -3 useradd hbase

8.前台作业:占据了命令提示符
 后台作业:启动后,释放命令提示符,后续的操作在后台完成
tar -jcf 文件 文件 & 转到后台运行

前台送往后台:ctrl+Z 正在前台的作业送往后台
                     或者command +&
bg:让后台的停止的就业运行
bg [[%]作业号]
jobs:查看后台的所有作业
作业号不同于进程号
+:命令将默认认操作的作业
-:命令将第二个执行的作业

fg:将后台作业调回前台
fg [[%]作业号]
kill %作业号 终止作业

10.vmstat:系统状态查看命令
  1    每隔1秒钟刷新一次
  1 5   每隔1秒显示一次但是只显示5次
11.uptime
  /proc/memifo 内存信息
  cd /proc/1 cat maps 查看进程文件占用的内存

以上是关于Linux 进程管理的主要内容,如果未能解决你的问题,请参考以下文章

Linux 内核Linux 内核体系架构 ( 进程调度 | 内存管理 | 中断管理 | 设备管理 | 文件系统 )

Linux性能及调优指南(翻译)之Linux进程管理

linux进程管理

Linux进程管理专题

linux进程管理

Linux 进程管理 进程优先级管理