目录
一、程序和进程
1.程序
保存在硬盘、光盘等介质中的可执行代码和数据文件中
静态保存的代码
2.进程
在CPU及内存中运行的程序代码
动态执行的代码
父、子进程
每个程序可以创建一个或多个进程
3.线程与进程
进程是程序的一次执行,它是资源分配和管理的基本单位,包括代码、数据、堆栈、文件句柄等。
线程是进程中的一个执行流程,是CPU调度的基本单位,共享进程的资源,包括内存、文件和其他系统资源。
进程之间通常是相互独立的,每个进程有独立的内存空间,通过进程间通信(IPC)来实现数据共享和通信。
线程之间共享相同的地址空间和其他进程资源,线程之间的数据共享和通信更为方便。
二、查看系统进程
1.ps-静态查看系统进程
常用选项
a | 显示当前终端下的所有进程信息,包括其他用户的进程 |
u | 使用以用户为主的格式输出进程信息 |
x | 显示当前用户在所有终端下的进程信息 |
-e | 显示系统内的所有进程信息 |
-l | 使用长格式显示进程信息 |
-f | 使用完整的格式显示进程信息 |
-a | 显示现行终端下的所有进程 |
-T | 查看线程信息 |
–sort 属性 | 对属性排序,属性前加-表示倒序 |
ps aux-各列解释
USER | 进程的用户 |
PID | 进程的ID |
%CPU | 进程占用的CPU百分比,占用越高,进程越耗费资源 |
%MEM | 占用内存的百分比 |
VSZ | 该进程使用的虚拟内存量(KB) |
RSS | 该进程占用的实际物理内存量(KB) |
TTY | 启动进程的终端名。不是从终端启动的进程则显示为 ? |
STAT | 该进程的状态: D:不可中断的休眠状态; R:正在运行状态; S:处于休眠状态,可被唤醒; T:停止状态,可能是在后台暂停或进程处于跟踪调试状态; Z:僵尸进程,进程已经中止,但是部分程序还在内存当中 |
START | 该进程被启动时间 |
TIME | 该进程实际使用CPU的时间 |
COMMAND | 进程的名称与参数 |
[root@localhost ~]# ps -aT #显示所有线程
[root@localhost ~]# ps -T -p <pid> #查看指定进程中已经起的线程
[root@localhost ~]# ps -L <pid> #查看指定进程中的线程信息
[root@localhost ~]#ps aux --sort -%cpu | head -10 #按cpu降序排列,-为降序,+为升序,p与%同义
[root@localhost ~]#ps aux --sort +pmem | head -n 10 #按内存升序排列
[root@localhost ~]#ps aux --sort -pcpu,+pmem | head -n 10
各列解释
F | 内核分配给进程的系统标记 |
S | 进程的状态 |
UID | 启动这些进程的用户 |
PID | 进程的进程ID |
PPID | 父进程的进程号(如果该进程是由另一个进程启动的) |
C | 进程生命周期中的CPU利用率 |
PRI | 进程的优先级(越大的数字代表越低的优先级) |
NI | 谦让度值用来参与决定优先级 |
ADDR | 进程的内存地址 |
SZ | 假如进程被换出,所需交换空间的大致大小 |
WCHAN | 若该进程在睡眠,则显示睡眠中的系统函数名 |
STIME | 进程启动时的系统时间 |
TTY | 进程启动时的终端设备 |
TIME | 运行进程需要的累计CPU时间 |
CMD | 进程的启动命令 |
僵尸进程:
一个进程结束了,但是如果该进程的父进程已经先结束了,那么该进程就不会变成僵尸进程,因为每个进程结束的时候,系统都会扫描当前系统中所运行的所有进程,看有没有哪个进程是刚刚结束的这个进程的子进程,如果是的话,就由Init来接管它,成为它的父进程,子进程退出后init会回收其占用的相关资源。
但是当子进程比父进程先结束,而父进程又没有回收子进程,释放子进程占用的资源,此时子进程将成为一个僵尸进程。
2.top-查看进程动态信息
常用命令
P 键 | 根据CPU使用百分比大小进行排序 |
M 键 | 根据驻留内存大小进行排序 |
N 键 | 根据启动时间进行排序 |
c 键 | 切换显示命令名称和完整命令行 |
h 键 | 可以获得 top程序的在线帮助信息 |
k 键 | 根据提示输入指定进程的 PID 号并按 Enter 键终止对应的进程 |
q 键 | 退出 top 程序 |
数字1 键 | 显示CPU个数和状态 |
[root@localhost ~]#top -H #显示所有线程
[root@localhost ~]#top -H -p <pid> #显示特定进程中的线程
第一行:任务队列信息
11:06:48 | 系统时间 |
up 1:22 | 系统已运行时长 |
1 user | 当前登录用户数 |
load average: 0.06, 0.60, 0.48 | 系统负载,即单位时间内系统处理的任务数,后面三个数值分别为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 | 可用物理空间 |
CPU使用率和CPU负载:
CPU使用率是指CPU在某个时间段内被使用的比例,以百分比表示。反映了CPU的使用强度
CPU负载是指CPU正在处理的任务数或等待CPU处理的任务数。反映了系统中的任务繁忙程度
tty终端
Centos7系统,tty1表示图形界面,tty2-tty6表示文字界面,可以用Ctrl+Alt+F1-F6切换。
pts说明是用远程工具连接的,比如xshell,后面的数字代表登录的时间顺序,越小证明登录的越早
3.pgrep-根据特定条件查询进程pid信息
[root@localhost ~]# pgrep -l "-log" #-l:显示进程名 缺省时只输出PID号
2538 rsyslogd
2113 mcelog
[root@localhost ~]# pgrep -l -U teacher -t tty2 #-U:指定特定用户 -t:指定终端
27483 bash
27584 vim
4.pstree-查看进程树
-a | 显示完整信息 |
-u | 列出对应用户名 |
-p | 列出对应pid号 |
pstree -ap teacher #只查看属于指定用户的进程树结构
三、控制进程
1.进程的启动方式
手工启动
前台启动:用户输入命令,直接执行程序
后台启动:在命令行尾加入“&”符号
调度启动
使用at命令,设置一次性计划任务
使用crontab命令,设置周期性计划任务
2.进程的前后台调度
Ctrl+Z组合键 | 将当前进程挂起,即调入后台并停止执行 |
jobs [-l] | 查看处于后台的任务列表 |
fg+序号 | 将后台的进程恢复到前台运行,可指定任务序号 |
3.终止进程
Ctrl+C组合键
中断正在执行的命令
kill、killall命令
kill用于终止指定PID号的进程
killall用于终止指定名称相关的所有进程
-9选项用于强制终止
kill是如何杀掉进程的? 向进程发送信号的方式杀掉进程
kill | 默认选项为 -15,发送信号 SIGTERM,表示告诉进程自行停止运行并退出,进程可以忽略 |
kill -9 | 发送信号 SIGKILL,表示进程要立即退出,且不能被捕捉或忽略 |
kill -3 | 发送信号 SIGQUIT,表示进程自行退出,并打印进程各个线程的堆栈信息,保存路径为 /proc/${pid}/cwd,文件名为 antBuilderOutput.log |
kill -1 | 发送信号 SIGHUP,表示进程重新加载配置文件,不退出 |
pkill命令
根据特定条件终止相应的进程
pkill <关键词> -U <用户名> -t <终端> #U:根据进程所属的用户名终止相应进程;-t:根据进程所在的终端终止相应进程
[root@localhost ~]# pgrep -l -U "teacher"
3045 bash
[root@localhost ~]#pkill -9 -U "teacher"
四、计划任务管理
1.at-一次性计划任务
at HH:MM [yyyy-mm-dd] --> 输入命令列表 --> ctrl + d 提交任务 --> atq 查看没执行的任务列表和序号 --> atrm <序号> 删除指定的任务
[root@localhost ~]# date
Sun May 7 10:33:13 EDT 2017
[root@localhost ~]# 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
2.crontab-周期性计划任务
按照预先设置的时间周期(分钟、小时、天、月、周)重复执行用户指定的命令操作
属于周期性计划任务
主要设置文件
全局配置文件,位于文件:/etc/crontab
系统默认的设置,位于目录:/etc/cron.*/
用户定义的设置,位于文件:/var/spool/cron/用户名
启动周期性任务必须确认对应的系统服务crond已经运行
crontab -e [-u 用户] --> 自动对应文件 /var/spool/cron/用户名
分 时 日 月 周 执行命令或脚本路径
分 0 ~ 59
时 0 ~ 23
日 1 ~ 31
月 1 ~ 12
周 0 ~ 7 , 0 和 7 都代表 周日
符号 | 说明 |
---|---|
* | 表示该范围内的任意时间 |
, | 表示间隔的多个不连续的时间点 |
- | 表示一个连续的时间范围 |
/ | 指定间隔的时间频率 (写在第一个 */2 每隔2分钟) |