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个数和状态

1.png

查看进程信息pgrep

pgrep命令
根据特定条件查询进程PID信息

[root@localhost ~]# pgrep -I 进程

缺省时只输出PID号

-l:      显示进程名
-U:      指定特定用户
-t:      指定终端

2.png

查看进程树pstree

pstree命令
以树形结构列出进程信息

3.png

[root@localhost ~]# pstree -aup

-a:        显示完整信息
-u:        列出对应用户名
-p:        列出对应PID号

4.png

进程与线程的区别

进程

指在系统中正在运行的一个应用程序,程序一旦运行就是进程,进程一一资源分配的最小单位

线程

系统分配处理器时间资源的基本单元,或者说进程之内独立执行的一个单元执行流。线程一程序执行的最小单位

进程要分配一大部分的内存,而线程只需要分配一部分栈就可以了

一个程序至少有一个进程,一个进程至少有一个线程

一个线程可以创建和撤销另一个线程,同一个进程中的多个线程之间可以并发执行

三、控制进程

进程的启动方式

手工启动

前台启动:用户输入命令,直接执行程序
后台启动:在命令行尾加入“&”符号
[root@localhost ~]# cp /dev/cdrom mycd.iso &
[1] 28454
输出信息中包括后台
任务序号、PID号

5.png

调度启动

使用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

6.png

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提供了大量能使我们快速便捷地处理数据的函数和方法。