一、程序和进程的关系
-
程序
- 保存在硬盘、光盘等介质中的可执行代码和数据
- 文件中静态保存的代码
-
进程
- 在CPU及内存中运行的程序代码
- 动态执行的代码
- 父、子进程
每个程序可以创建一个或多个进程
二、常看进程信息
-
ps命令
查看静态的进程统计信息
ps aux
部分选项
a | 显示现行终端下的所有进程,包括其它用户的进程 |
u | 显示进程的归属用户及内存的使用情况 |
x | 显示所有终端的进程 |
h | 不显示标题列 |
USER | 进程的用户 |
PID | 进程的ID |
%CPU | 进程占用的CPU百分比,占用越高,进程越耗费资源 |
%MEM | 占用内存的百分比 |
VSZ | 该进程使用的虚拟内存量(KB) |
RSS | 该进程占用的实际物理内存量(KB) |
TTY | 启动进程的终端名。不是从终端启动的进程则显示为 ? |
STAT | 该进程的状态(D:不可中断的休眠状态;R:正在运行状态;S:处于休眠状态,可被唤醒;T:停止状态,可能是在后台暂停或进程处于跟踪调试状态;Z:僵尸进程,进程已经中止,但是部分程序还在内存当中) |
START | 该进程被启动时间 |
TIME | 该进程实际使用CPU的时间 |
COMMAND | 进程的名称与参数 |
- 僵尸进程
一个进程结束了,但是如果该进程的父进程已经先结束了,那么该进程就不会变成僵尸进程,因为每个进程结束的时候,系统都会扫描当前系统中所运行的所有进程,看有没有哪个进程是刚刚结束的这个进程的子进程,如果是的话,就由Init来接管它,成为它的父进程,子进程退出后init会回收其占用的相关资源。但是当子进程比父进程先结束,而父进程又没有回收子进程,释放子进程占用的资源,此时子进程将成为一个僵尸进程
ps -elf
选项
-e | 显示系统内的所有进程信息 |
-l | 使用长格式显示进程信息 |
-f | 使用完整的格式显示进程信息 |
-a | 显示现行终端下的所有进程 |
-T | 查看线程信息 |
-C <进程名称> | 显示指定进程名的信息 |
-p <进程pid> | 显示指定pid的进程的信息 |
-H | 显示树状结构,表示进程间的相互关系 |
--no-headers | 不显示标题列 |
-L <进程pid> | 查看指定进程中的线程信息 |
F | 内核分配给进程的系统标记 |
S | 进程的状态 |
UID | 启动这些进程的用户 |
PID | 进程的进程ID |
PPID | 父进程的进程号(如果该进程是由另一个进程启动的) |
C | 进程生命周期中的CPU利用率 |
PRI | 进程的优先级(越大的数字代表越低的优先级) |
NI | 谦让度值用来参与决定优先级 |
ADDR | 进程的内存地址 |
SZ | 假如进程被换出,所需交换空间的大致大小 |
WCHAN | 若该进程在睡眠,则显示睡眠中的系统函数名 |
STIME | 进程启动时的系统时间 |
TTY | 进程启动时的终端设备 |
TIME | 运行进程需要的累计CPU时间 |
CMD | 进程的启动命令 |
ps aux --sort -%cpu 按cpu降序排列,-为降序,+为升序,p与%同义
ps aux --sort +pmem 按内存升序排列
- tty终端
Centos7系统,tty1表示图形界面,tty2-tty6表示文字界面,可以用Ctrl+Alt+F1-F6切换
pts说明是用远程工具连接的,比如xshell,后面的数字代表登录的时间顺序,越小证明登录的越早
-
top命令
查看动态的进程统计信息
top
第一行 任务队列信息 | ||||||||
18:40:25 | 系统时间 | |||||||
up 16 | 系统已运行时长 | |||||||
2 users | 当前登录用户数 | |||||||
load average: 0.04, 0.03, 0.05 | 系统负载,即单位时间内系统处理的任务数,后面三个数值分别为1分钟、5分钟、15分钟前到现在的平均值 | |||||||
第二行 进程信息 | ||||||||
Tasks | 总进程数 | |||||||
running | 正在运行的进程数 | |||||||
sleeping | 休眠的进程数 | |||||||
stopped | 中止的进程数 | |||||||
zombie | 僵死的进程数 | |||||||
第三行 CPU信息 | ||||||||
us | 用户占用 | |||||||
sy | 内核占用 | |||||||
ni | 优先级调度占用 | |||||||
id | 空闲CPU,要了解空闲的 CPU 百分比,主要看%id 部分 | |||||||
wa | I/O 等待占用 | |||||||
hi | 硬件中断占用 | |||||||
si | 软件中断占用 | |||||||
st | 虚拟化占用 | |||||||
第四行 内存的信息 | ||||||||
total | 总内存空间 | |||||||
free | 空闲内存 | |||||||
used | 已用内存 | |||||||
buff/cache | 物理内存和交换内存的缓冲区总和 | |||||||
第五行 交换空间的信息 | ||||||||
total | 总交换空间 | |||||||
free | 空闲交换空间 | |||||||
used | 已用交换空间 | |||||||
avail Mem | 可用物理空间 | |||||||
进程信息区 | ||||||||
PID | 进程id | |||||||
USER | 进程所有者的用户名 | |||||||
PR | 优先级 | |||||||
NI | 谦让度值。负值表示高优先级,正值表示低优先级 | |||||||
VIRT | 进程使用的虚拟内存总量,单位kb | |||||||
RES | 进程使用的物理内存大小,单位kb | |||||||
SHR | 共享内存大小,单位kb | |||||||
S | 进程状态 | |||||||
%CPU | 上次更新到现在的CPU时间占用百分比 | |||||||
%MEM | 进程使用的物理内存百分比 | |||||||
TIME+ | 进程使用的CPU时间总计,单位1/100秒 | |||||||
COMMAND | 命令名/命令行 |
- load average
当平均负载长时间高于CPU数量的70%时,load average 的值可认为是异常的
load average 平均负载高时可能是CPU密集型进程多导致,也可能是I/O繁忙导致
查看 load average 的命令
top
w
uptime
- CPU使用率和CPU负载:
CPU使用率是指CPU在某个时间段内被使用的比例,以百分比表示。反映了CPU的使用强度
CPU负载是指CPU正在处理的任务数或等待CPU处理的任务数。反映了系统中的任务繁忙程度
- 常用命令
P 键 | 根据CPU使用百分比大小进行排序 |
M 键 | 根据驻留内存大小进行排序 |
N 键 | 根据启动时间进行排序 |
c 键 | 切换显示命令名称和完整命令行 |
h 键 | 可以获得 top程序的在线帮助信息 |
k 键 | 根据提示输入指定进程的 PID 号并按 Enter 键终止对应的进程 |
q 键 | 退出 top 程序 |
数字1 键 | 显示CPU个数和状态 |
top -H | 显示所有线程 |
top -H -p <pid> | 显示特定进程中的线程 |
- 查看系统指标
CPU
top
vmstat
sar
htop
atop
内存
free -m
vmstat
sar
top
cat /proc/meninfo
IO
iostat(磁盘级别)
iotop(进程级别)
vmstat(系统级别)
atop
sar
磁盘容量
df -h
du
进程
ps
top
htop
atop
pidstat
网卡流量
ifconfig
iftop
atop
cat /proc/net/dev
-
pgrep命令
根据特定条件查询进程PID信息
pgrep -l <关键词> -U <用户名> -t <终端>
pgrep -l "log" (-l显示进程名,缺省时只输出PID号)
pgrep -l -U teacher -t tty2 (-U指定特定用户,-t指定终端)
三、查看进程树
- pstree命令
以树形结构列出进程信息
pstree -aup (-a:显示完整信息;-u:列出对应用户名;-p:列出对应PID号)
pstree -ap 用户名 只查看属于指定用户的进程树结构
四、进程的启动方式
-
手工启动
前台启动:用户输入命令,直接执行程序
后台启动:
在命令行尾加入“&”符号,默认情况下通过追加 & 后台运行的进程会随着终端的关闭而自动退出
可在命令开头位置添加 nohup(格式为nohup 命令 &),可实现后台运行的进程不会随着终端的关闭而自动退出
-
调度启动
使用at命令,设置一次性计划任务
使用crontab命令,设置周期性计划任务
五、进程的前后台调度
-
Ctrl+Z组合键
将当前进程挂起,即调入后台并停止执行
-
jobs命令
jobs [-l]
查看处于后台的任务列表
-
fg命令
将后台进程恢复到前台运行,可指定任务序号
fg 序号
六、终止进程的运行
-
Ctrl+c组合键
中断正在执行的命令
-
kill、killall命令
kill用于终止指定PID号的进程
killall用于终止指定名称相关的所有进程
-9选项用于强制终止
kill <PID>
killall <进程名>
- 小知识
- kill是向进程发送信号的方式杀掉进程
- kill 默认选项为 -15 ,发送信号 SIGTERM,表示告诉进程自行停止运行并退出,进程可以忽略
- kill -9 ,发送信号 SIGKILL,表示进程要立即退出,且不能被捕捉或忽略
- kill -3 ,发送信号 SIGQUIT,表示进程自行退出,并打印进程各个线程的堆栈信息,保存路径为 /proc/${pid}/cwd,文件名为 antBuilderOutput.log
- kill -1 ,发送信号 SIGHUP,表示进程重新加载配置文件,不退出
-
pkill命令
根据特定条件终止相应的进程
常用命令选项
-U | 根据进程所属的用户名终止相应进程 |
-t | 根据进程所在的中断终止相应进程 |
pkill <关键词> -U <用户名> -t <终端>
七、计划任务管理
-
at命令
一次性计划任务
at [HH:MMM] [yyyy-mm-dd]
Ctrl键+D提交任务
atq 查看未执行的任务列表
atrm 序号 删除指定的任务
-
crontab命令
- 按照预先设置的时间周期(分钟、小时、天、月、周)重复执行用户指定的命令操作
- 属于周期性计划任务
- 主要设置文件
全局配置文件,位于文件:/etc/crontab
系统默认的设置,位于目录:/etc/cron.*/
用户定义的设置,位于文件:/var/spool/cron/用户名
- 管理crontab计划任务
编辑计划任务
crontab -e -u 用户名
查看计划任务
crontab -l -u 用户名
删除计划任务
crontab -r -u 用户名
- crontab任务配置的格式
分钟 | 小时 | 日期 | 月份 | 星期 | 命令或脚本文件 |
0~59 | 0~23 | 1~31 | 1~12 | 0~7 | 需要执行的命令 |
时间数值的特殊表达方法
* | 表示该范围内的任意时间 |
, | 表达间隔的多个不连续时间点 |
- | 表达一个连续的时间范围 |
/ | 指定间隔的时间频率 |
- 例
11月12号 上午8点到10点的第三十分钟
30 8-10 12 11 *
每个月的8号 9点半
30 9 8 * *
每个月每隔五天的晚上八点一刻
15 20 */5 * *
每个月每隔5天的早上八点和晚上八点每隔5分钟
*/5 8,20 */5 * *
每隔两个月的工作日的朝九晚五期间的第30分钟执行
30 9-17 * */2 1-5