Linux中的进程管理
Posted M桀骜9
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Linux中的进程管理相关的知识,希望对你有一定的参考价值。
Linux中的进程管理
一、程序和进程的关系
程序
- 保存在硬盘、光盘等介质中的可执行代码和数据
- 文件中静态保存的代码
进程
- 在CPU及内存中运行的程序代码
- 动态执行的代码
- 父、子进程
- 每个程序可以创建一个或多个进程
二、查看进程信息ps
ps命令
- 查看静态的进程统计信息
[root@localhost~]#ps aux
a:显示终端上的所有进程,包括其他用户的进程
u:表示列出进程的用户
x:显示所有终端的进程
各列的解释:
USER:进程的用户。
PID:进程的ID
%CPU:进程占用的CPU百分比
%MEM:占用内存的百分比
VSZ:该进程使用的虚拟内存量(KB)
RSS:该进程占用的物理内存量(KB)
TTY:启动进程的终端名。不是从终端启动的进程则显示为?
STAT:该进程的状态(D:不可中断的休眠状态;R:正在运行状态;S:
处于休眠状态:
ps命令
- 查看静态的进程统计信息
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:进程的启动命令
僵尸进程:
一个进程结束了,但是如果该进程的父进程已经先结束了,那么该进程就不会变成僵尸进程,因为每个进程结束的时候,系统都会扫描当前系统中所运行的所有进程,看有没有哪个进程是刚刚结束的这个进程的子进程,如果是的话,就由Init来接管它,成为它的父进程,子进程退出后init会回收其占用的相关资源。
但是当子进程比父进程先结束,而父进程又没有回收子进程,释放子进程占用的资源,此时子进程将成为一个僵进程。
top命令
- 查看动态的进程排名信息
[root@localhost~]# top
查看进程信息top
top命令
查看动态的进程排名信息
[root@localhost~]# top
top命令---查看进程动态信息
第一行是任务队列信息
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 可用物理空间
进程信息区各列解释
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个数和状态
查看进程信息pgrep
pgrep命令
根据特定条件查询进程PID信息
[root@localhost ~]# pgrep -I 进程
缺省时只输出PID号
-l: 显示进程名
-U: 指定特定用户
-t: 指定终端
查看进程树pstree
pstree命令
以树形结构列出进程信息
[root@localhost ~]# pstree -aup
-a: 显示完整信息
-u: 列出对应用户名
-p: 列出对应PID号
进程与线程的区别
进程
指在系统中正在运行的一个应用程序,程序一旦运行就是进程,进程一一资源分配的最小单位
线程
系统分配处理器时间资源的基本单元,或者说进程之内独立执行的一个单元执行流。线程一程序执行的最小单位
进程要分配一大部分的内存,而线程只需要分配一部分栈就可以了
一个程序至少有一个进程,一个进程至少有一个线程
一个线程可以创建和撤销另一个线程,同一个进程中的多个线程之间可以并发执行
三、控制进程
进程的启动方式
手工启动
前台启动:用户输入命令,直接执行程序
后台启动:在命令行尾加入“&”符号
[root@localhost ~]# cp /dev/cdrom mycd.iso &
[1] 28454
输出信息中包括后台
任务序号、PID号
调度启动
使用at命令,设置一次性计划任务
使用crontab命令,设置周期性计划任务
终止进程的运行
Ctrl+C组合键
中断正在执行的命令
kill命令
okill PID 用于终止指定PID号的进程
killall命令
okilall 进程名称 用于终止指定名称相关的所有进程(慎用)
pkill命令
根据特定条件终止相应的进程
常用命令选项
-9 选项用于强制终止
-U: 根据进程所属的用户名终止相应进程
-t: 根据进程所在的终端终止相应进程
四、at一次性任务设置
一次性计划任务
at [HH:MM] [yyyy-mm-dd]
[root@localhost ~]# date
2021年 04月 22日 星期四 18:40:30 CST
[root@localhost ~]# at 18:45 2021-04-22
at> pgrep-U root | wc -l > /tmp/ps.root
at> <EOT> 按Ctrl+D键提交任务
job 1 at Thu Apr 22 18:45:00 2021
at 18:50 不携带日期表示为当天
atq 查看未执行的任务列表
atrm 1 删除第1条任务
五、crontab周期性任务设置
crontab命令
按照预先设置的时间周期(分钟、小时、天、月、周)重复执行用户指定的命令操作
属于周期性计划任务
主要设置文件
全局配置文件,位于文件: /etc/crontab
系统默认的设置,位于目录: /etc/cron.*/
用户定义的设置, 位于文件: /var/spool/cron/用户名
管理crontab计划任务
-u 缺省时默认是针对当前用户
编辑计划任务
crontab -e [-u 用户名]
查看计划任务
crontab -l [-u 用户名]
删除计划任务
crontab -r [-u 用户名]
crontab任务配置的格式
字段 | 说明 |
---|---|
分钟 | 取值为从0到59之间的任意整数 |
小时 | 取值为从0到23之间的任意整数 |
日期 | 取值为从1到31之间的任意整数 |
月份 | 取值为从1到12之间的任意整数 |
星期 | 取值为从1到12之间的任意整数 |
命令 | 要执行的命令或程序脚本 |
时间数值的特殊表示方法
* 表示该范围内的任意时间
, 表示间隔的多个不连续时间点
- 表示一个连续的时间范围
/ 指定间隔的时间频率
应用示例
0 04 * * 1-5 周一到周五每天04:00
30 8 * * 1,3,5 每周一、三、五的8点30分
0 8-18/2 * * 8点到18点之间每2小时
0 * */3 * * 每3天
crontab任务配置
代表意义 分钟 小时 日期 月份 周 命令
数字范围 0~59 0~23 1~31 1~12 0~7 需要执行的命令
周的数字为0或7时,都代表“星期天”的意思。
echo ‘30 7 6 /usr/bin/systemctl httpd restart’ >> /var/spool/cron/root
总结
提示:这里对文章进行总结:
例如:以上就是今天要讲的内容,本文仅仅简单介绍了pandas的使用,而pandas提供了大量能使我们快速便捷地处理数据的函数和方法。
以上是关于Linux中的进程管理的主要内容,如果未能解决你的问题,请参考以下文章
LINUX PID 1和SYSTEMD PID 0 是内核的一部分,主要用于内进换页,内核初始化的最后一步就是启动 init 进程。这个进程是系统的第一个进程,PID 为 1,又叫超级进程(代码片段