进程和计划任务管理
结构
查看进程
控制进程
at一次性任务设置
crontab周期性任务设置
程序和进程的关系
程序
- 保存在硬盘、光盘等介质中的可执行代码和数据
- 文件中静态保存的代码
进程
- 在CPU及内存中运行的程序代码
- 动态执行的代码
- 父、子进程
- 每个程序可以创建一个或多个进程
注意进程和线程的区别
进程:指在系统中正在运行的一个应用程序;程序一旦运行就是进程。进程——资源分配的最小单位。
线程:系统分配处理器时间资源的基本单元,或者说进程之内独立执行的一个单元执行流。线程——程序执行的最小单位。
ps命令查看静态的进程统计信息
方法一
ps aux
a: 显示终端上的所有进程,包括其它用户的进程。
u: 表示列出进程的用户。
x: 显示所有终端的进程。
各列的解释:
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: 显示所有进程pid.
-T: 查看线程信息。
ps -aT 显示所有线程
各列的解释:
F | 内核分配给进程的系统标记 |
S | 进程的状态 |
UID | 启动这些进程的用户 |
PID | 进程的进程ID |
PPID | 父进程的进程号(如果该进程是由另一个进程启动的) |
C | 进程生命周期中的CPU利用率 |
PRI | 进程的优先级(越大的数字代表越低的优先级) |
NI | 谦让度值用来参与决定优先级 |
ADDR | 进程的内存地址 |
SZ | 假如进程被换出,所需交换空间的大致大小 |
WCHAN | 若该进程在睡眠,则显示睡眠中的系统函数名 |
STIME | 进程启动时的系统时间 |
TTY | 进程启动时的终端设备 |
TIME | 运行进程需要的累计CPU时间 |
CMD | 进程的启动命令 |
top命令:查看进程动态信息
第一行是任务队列信息
23:39:46 系统时间
up 4 min 系统已运行时长
2 user 当前登录用户数
load average: 0.04, 0.18, 0.10
系统负载,即单位时间内系统处理的任务数,后面三个数值分别为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 | 命令名/命令行 |
top常用命令:
P键: 根据CPU使用百分比大小进行排序
M键: 根据驻留内存大小进行排序
N键: 根据启动时间进行排序
c键: 切换显示命令名称和完整命令行
h键: 可以获得top程序的在线帮助信息
k键: 根据提示输入指定进程的PID号并按Enter键终止对应的进程
q键: 退出top程序
数字1键: 显示CPU个数和状态
top -H: 显示所有线程
top -H -p <pid>: 显示特定进程中的线程
查看进程信息pgrep
pgrep命令
根据特定条件查询进程PID信息
示例:
-
-l:显示进程名,缺省时只会显示PID号
-
-U:指定特定用户
-
-t:指定终端
tty终端
- Centos7系统, tty1表示图形界面, tty2-tty6表示文字界面,可以用Ctrl+Alt+F1-F6切换。
- pts说明是用远程工具连接的,比如xshell,后面的数字代表登录的时间顺序,越小证明登录的越早
- Ctrl+Alt+F1 切换为图形界面
查看进程树pstree
pstree命令
以树形结构列出进程信息
示例:
- -a:显示完整信息
- -u:列出对应用户名
- -p:列出对应PID号
- 只查看属于特定用户的进程树结构
进程的启动方式
手工启动
- 前台启动:用户输入命令,直接执行程序
- 后台启动:在命令行尾加入"&"符号
示例:
[root@localhost ~]# cp /dev/cdrom mycd.iso &
[1] 28454
- 输出信息中包括后台任务序号、PID号
调度启动
- 使用at命令,设置一次性计划任务
- 使用crontab命令,设置周期性计划任务
进程的前后台调度
Ctrl+Z组合键
- 将当前进程挂起,即调入后台并停止执行
jobs命令
- jobs [-l]
- 查看处于后台的任务列表
fg命令
- 将后台进程恢复到前台运行,可指定任务序号
示例:
[root@localhost ~]# jobs [1]- Stopped cp /dev/cdrom mycd.iso [2]+ Stopped top [root@localhost ~]# fg 1
终止进程的运行
Ctrl+C组合键
- 中断正在执行的命令
kill, killall命令
- kill 于终止指定PID号的进程
- killall用于终止指定名称相关的所有进程
- -9选项用于强制终止
pkill命令
- 根据特定条件终止相应的进程
常用命令选项
- -U: 根据进程所属的用户名终止相应进程
- -t: 根据进程所在的终端终止相应进程
示例:
[root@localhost ~]# pgrep -l -U "teacher" 3045 bash [root@localhost ~]# pkill -9 -U " teacher" [root@localhost ~]# pgrep -l -U "teacher"
计划任务管理at
at命令
- 一次性计划任务
格式:
at [HH:MM] [yyyy-mm-dd]
示例:
- 不携带日期表示为当天
- Ctrl+D提交任务
- atq查看未执行任务列表
- atrm删除列表中对应序号的任务
计划任务管理crontab
crontab命令
按照预先设置的时间周期(分钟、小时、天、月、周)重复执行用户指定的命令操作
属于周期性计划任务
主要设置文件
- 全局配置文件,位于文件: /etc/crontab
- 系统默认的设置,于目录: /etc/cron.*/
- 用户定义的设置,位于文件: /var/spool/cron/用户名
管理crontab计划任务
- 编辑计划任务
crontab -e [-u 用户名] #-u缺省时默认是针对当前用户
- 查看计划任务
crontab -l [-u 用户名]
- 删除计划任务
crontab -r [-u 用户名]
crontab任务配置的格式
* * * * * run_command
前五个字段分别表示分钟、小时、日期、月份、星期,后跟命令或脚本。
注意:命令或脚本需要用绝对路径来指定
字段 | 说明 |
分钟 | 取值为从0到59之间的任意整数 |
小时 | 取值为从0到23之间的任意整数 |
日期 | 取值为从1到31之间的任意整数 |
月份 | 取值为从1到12之间的任意整数 |
星期 | 取值为从0到7之间的任意整数,0或7代表星期日 |
命令 | 要执行的命令或程序脚本 |
示例:
crontab -e [-u root]
1.每分钟定时执行一次规则:
每1分钟执行: */1 * * * *或者* * * * *
每5分钟执行: */5 * * * *
2.每小时定时执行一次规则:
每小时执行: 0 * * * *或者0 */1 * * *
每天上午7点执行: 0 7 * * *
每天上午7点10分执行: 10 7 * * *
3.每天定时执行一次规则:
每天执行:0 0 * * *
4.每周定时执行一次规则:
每周执行:0 0 * * 1
5.每月定时执行一次规则:
每月执行:0 0 1 * *
6.每年定时执行一次规则:
每年执行:0 0 1 1 *
-$(date +%Y%m%d) 添加时间戳,防止复制文件时强制覆盖
方法二:
echo '30 7 * * 6 /usr/bin/systemctl httpd restart' >> /var/spool/cron/root
>> 表示重定向
方法三:
vim /etc/crontab
- 使用vim 编辑 /etc/crontab 时,需要在命令前加入user-name
总结
查看进程的命令(ps, top, pgrep, pstree)
进程控制
启动进程、调度进程、终止进程
-
at命令设置计划任务
crontab计划任务的配置字段