进程与任务
linux系统中的进程就相当于Windows的任务管理器,只是区别于任务管理器的是进程需要用命令来管理的。
程序
1、保存在硬盘、光盘等介质中的可执行代码和数据
2、静态保存的代码
进程
1、在cpu及内存中运行的程序代码
2、动态执行的代码
3、父、子进程:每个程序可以创建一个或多个进程
PS:查看进程信息
ps -aux
-a:显示当前终端下的所有进程信息,包括其他用户的进程。与“x”选项结合时将显示系统中所有的进程信息
-u:使用以用户为主的格式输出进程信息
-x:显示当前用户在所有终端下的即可拿出信息
ps -aux:以简单列表的形式显示出进程信息
USER:进程的用户
PID:进程的ID
%CPU:进程占用的CPU百分比
%MEM:占用内存的百分比
VSZ:该进程使用的虚拟内存量
RSS:该进程占用的物理内存量
TTY:启动进程的终端进程名。不是从终端启动的进程则显示为?
START:该进程被触发启动时间
TIME:该进程实际使用CPU运行的时间
COMMAND:进程的启动命令
STAT:该进程的状态
D:系统守护进程
T:调试、程序执行一般停止
R:该进程目前正在运作,或者是可被运作
S:该程序目前正在睡眠当中(或是idle状态)但是可被某些讯号唤醒
T:该进程目前正在侦测或者停止
Z:该程序应该已经停止,但是其父程序却无法正常的终止他,造成zombie(僵尸)程序的状态D不可被中断状态
它们的含义如下:
<:表示进程运行在高优先级上
N:表示进程运行在低优先级上
L:表示进程有页面有锁定在内存里
s:表示进程是控制进程s
l:表示进程是多线程的
+:表示当前线程运行在前台
D:系统守护进程
T:调试、程序执行一般停止
ps -elf
ps -elf以长格式显示系统中的信息
-e:显示系统内的所有进程
-l:使用长格式显示进程信息
-f:使用完整的格式显示进程信息
F:内核分配给进程的系统标记
S:进程的状态
UID:启动这些进程的用户
PID:进程的进程ID
PPID:父进程的进程号(如果该进程是由另一个进程启动的)
C:进程生命周期中的CPU利用率
PRI:进程的优先级(越大的数字代表越低的优先级)
NI:谦让度值用来参与决定优先级
ADDR:进程的内存地址
SZ:假如进程被换出,所需交换空间的大致大小
WCHAN:若该进程在睡眠,则显示睡眠中的系统函数名
STIME:进程启动时的系统时间
TTY:进程启动时的终端设备
TIME:运行进程需要的累计CPU时间
CMD:进程的启动命令
僵尸进程:
一个进程结束了,但是如果该进程的父进程已经先结束了,那么该进程就不会变成僵尸进程,因为每个进程结束的时候,系统都会扫描当前系统中所运行的所有进程,看有没有哪个进程是刚刚结束的这个进程的子进程,如果是的话,就由Init来接管它,成为它的父进程,子进程退出后init会回收其占用的相关资源。但是当子进程比父进程先结束,而父进程又没有回收子进程,释放子进程占用的资源,此时子进程将成为一个僵尸进程。
进程状态:
-D: 不可被唤醒的睡眠状态,通常用于I/o情况。
-R:该进程正在运行。
-S:该进程处于睡眠状态,可被唤醒。
-T:停止状态,可能是在后台暂停或进程处于除错状态。
-W:内存交互状态(从2.6内核开始无效)。
-X:死掉的进程(应该不会出现)。
-Z:僵尸进程。进程已经中止,但是部分程序还在内存当中。
-<:高优先级(以下状态在BSD格式中出现)。
-N:低优先级。
-L:被锁入内存。
-s:包含子进程。
-l:多线程(小写L)。
-+:位于后台。
-C:进程占用CPU的百分比
top
top 命令是 Linux 下常用的性能分析工具,能够实时显示系统中各个进程的资源占用状况,常用于服务端性能分析。
在 top 命令中按 f,可以修改显示的列,按对应字母来开启/关闭列,大写字母表示开启,小写字母表示关闭。带 * 号的是默认列。
Linux 中的 top 命令就像是 Windows 中的任务管理器。它会以列表的形式展示出系统的当前状态以及进程信息,并且定时刷新,同时也支持一些交互性的操作。
第一行
top – 16:59:23 #当前系统时间
Up 1 min #系统已经运行时间
2 users #当前登录用户
Load average 0.00 0.01 0.05#系统平均负载,后面三个数字代表每1分钟,5分钟,15分钟的平均负载
第二行
Tasks: 214 total 进程总数
1 running 正在运行的进程数
213 sleeping 睡眠的进程数
0 stopped 睡眠的进程数
0 zombie 僵尸进程数
第三行
0.2 us 用户空间占用CPU百分比 查看CPU使用率
0.2 sy 内核空间占用CPU百分比
0.0 ni 用户进程空间内改变过优先级的进程占用CPU百分比
99.7 id 空闲CPU百分比
0.0 wa 等待输入输出的CPU时间百分比
0.0 hi 硬中断消耗时间 硬中断占用
0.0 si 软中断消耗时间 软中断占用
0.0 st 虚拟化占用
第四行
3861516total 物理内存总量
2263364 free 空闲内存总量
725224used 已使用的物理内存总量
872928 buff/cache用作内核缓存的内存量
第五行
3907580 total 交换区总量
3907580 free 空闲交换区总量
0 used 已使用的交换区总量
2784816 avail Mem 缓冲的交换区总量
PID:进程id
USER:进程所有者的用户名
PR:优先级
NI:谦让度值。负值表示高优先级,正值表示低优先级
VIRT:进程使用的虚拟内存总量,单位kb
RES:进程使用的物理内存大小,单位kb
SHR:共享内存大小,单位kb
S:进程状态
%CPU:上次更新到现在的CPU时间占用百分比
%MEM:进程使用的物理内存百分比
TIME+:进程使用的CPU时间总计,单位1/100秒
COMMAND :命令名/命令行
交互命令
在top命令执行过程中可以使用的一些交互命令。这些命令都是单字母的,如果在命令行中使用了-s选项, 其中一些命令可能会被屏蔽。
P 键:根据CPU使用百分比大小进行排序
M 键:根据驻留内存大小进行排序
N 键:根据启动时间进行排序
c 键:切换显示命令名称和完整命令行
h 键:可以获得 top程序的在线帮助信息
k 键:根据提示输入指定进程的 PID 号并按 Enter 键终止对应的进程
数字1 键:显示CPU个数和状态
q 键:退出 top 程序
pgrep
根据特定条件查询进程PID信息(grep的进化版)
-l:选项可同时输出对应的进程名以及PID
-u:选项查询特定用户的进程
-t:选项查询在特定终端运行的进程
pstree
-a:显示完整信息
-u:列出对应用户名
-p:列出对应的PID号
以树形结构列出进程信息
进程的启动方式
手工启动
前台启动:用户输入命令,直接执行程序
后台启动:在命令行尾加入"&"符号
调度启动
使用at命令,设置一次性计划任务
使用crontab命令,设置周期性计划任务
进程的前后台调度
Ctrl + Z组合键:将当前进程挂起,即调入后台并停止执行
jobs命令:查看处于后台的任务列表
fg命令:将后台进程恢复到前台运行,可指定任务序号
bg和fg的区别
bg 1(jobs查到的号码这里是1或者2)是将放入后台的程序继续执行,但不会显示到前台。
fg 1 将放入后台的程序直接切换到前台执行。
“&”
Linux 终端命令的末尾加上一个 &表示将这个任务放到后台去执行,不用等待命令结束,直接执行下一条命令
终止进程的运行
Ctrl + C:中断正在执行的命令
kill、killall命令
kill用于终止指定PID号的进程
killall用于终止指定名称的所有进程
-9选项用于强制终止
kill最常用的信号是:
1 (HUP):重新加载进程。
9 (KILL):杀死一个进程。
15 (TERM):正常停止一个进程。
kill值默认15
kill -3 杀死并退出进程
kill -9不正规,直接杀进程 kill -3是友好的杀死进程
kill -19和ctrl+z差不多 ,挂起并停止执行
pkill命令
根据特定条件终止相应的进程
常用命令选项
- -U:根据进程所属的用户名终止相应进程
- -t:根据进程所在的终端终止相应进程
- -l:选项可同时输出对应的进程名以及PID
计划任务管理
at
一次性计划任务
at [HH:MM] [yyyy-mm-dd]
任务设置完毕后按Ctrl + D提交
crontab
按照预先设置的时间周期(分、时、日、月、周)重复执行用户指定的命令操作
属于周期性计划任务
主要设置文件:
①全局配置文件,位于文件:/etc/crontab
②系统默认的设置,位于目录:/etc/cron.*/
③用户定义的设置,位于文件:/var/spool/cron/用户名
crontab -e 【-u 用户名】 编辑计划任务
crontab -l 【-u 用户名】 查看计划任务
crontab -r 【-u 用户名】删除计划任务
字 段 | 分钟 | 小时 | 日期 | 月份 | 星期 | 命令 |
范 围 | 0~59 | 0~23 | 1~31 | 1~12 | 0~7(0或7都表示周日) | 需要执行的任务 |
其中时间的特殊表示方法:
* 表示该范围内的任意时间
, 表示间隔的多个不连续时间点
- 表示一个连续的时间范围
/ 表示间隔的时间频率
例如:
0 20 * * 1-5 周一到周五每天20点
30 8 * * 1,3,5 周一,周三,周五8.30
0 8-18 */2 * * 8点到18点每两小时
0 * */3 * * 每三天
* 8-10 * * 1,3,5 周一,周三,周五的8点到10点