进程和计划任务管理——工作中常用的理论知识
前言:
查看进程:分为静态查看和动态查看
控制进程:以关掉进程为主,可以按条件关闭指定进程,全部关闭所有进程
at 一次性任务设置
crontab 周期性任务设置
一、程序和进程的关系
(1)、程序
保存在硬盘、光盘等介质中的可执行代码和数据
静态保存的代码
(2)、进程
在CPU及内存中运行的程序代码
动态执行的代码
父、子进程
每个进程可以创建一个或多个进程
(3)、程序、进程、线程之间的三者关系
一个应用程序可以包含一个或多个应用进程
一个进程包含一个或多个线程
线程是执行操作的最小单元
PS:应用程序=工厂 进程=车间 线程=工人 高并发处理依赖于多线程操作
二 、查看静态进程信息 PS
2.1、 PS 命令----ps aux 命令
查看静态的进程统计信息
[root@localhost ~]# ps aux
常用选项:
a:显示终端bail上的所有进程,包括其它用户的进程。
u: 表示列出进程的用户。
x:显示所有终端的进程。
cpu、mem需要重点关注
2.2、 PS 命令----ps -elf命令
查看静态的进程统计信息
[root@localhost ~]# ps -elf
常用选项
-e:显示系统内的所有进程信息。
-1:使用长格式显示进程信息
-f:使用完整的格式显示进程信息。
F:内核分配给进程的系统标记
S:进程的状态
UID:启动这些进程的用户
PID:进程的进程ID
PPID:父进程的进程号(如果该进程是由另一个进程启动的)
C:进程生命周期中的CPU录用率
PRI:进程的优先级(越大的数字代表越低的优先级)
NI:谦让度值用来参与决定优先级
ADDR:进程的内存地址
SZ:假如进程被换出,所需要的交换空间的大致大小
WCHAN:若该进程在睡眠,则显示睡眠中的系统函数名
STIME:进程启动时的终端设备
TTY:进程启动时的系统时间
TIME:运行进程需要的累计CPU时间
CMD:进程的启动命令
三、查看动态进程信息 top
top命令
查看动态的进程排名信息
[root@localhost ~]# top
常用选项
P:根据CPU使用百分比大小进行排序
M:根据驻留内存大小进行排序
N:根据启动时间进行排序
c:切换显示命令名称和完整命令行
h:可以获得top程序的在线帮助信息
k:根据提示输入指定进程的PID号并按Enter键中止对应的进程
q:退出top程序
数字1键:显示CPU的个数和状态
第一行是任务队列信息
14:29:58 系统时间
up 3:46 min 系统已运行时长
3 users 当前登陆用户数
load average :0.00,0.01,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 可用物理空间
PS:
(1)僵尸进程:一个进程结束了,但是如果该进程的父进程已经结束了,那么该进程就不会变成僵尸进程,因为每个进 程结束的时候,系统都会扫描当前系统中的所有进程,看有没有哪个进程是刚刚结束的这个进程的子进程,如果是的话, 就会由Init来接管它,成为它的父进程,子进程退出后init会回收其占用的相关资源。但是当子进程比父进程先结束,而父进程没有回收子进程,释放子进程占用的资源,此时子进程将会变成一个僵尸进程。
(2) tty终端:CentOS7系统,tty1表示图形界面,tty2-6表示文字界面,可以用Ctrl+Alt+F1-F6切换。
pts说明是用远程工具连接的,比如xshell,后面的数字代表登录的时间顺序,越小证明登陆的越早。
四 、查看进程信息 pgrep
根据特定条件查询进程PID信息
[root@localhost ~]# pgrep -l "log" -l:显示进程名 缺省时只输出PID号
2538 rsyslogd
2113 mcelog
[root@localhost ~]# pgrep -l -U root -t tty2 -U:指定特定用户 -t:指定终端
27483 bash
27584 vim
五、查看进程信息 pstree
以树形结构列出进程信息
[root@localhost ~]# pstree -aup -a:显示完整信息 -u:列出对应用户名 -p:列出对应PID号
[root@localhost ~]# pstree -ap teacher 只查看属于指定用户的进程树结构
六 、进程的启动方式
6.1 、手工启动
前台启动:用户输入命令,直接执行程序
后台启动;在命令行尾加入“&(读end)”符号,后台启用是为了防止文件过大会影响正常使用系统,这时就要去后台启用
[root@localhost dev]# cp /dev/cdrom mycd.iso&
[1] 28454 '输出信息中包括后台任务序号、PID号'
6.2 、调度启动(at、crontab)
(1)使用at命令,设置一次性计划任务
(2)使用crontab命令,设置周期性计划任务
6.3、 进程的前后台调度
Ctrl+Z 组合键
将当前进程挂起,即调入后台并停止执行
jobs 命令
jobs【-l】
查看处于后台的进程列表
fg命令
将后台进程恢复到前台运行,可通过指定任务序号去选中
[root@localhost ~]# jobs
【1】 - stopped cp /dev/cdrom mycd.iso
【2】+ stopped top
[root@localhost ~]# fg 1 恢复[1]命令到前台
6.4、终止进程的运行
(1)、Ctrl+c 组合键
中断正在执行的命令
(2)、kill、killall 命令
kill:终止指定PID号的进程
killall:终止指定名称相关的所有进程
-9:强制终止
(3)、pkill命令
根据特定条件终止相应的进程
常用命令选项
-U:根据进程所属的用户名终止相应进程
-t :根据进程所在的终端终止相应进程
[root@localhost ~]# pgrep -l -U "teacher‘
3045 bash
[root@localhost ~]# pkill -9 -U “teacher”
[root@localhost ~]# pkill -l -U “teacher”
七、计划任务管理
7.1、 at命令
一次性计划任务
[root@localhost mnt]# at [HH:MM] [yyyy-mm-dd] 'at 小时:分钟 年-月-日'
[root@localhost mnt]# date '查看当前时间'
Sun May 7 10:33 :13 EDT 2017
[root@localhost mnt]# at 10:35 2017-05-07
at> pgrep -U root | wc -l > /tmp/ps.root
at> <EOT> 按'Ctrl+D,提交任务'
job 1 at Sun May 7 10:35:00 2017
[root@localhost ~]# cat /tmp/ps.root
202
案例:在当天的21:30时自动关闭当前系统
7.2、 crontab命令
按照预先设置的时间周期(分时日月周)重复执行用户指定的命令操作
属于周期性计划任务
主要设置文件
全局配置文件,位于文件:/etc/crontab
系统默认的设置,位于目录:/etc/cron.*/
用户定义的设置,位于文件:/var/spool/cron/用户名
7.3、管理crontab计划任务
编辑cron计划任务
[root@localhost mnt]# crontab -e [-u 用户名]
查看计划任务
[root@localhost mnt]# crontab -l [-u 用户名]
删除计划任务
[root@localhost mnt]# crontab -r [-u 用户名]
7.4、crontab任务配置的格式
7.5、时间数值的特殊表示方法
7.6、应用实例
八、总结
查看进程的命令(ps、top、pgrep、pstree)
进程控制
启动进程
调度进程(Ctrl+z组合键、jobs、bg、fg)
终止进程(kill、killall、pkill)
at命令设置计划任务
crontab计划任务的配置字段