Linux中进程和计划任务管理
一、进程概述
程序和进程的关系
程序
(1)保存在硬盘、光盘等介质中的可执行代码和数据
(2)文件中静态保存的代码
进程
(1)在CPU及内存中运行的程序代码
(2)动态执行的代码
(3)父、子进程
(4)每个程序可以创建一个或多个进程
线程
线程是进程中的一个实体,作为系统调度和分派的基本单位
进程与线程的区别
进程是操作系统资源分配的基本单位,而线程是任务调度和执行的基本单位
二、查看进程信息的命令
1.查看静态的进程统计信息—ps命令
方法一
ps aux
a:显示终端bai上的所有进程,包括其它用户的进程。
u:表示列出进程的用户。
x:显示所有终端的进程。
演示
各列参数解释
参数 | 说明 |
---|---|
USER | 进程的用户 |
PID | 进程的ID |
%CPU | 进程占用的CPU百分比 |
%MEM | 占用内存的百分比。 |
VSZ | 该进程使用的虚拟内存量(KB) |
RSS | 该进程占用的物理内存量(KB) |
TTY | 启动进程的终端名。不是从终端启动的进程则显示为 ? |
STAT | 该行程的状态 |
START | 该进程被触发启动时间 |
TIME | 该进程实际使用CPU运行的时间 |
COMMAND | *进程的启动命令 |
行程的状态分为
D:不可中断的休眠状态;
R:正在运行状态;
S:休眠状态,可被唤醒;
T:停止状态,可能是在后台暂停或进程处于跟踪调试状态;
Z:僵尸进程,进程已经中止,但是部分程序还在内存中
补充概念
(1)僵尸进程:一个进程结束了,但是如果该进程的父进程已经先结束了,那么该进程就不会变成僵尸进程,因为每个进程结束的时候,系统都会扫描当前系统中所运行的所有进程,看有没有哪个进程是刚刚结束的这个进程的子进程,如果是的话,就由Init来接管它,成为它的父进程,子进程退出后init会回收其占用的相关资源。但是当子进程比父进程先结束,而父进程又没有回收子进程,释放子进程占用的资源,此时子进程将成为一个僵尸进程。
(2)tty终端:Centos7系统,tty1表示图形界面,tty2-tty6表示文字界面,可以用Ctrl+Alt+F1-F6切换。
(3)pts说明是用远程工具连接的,比如xshell,后面的数字代表登录的时间顺序,越小证明登录的越早
方法二
ps -elf
-e:显示系统内的所有进程信息。
-l:使用长格式显示进程信息。
-f:使用完整的格式显示进程信息。
演示
各列参数解释
参数 | 说明 |
---|---|
F | 内核分配给进程的系统标记 |
S | 进程的状态 |
UID | 启动这些进程的用户 |
PID | 进程的进程ID |
PPID | 父进程的进程号(如果该进程是由另一个进程启动的) |
C | 进程生命周期中的CPU利用率 |
PRI | 进程的优先级(越大的数字代表越低的优先级) |
NI | 谦让度值用来参与决定优先级 |
ADDR | 进程的内存地址 |
SZ | 假如进程被换出,所需交换空间的大致大小 |
WCHAN | 若该进程在睡眠,则显示睡眠中的系统函数名 |
STIME | 进程启动时的系统时间 |
TTY | 进程启动时的终端设备 |
TIME | 运行进程需要的累计CPU时间 |
CMD | 进程的启动命令 |
2.查看动态的进程排名信息—top命令
top
top常用命令
命令 | 说明 |
---|---|
P 键 | 根据CPU使用百分比大小进行排序 |
M 键 | 根据驻留内存大小进行排序 |
N 键 | 根据启动时间进行排序 |
c 键 | 切换显示命令名称和完整命令行 |
h 键 | 可以获得 top程序的在线帮助信息 |
k 键 | 根据提示输入指定进程的 PID 号并按 Enter 键终止对应的进程 |
q 键 | 退出 top 程序 |
数字1 键 | 显示CPU个数和状态(前提是有多个CPU) |
实例
每行字段说明
行数 | 说明 |
---|---|
第一行是任务队列信息 | 14:15:51 ----系统时间;up 3:37----系统已运行时长;3 user----当前登录用户数;load average: 0.06,0.04, 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 | 命令名/命令行 |
3.查看进程信息—pgrep命令
gprep根据特定条件查询进程PID信息(常用)
-l -显示进程名(后面必须跟参数,最好带上,不然只显示进程号)
-U -指定特定用户
-t -指定终端
演示
4.查看进程树—pstree
以树形结构列出进程信息
pstree
演示
pstree -aup
-a -显示完整信息
-u -列出对应用户名
-p -列出对应PID号
演示
三、进程启动调度终止
1.进程的启动方式
(1)手动启动
前台启动:用户输入命令,直接执行程序
后台启动:在命令行尾加入“&”符号
演示
(2)调度启动
使用at命令,设置一次性计划任务
使用crontab命令,设置周期性计划任务
2.进程的前后台调度
按键或命令 | 说明 |
---|---|
Ctrl+Z组合键 | 将当前进程挂起,即调入后台并停止执行 |
jobs命令 | 查看处于后台的任务列表,jobs -l(加上-l显示进程号,某些命令需要进程号) |
fg命令 | 将后台进程恢复到前台运行,可指定任务序号 |
演示
终止进程的运行
按键或命令 | 说明 |
---|---|
Ctrl+C组合键 | 中断正在执行的命令 |
kill命令 | kill用于终止指定PID号的进程(可以加上-9选项强制终止) |
killall命令 | killall用于终止指定名称相关的所有进程(可以加上-9选项强制终止) |
pkill命令 | 作用:根据特定条件终止相应的进程,常用命令选项:-U:根据进程所属的用户名终止相应进程;-t:根据进程所在的终端终止相应程序 |
kill演示
pkill演示
四、计划任务管理
1.at命令(一次性计划任务)
格式:at [HH:MM] [yyyy-mm-dd] -如果后面不跟年月日,那么默认使用当前日期
建立任务格式对应: at [小时:分钟] [年-月-日]
查看任务命令:atq
删除任务:atrm 任务编号
演示
2.crontab命令(周期性计划任务)
概念:按照预先设置的时间周期(分、时、日、月、周)重复执行用户指定的命令操作,是一种周期性计划任务。
主要设置文件
全局配置文件,位于文件:/etc/crontab
系统默认的设置,位于目录:/etc/cron.*/
用户定义的设置,位于文件:/var/spool/cron/用户名
管理crontab计划任务
编辑计划任务:crontab -e [-u 用户名] - -u默认的是当前用户
查看计划任务:crontab -l [-u 用户名]
删除计划任务:crontab -r [-u 用户名]
crontab任务配置的格式
字段 | 说明 |
---|---|
分钟 | 0~59 |
小时 | 0~23 |
日期 | 1~31 |
月份 | 1~12 |
星期 | 0~7 |
命令 | 执行的命令或脚本 |
注:星期中0和7都代表星期天
时间数值的特殊表示方法
符号 | 说明 |
---|---|
* | 表示这个字段的范围内任意的时间 |
, | 表示间隔的多个不连续时间点 |
- | 表示一个连续的时间范围 |
/ | 指定间隔的时间频率 |
举例
1月和8月的每周五 10-17时每十分钟执行 ls -l 命令
*/10 10-17 * 1,8 5 /usr/bin/ls -l
设置周期性任务的方法二
每个星期6的8点30重启httpd服务
echo '30 8 * * 6 /usr/bin/systemctl httpd restart' >> /var/spool/cron/root