一、程序与进程
1.1 程序
报讯在硬盘、光盘等介质中的可执行代码和数据
文件中静态保存的代码
1.2 进程
在CPU及内存中运行的程序代码
动态执行的代码
父、子进程
每个程序创建一个或多个进程
1.3 进程与线程的区别
1、进程是资源分配最小单位,线程是程序执行的最小单位;
2、进程有自己独立的地址空间,每启动一个进程,系统都会为其分配地址空间,建立数据表来维护代码段、堆栈段和数据段,线程没有独立的地址空间,它使用相同的地址空间共享数据;
3、CPU切换一个线程比切换进程花费小;
4、创建一个线程比进程开销小;
5、线程占用的资源要⽐进程少很多。
6、线程之间通信更方便,同一个进程下,线程共享全局变量,静态变量等数据,进程之间的通信需要以通信的方式(IPC)进行;(但多线程程序处理好同步与互斥是个难点)
7、多进程程序更安全,生命力更强,一个进程死掉不会对另一个进程造成影响(源于有独立的地址空间),多线程程序更不易维护,一个线程死掉,整个进程就死掉了(因为共享地址空间);
8、进程对资源保护要求高,开销大,效率相对较低,线程资源保护要求不高,但开销小,效率高,可频繁切换;
1.3 查看进程信息
1.3.1 ps
查看静态的进程统计信息
方法一:ps aux
[root@localhost~]# ps aux
a:显示终端上的所有进程,包括其他用户的进程
u:表示列出进程的用户
x:显示所有终端的进程
USER:进程的用户
PID:进程的ID
%CPU:进程占用的CPU百分比
%MEN:占用的内存的百分比
VSZ:该进程使用的虚拟内存量(KB)
RSS:该进程占用的物理内存量(KB)
TTY:启动进程的终端名。不是从终端启动的进程则显示为?
STAT:该进程的状态。D:不可中断的休眠状态。R:正在运行状态。S:处于休眠状态,可被唤醒。T:停滞状态,可能是在后台暂停后进程处于跟踪调试状态。Z:僵尸进程,进程已经终止,但是部分程序还在内存中。
START:该进程被触发启动时间。
TIME:该进程实际使用CPU运行时间
COMMAND:进程的启动命令。
解释:
(1)僵尸进程:一个进程结束了,但是如果该进程的父进程已经结束了,那么该进程就不会变成僵尸进程,因为每个进程结束的时候,系统都会扫描当前系统中的所有进程,看有没有哪个进程是刚刚结束的这个进程的子进程,如果是的话,就会由Init来接管它,成为它的父进程,子进程退出后init会回收其占用的相关资源。但是当子进程比父进程先结束,而父进程没有回收子进程,释放子进程占用的资源,此时子进程将会变成一个僵尸进程。
(2) tty终端:CentOS7系统,tty1表示图形界面,tty2-6表示文字界面,可以用Ctrl+Alt+F1-F6切换。
pts说明是用远程工具连接的,比如xshell,后面的数字代表登录的时间顺序,越小证明登陆的越早。
方法二:
[root@localhost~]# ps -elf
-e:显示系统内的所有进程信息
-l:使用长格式显示进程信息
-f:使用完整的格式显示进程信息
F:内核分配给进程的系统标记
S:进程的状态
UID:启动这些进程的用户
PID:进程的进程ID
PPID:父进程的进程号(如果该进程是由另一个进程启动的)
C:进程生命周期中的CPU录用率
PRI:进程的优先级(越大的数字代表越低的优先级)
NI:谦让度值用来参与决定优先级
ADDR:进程的内存地址
SZ:假如进程被换出,所需要的交换空间的大致大小
WCHAN:若该进程在睡眠,则显示睡眠中的系统函数名
STIME:进程启动时的终端设备
TTY:进程启动时的系统时间
TIME:运行进程需要的累计CPU时间
CMD:进程的启动命令
1.3.2 top
查看动态进程排名信息
[root@localhost~]# top
第一行是任务队列信息
14:27:34 系统时间
up 9 min 系统已运行时长
1 user 当前登陆用户数
load average :0.00,0.02,0.04
系统负载,即单位时间内系统处理的任务数,后面三个数值分别是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的个数和状态
1.3.3 pgerp
根据特定条件查询进程PID信息
1.3.4 以树形节构列出进程信息
1.4 进程的启动方式
1.4.1 手动启动
(1)前台启动:用户输入命令,直接执行程序
(2)后台启动:在命令行尾加入“&”符号
1.4.2 调动启动
使用at命令,设置一次性计划任务
使用crontab命令,设置周期性计划任务
1.5 进程的前后台调度
1.5.1 Ctrl+Z组合键
将当前进程挂起,即调入后台并停止执行
1.5.2 jobs命令
查看处于后台的任务列表
jobs [-l]
1.5.3 fg命令
将后台进程恢复到前台运行,可指定任务序号
[root@localhost~]# jobs
[1]- Stopped cp /dev/cdrom/ mycd.iso
[2]+ Stopped top
[root@localhost~]# fg 1 (恢复[1]命令到前台)
1.6 终止进程的运行
1.6.1 Ctrl+C组合键
中断正在执行的命令
1.6.2 kill、killall命令
kill:终止指定PID号的进程
killall:终止指定名称相关的所有进程
-9:强制终止
1.6.3 pkill命令
根据特定的条件终止相应的进程
-U:根据进程所属的用户名终止相应的进程
-t:根据进程所在的终端终止相应进程
例
[root@localhost~]#pgrep -l -U "teacher"
3045 bash
[root@localhost~]#pkill -9 -U "teacher"
[root@localhost~]#pgrep -l -U "teacher"
二、 计划任务管理
2.1 at命令
一次性计划任务
at [HH:MM] [yyyy-mm-dd]
例:在当天的21:30时自动关闭系统
2.2 crontab命令
按照预先设置的时间周期(分钟、小时、天、月、周)重复执行用户指定的命令操作
属于周期性计划任务
2.2.1 主要配置文件:
(1)全局配置文件,位于文件:/etc/crontab
(2)系统默认的设置,位于目录:/etc/cron.*/
(3)用户定义的设置,位于文件:/var/spool/cron/用户名
2.2.2 管理crontab计划任务
1、编辑计划任务(-u缺省时默认是针对当前用户)
crontab -e [-u 用户名]
2、查看计划任务
crontab -l [-u 用户名]
3、删除计划任务
crontab -r [-u 用户名]
2.2.3 crontab任务配置的格式
全部数值为整数
分钟 | 小时 | 日期 | 月份 | 星期 | 命令 |
---|---|---|---|---|---|
0-59 | 0-23 | 1-31 | 1-12 | 0-7(0/7都指星期天) | 命令或程序脚本 |
时间数值的特殊表示方法
符号 | 意义 | 例 |
---|---|---|
* | 该范围的任意时间 | 0 17 * * 1-5 (星期一到星期五每天17点) |
, | 间隔的多个不连续时间点 | 30 8 * * 1,3,5 (每周一、三、五的8点30) |
- | 一个连续的时间范围 | 0 8-18/2 * * * (8点到18点间每两小时) |
/ | 指定间隔的时间频率 | 0 * */3 * * (每三天) |
方法二:
追加
echo ‘ 30 7 * * 6 /usr/bin/systemctl httpd restart ’ >> /var/spool/cron/root