目录
一、程序和进程的关系
1、程序
保存在硬盘、光盘等介质中的可执行代码和数据
文件中静态保存的代码
2、进程
在cpu及内存中运行的程序代码
动态执行的代码
父、子进程
每个程序可以创建一个或多个进程
3、线程和进程的关系
线程 :程序执行的最小单位
线程 是CPU调度的最小单位(程序执行流的最小单元),它被包含在进程之中,是进程中的实际运作单元。
一条线程是进程中一个单一顺序的控制流,一个进程中可以并发多个线程,每条线程并行执行不同的任务
一个线程挂掉会影响其他线程,而进程之间是互相隔离的,互不影响
进程:资源分配的最小单位
进程 是程序执行时的一个实例,即它是程序已经执行到课中程度的数据结构的汇集。
从内核的观点看,进程的目的就是担当分配系统资源(CPU时间、内存等)的基本单位
二、查看进程信息
ps命令 查看静态的进程统计信息
1、ps aux命令
ps aux #基本格式(aux前面可不加——)
ps aux | wc -l #结合管道符号查询具体的数量(需要-1)
a:显示终端上的所有进程,包括其他用户的进程
u:表示列出进程的用户
x:显示所有终端的进程
显示进程的信息
各列名词解释
USER | 进程的用户 |
PID | 进程的ID |
%CPU | 进程占用的CPU百分比 |
%MEM | 占用内存的百分比 |
VSZ | 该进程使用的虚拟内存量(KB) |
RSS | 该进程占用的物理内存量(KB) |
TTY | 启动进程的终端名。不是从终端启动的进程则显示为 ? |
STAT | 该行程的状态: D:不可中断的休眠状态 R:正在运行状态 S:处于休眠状态,可被唤醒 T:停止状态,可能是在后台暂停或进程处于跟踪 调试状态 Z:僵尸进程,进程已经中止,但是部分程序还在内存当中 w:进入内存交换(从内核2.6开始无效) X,死掉的进程;< 高优先级 N 低优先级 L 有些页被锁进内存 s 包含子进程 + 位于后台的进程组 l 多线程,克隆线程 |
START | 该进程被触发启动时间 |
TIME | 该进程实际使用CPU运行的时间 |
COMMAND | 进程的启动命令 |
2、ps -elf命令
-e:显示系统内的所有进程信息
-l:使用长格式显示进程信息
-f:使用完整的格式显示进程信息
常用选项
-e | 显示系统内的所有进程信息 |
-l | 使用长格式显示进程信息 |
-f | 使用完整的格式显示进程信息 |
-a | 显示所有进程PID |
-T | 查看线程信息 |
ps -aT | 显示所有线程 |
各列名词解释
F | 内核分配给进程的系统标记 |
S | 进程的状态 |
UID | 启动这些进程的用户 |
PID | 进程的进程ID |
PPID | 父进程的进程号(如果该进程是由另一个进程启动的) |
C | 进程生命周期中的CPU利用率 |
PRI | 进程的优先级(越大的数字代表越低的优先级) |
NI | 谦让度值用来参与决定优先级 |
ADDR | 进程的内存地址 |
SZ | 假如进程被换出,所需交换空间的大致大小 |
WCHAN | 若该进程在睡眠,则显示睡眠中的系统函数名 |
STIME | 进程启动时的系统时间 |
TTY | 进程启动时的终端设备 |
TIME | 运行进程需要的累计CPU时间 |
CMD | 进程的启动命令 |
三、查看进程信息top
top #查看动态进程信息
每行对应信息
第一行是任务队列信息
1. 14:25:23 系统时间
2. up 1:14 系统已运行时长
3. 1 user 当前登录用户数
4. load average: 0.00, 0.01, 0.05 :系统负载,即单位时间内系统处理的任务数,后面三个数值分别为1分钟、5分钟、15分钟前到现在的平均值
第二行为进程信息
1. Tasks 总进程数
2. running 正在运行的进程数
3. sleeping 休眠的进程数
4. stopped 中止的进程数
5. zombie 僵死的进程数
第三行为CPU的信息
1. us 用户占用
2. sy 内核占用
3. ni 优先级调度占用
4. id 空闲CPU,要了解空闲的 CPU 百分比,主要看%id 部分
5. wa I/O 等待占用
6. hi 硬件中断占用
7. si 软件中断占用
8. st 虚拟化占用
第四行为内存的信息
1. total 总内存空间
2. free 空闲内存
3. used 已用内存
4. buff/cache 物理内存和交换内存的缓冲区总和
第五行为交换空间的信息
1. total 总交换空间
2. free 空闲交换空间
3. used 已用交换空间
4. avail Mem 可用物理空间
进程信息区各列解释
PID | 进程id |
USER | 进程所有者的用户名 |
PR | 优先级 |
NI | 谦让度值。负值表示高优先级,正值表示低优先级 |
VIRT | 进程使用的虚拟内存总量,单位kb |
RES | 进程使用的物理内存大小,单位kb |
SHR | 共享内存大小,单位kb |
S | 进程状态 |
%CPU | 上次更新到现在的CPU时间占用百分比 |
%MEM | 进程使用的物理内存百分比 |
TIME+ | 进程使用的CPU时间总计,单位1/100秒 |
COMMAND | 命令名/命令行 |
top常用命令
P 键 | 根据CPU使用百分比大小进行排序 |
M 键 | 根据驻留内存大小进行排序 |
N 键 | 根据启动时间进行排序 |
c 键 | 切换显示命令名称和完整命令行 |
h 键 | 可以获得 top程序的在线帮助信息 |
k 键 | 根据提示输入指定进程的 PID 号并按 Enter 键终止对应的进程 |
q 键 | 退出 top 程序 |
数字1 键 | 显示CPU个数和状态 |
tty终端
Centos 7系统,tty1表示图形界面,tty2-tty6表示文字界面,可以用Ctrl+Alt+F1-F6切换
pts说明是用远程工具连接的,比如Xshell。后面的数字代表登陆的时间顺序,越小证明登陆的越早
查看线程 top -H;ps -T
top -H -p :显示特定进程中的线程
四、查看进程信息pgrep
pgrep命令
根据特定条件查询进程PID信息
● pgrep -l "进程关键字" #指定查看进程名
常用选项
-l | 显示进程名 |
-U | 指定特定用户 |
-t | 指定终端 |
● pgrep -l "进程关键字" -U 指定特定用户
● pgrep -l "进程关键字" -t 指定终端 使用较少
五、查看进程树pstree
pstree命令
以树形结构列出进程信息
● pstree -aup 用户名 #以树形结构完整列出对应用户名及进程号
-a:显示完整信息
-u:列出对应用户名
-p:列出对应PID号
六、进程的启动方式
1、手工启动
前台启动:用户输入命令,直接执行程序
cp /data/fileK /opt
后台启动:在命令行尾加入“&”符号
cp /data/fileK /opt &
2、调度启动
使用at命令,设置一次性计划任务
使用crontab命令,设置周期性计划任务
七、进程的前后台调度
1、Ctrl + z组合键
2、jobs命令
jobs -l
查看处于后台的任务列表
3、fg命令
将后台进程恢复到前台运行,可指定任务序号
八、终止进程的运行
1、Ctrl + c 组合键
中断正在执行的命令
2、Kill、Killall命令
kill用于终止指定PID号的进程
killall用于终止指定名称相关的所有进程
-9选项用于强制终止 (可能导致数据丢失,不建议使用)
九、计划任务管理
1、at命令
一次性计划任务
at [HH:MM] [yyyy-mm-dd] #指定时间设置任务(不加年月日表示当天)ctrl+D退出
atq #查看未执行的任务列表
atrm [任务序号] #删除第一条任务
2、crontab命令
按照预先设置的时间周期(分、时、日、月、周)重复执行用户指定的命令操作
属于周期性计划任务
1)管理crontab计划任务
编辑计划任务
crontab -e 【-u 用户名】 -u缺省时默认当前用户
查看计划任务
crontab -l 【-u 用户名】
删除计划任务
crontab -r 【-u 用户名】
2)crontab任务配置的格式
代表含义 | 分钟 | 小时 | 日期 | 月份 | 周 | 命令 |
数字范围 | 0~59 | 0~23 | 1~31 | 1~12 | 0~7 | 需要执行的命令 |
周的数字为0 或 7 时,都代表“星期天”
* 表示该范围内的任意时间
, 表示间隔的多个不连续时间点
- 表示一个连续的时间范围
/ 表示间隔的时间频率