目录
学习链接:
Linux 监控工具讲解
Linux 10个top工具
一、进程
1.1 程序、进程和线程的关系
程序:
- 保存在 硬盘、光盘等介质中的可执行代码和数据;
- 文件中静态保存的代码;
进程:
- 在CPU及内存中运行的程序
- 动态执行的代码
- 一个进程(父进程)可以拥有一个或多个进程(子进程)
- 是资源分配的最小单位(CPU分配资源)
- 坏掉一个进程,其它进程不受影响
线程:
- 线程是CPU调度的最小单位(程序执行的最小单元,共享线程内存资源)
- 它被包含在进程之中,是进程中的实际运作单元。
- 一条线程是进程中一个单一顺序的控制流,一个进程中可以并发多个线程,每条线程并行执行不同的任务。
- 坏掉一个线程,其他线程会受影响
那么在Linux系统中如何查看、管理进程呢?方法有很多种,本篇只讲解常用的 ps 、top 命令。
1.2 查看静态进程信息 ps
ps 命令
用来查看 静态的 进程统计信息(静态,只显示一次,不会自动刷新)。有两种用法:
方法一:ps aux
- a:显示终端上的所有进程,包括其它用户的进程。
- u:表示列出进程的用户。
- x:显示所有终端的进程。
- -T:开启线程查看,也可以使用
ps -T -p <pid>
查看进程号pid 的进程创建的所有线程。
列名 | 说明 |
---|---|
USER | 进程的用户 |
PID | 进程的ID号 |
%CPU | 进程占用的 CPU 百分比 |
%MEM | 进程占用的 内存 的百分比 |
VSZ | 该进程使用的虚拟内存量(KB) |
RSS | 该进程占用的物理内存量(KB) |
TTY | 启动进程的终端名。不是从终端启动的进程则显示为: ? |
STAT | 该进程的状态(D:不可中断的休眠状态;R:正在运行;S:休眠状态,可被唤醒;T:停止状态,可能是在后台暂停或进程处于跟踪调试状态;Z:僵尸进程,进程已经中止,但是部分程序还在内存中) |
START | 该进程被触发启动时间 |
TIME | 该进程实际使用CPU运行的时间 |
COMMAND | 进程的启动命令 |
什么是僵尸进程?
- 当一个进程结束了,但是如果该进程的父进程已经先结束了,那么该进程就不会变成僵尸进程,因为每个进程结束的时候,系统都会扫描当前系统中所运行的所有进程,看有没有哪个进程是刚刚结束的这个进程的子进程,如果是的话,就由 init 进程 来接管它,成为它的父进程,子进程退出后 init 会回收其占用的相关资源。
- 但是当子进程比父进程先结束,而父进程又没有回收子进程,没有释放子进程占用的资源,此时子进程将成为一个僵尸进程。
#补充命令
ps aux | wc -l #查看有多少个线程(一行一个)3
ps -aux | grep java #查看java有关的进程
方法二:ps -elf
- 使用 -elf 与 aux 展示的字段稍有不一样
- -e:显示系统内的所有进程信息。
- -l:使用长格式显示进程信息。
- -f:使用完整的格式显示进程信息。
列名 | 说明 |
---|---|
F | 内核分配给进程的系统标记 |
S | 进程的状态 |
UID | 启动这些进程的用户 |
PID | 进程的进程ID |
PPID | 父进程的进程号(如果该进程是由另一个进程启动的) |
C | 进程生命周期中的CPU利用率 |
PRI | 进程的优先级(越大的数字代表越低的优先级) |
NI | 谦让度值用来参与决定优先级 |
ADDR | 进程的内存地址 |
SZ | 假如进程被换出,所需交换空间的大致大小 |
WCHAN | 若该进程在睡眠,则显示睡眠中的系统函数名 |
STIME | 进程启动时的系统时间 |
TTY | 进程启动时的终端设备 |
TIME | 运行进程需要的累计CPU时间 |
CMD | 进程的启动命令 |
1.3 查看动态进程信息 top
动态刷新进程排名信息,5秒执行一次,可通过键盘按某个属性进行排序。
[ 进程总览信息区 ]中,每一行代表的含义:
第一行 是任务队列信息:
系统时间
up 5:32 ----系统已运行时长
2 user ----当前登录用户数
load average: 0.00, 0.01, 0.05
----系统负载,即单位时间内系统处理的任务数,'
----后面三个数值分别为1分钟、5分钟、15分钟前到现在的平均值
第二行 为进程信息
Tasks ----总进程数
Threads ----总线程数(按H)
running ----正在运行的进程数
sleeping ----休眠的进程数
stopped ----中止的进程数
zombie