天天看点

进程和计划任务管理一、程序和进程的关系二、进程与线程的关系三、命令 四、进程控制 五、总结

目录

一、程序和进程的关系

1.内核功用

2.程序

3.进程

二、进程与线程的关系

1.线程

2.进程与线程的区别与联系

关系图:

三、命令

1.查看静态进程信息ps

 2.查看动态进程信息top

 3.根据特定消息查询进程信息pgrep

4.以树形结构列出进程信息pstree

 四、进程控制

1.进程启动方式

2.进程的前后台调度

3.终止进程的运行

4.计划任务管理

5.计划任务管理crontab

 五、总结

一、程序和进程的关系

1.内核功用

进程管理、内存管理、文件系统、网络功能、驱动程序、安全功能等

2.程序

(1)保存在硬盘、光盘等介质中的可执行的代码和数据

(2)静态保存代码(没有运行)

3.进程

(1)在CPU及内存中运行的程序代码

(2)动态执行的代码

(3)父、子进程

每个程序可以创建一个或多个进程

二、进程与线程的关系

1.线程

(1)定义

是操作系统能够进行运算调度的最小单位。它被包含在进程之中,是进程中的实际运作单位

(2)一个进程至少有一个执行线程

(3)线程也被称为轻量级进程;

(4)线程是进程内部的一部分

2.进程与线程的区别与联系

区别

(1)角度一:资源分配与调度

进程是资源竞争的基本单位

线程是程序执行的最小单位

(2)角度二:资源占有角度

操作系统会为一个进程分配一堆资源,所有的进程之间是独立的,是互不影响的

线程会共享进程的虚拟地址空间,只拥有一小部分资源,比如自己的线程ID,私有栈空间,自己的上下文数据等

线程是共享资源,所以一个线程的异常退出会影响整个进程异常退出,并且要注意线程间的同步与互斥问题

(3)角度三:调度与切换

进程会携带很多资源,所以创建和撤销进程时,代价较大;线程花费代价较小

进程会携带很多资源,所以进程之间的切换或调度时,操作系统要做的工作比较多;线程调度时,工作较少

联系

进程和线程都是操作系统所运行的程序运行的基本单元

关系图:

进程和计划任务管理一、程序和进程的关系二、进程与线程的关系三、命令 四、进程控制 五、总结

三、命令

1.查看静态进程信息ps

(1)ps -aux

查看静态进程统计信息

进程和计划任务管理一、程序和进程的关系二、进程与线程的关系三、命令 四、进程控制 五、总结

常用参数

参数 功能
-a 显示当前终端下的所有进程信息,包括其他用户的进程。
-u 使用以用户为主的格式输出进程信息
-x 显示当前用户在所有终端下的进程信息

常用的选项组合

ps -aux  以简单列表的形式显示出进程信

标题 各字段含义
USER 启动该进程的用户账号的名称
PID 该进程在系统中的数字ID号,在当前系统中是唯一的
%CPU CPU 占用的百分比
%MEM 内存占用的百分比
VSZ 该进程使用的虚拟内存量(KB)
RSS 该进程占用的物理内存量(KB)
TTY 表明该进程在哪个终端上运行
STAT 该进程的状态
START 启动该进程的时间
TIME 该进程占用的 CPU 时间
COMMAND 启动该进程的命令的名称

PS:

STAT进程状态 含义
-D 不可被唤醒的睡眠状态,通常用于 I/O 情况
-R 该进程正在运行
-S 该进程处于睡眠状态,可被唤醒
-T 停止状态,可能是在后台暂停或进程处于除错状态
-W 内存交互状态
-X 死掉的进程
-Z 僵尸进程。进程已经中止,但是仍在占用内存
-< 高优先级(以下状态在 BSD 格式中出现)
-N 低优先级
-L 被锁入内存
-s 包含子进程
-l 多线程
-+ 位于后台
-C 进程占用CPU的百分比

(2)ps -elf   将以长格式显示系统中的进程信息

进程和计划任务管理一、程序和进程的关系二、进程与线程的关系三、命令 四、进程控制 五、总结

常用参数 

符号 功能
-e 显示系统内的所有进程信息
-l 使用长格式显示进程信息
-f 使用完整的格式显示进程信息

各列含义

标题 各字段含义
F 内核分配给进程的系统标记
S 进程的状态
UID 启动这些进程的用户
PID 进程的进程ID
PPID 父进程的进程号(如果该进程是由另一“个进程启动的)
C 进程生命周期中的CPU利用率
PRI 进程的优先级(越大的数字代表越低的优先级)
NI 谦让度值用来参与决定优先级
ADDR 进程的内存地址
SZ 假如进程被换出,所需交换空间的大致大小
WCHAN 若该进程在睡眠,则显示睡眠中的系统函数名
STIME 进程启动时的系统时间
TTY

进程启动时的终端设备

pts/0255代表虚拟终端,一般是远程连接的终端;tty1tty7 代表本地控制台终端

TIME TIME
CMD 进程的启动命令

 2.查看动态进程信息top

[[email protected] ~]# top
           
进程和计划任务管理一、程序和进程的关系二、进程与线程的关系三、命令 四、进程控制 五、总结

 各列含义

标题 各字段含义
PID 进程ID
USER 进程所有者的用户名
PR 优先级(由内核动态调整),用户不能
NI 进程优先级;nice值:负值表示高优先级,正值表示低优先级,用户可以自己调整
VIRT 虚拟内存,是进程正在使用的所有内存
RES 是进程所使用的物理内存。实际实用内存
PRI 进程的优先级(越大的数字代表越低的优先级)
S 进程状态
%CPU 上次更新到现在的CPU时间占用百分比
%MEM 进程使用的物理内存百分比
TIME+ 进程使用的 CPU 时间总计,单位 1/100 秒
COMMAND 命令名/命令行

 top 命令全屏操作界面快捷键

S 修改刷新时间
空格 立即刷新
P 按CPU排序
M 按内存排序
T 按时间排序
p 进程IP,查看某个进程状态
N 根据启动时间进行排序
1 显示每个内核的CPU使用率
U 指定显示的用户
h 可以获得top程序的在线帮助信息
q 可以正常地退出top程序

 3.根据特定消息查询进程信息pgrep

[[email protected] ~]# pgrep -l -u root
1 systemd
2 kthreadd
3 ksoftirqd/0
4 kworker/0:0
5 kworker/0:0H
7 migration/0
8 rcu_bh
9 rcu_sched
(以上为进程信息,这里只截选部分)
[[email protected] ~]# pgrep -l -U root -t tty1
1196 X
           

常用参数

参数 功能
-l 选项可同时输出对应的进程名以及PID
-U 选项查询特定用户的进程
-t 选项查询在特定终端运行的进程

4.以树形结构列出进程信息pstree

常用选项pstree -aup

符号 功能
-a 显示出完成信息
-u 列出对应用户
-p 列出对应PID号
进程和计划任务管理一、程序和进程的关系二、进程与线程的关系三、命令 四、进程控制 五、总结

PS:我们也可以通过以下命令查看子进程

[[email protected] ~]# vim /proc/4985/stat
4985为进程的PID号
           

 四、进程控制

1.进程启动方式

(1)手工启动

前台启动:用户输入命令,直接执行程序

后台启动:在命令行尾加入“&”符号

[[email protected] ~]# cp /dev/cdrom mycd.iso &
[1] 30649
前台我们需要等待加载
后台我们可以在加载的同时进行其他操作
           

(2)调度启动

使用at命令,设置一次性计划任务

使用crontab命令,设置周期性计划化任务、

2.进程的前后台调度

(1)Ctrl+Z组合键

将当前进程挂起,及调入后台并停止执行

[ [email protected] ky15]# cp -fr /data/* /mnt/ky15/
[1]+已停止             cp -i -fr /data/* /mnt/ky15/
           

(2)jobs命令

查看处于后台的任务列表

​[[email protected] ky15]# jobs
[1]+ 已停止            cp -i -fr /data/* /mnt/ky15/
           

(3)fg命令

将后台进程恢复到前台运行,可指定任务序号

[[email protected] ky15]# fg 1
cp -i -fr /data/* /mnt/ky15/
           

3.终止进程的运行

(1)Ctrl+C组合键

中断正在执行的命令

(2)kill、killall命令

kil用于终止指定PID号的进程

killall用于终止指定名称的所有进程

-9选项用于强制终止

[[email protected] ~]# pgrep -l "sshd"
1151 sshd
28451 sshd
[[email protected] ~]# kill 1151
[[email protected] ~]# pgrep -l "sshd"
28451 sshd
           

(3)pkill命令

根据特定条件终止相应的进程

常用命令选项

选项 功能
-U 根据进程所属的用户名终止相应进程
-t 根据进程所在的终端终止相应进程
[[email protected] ~]# pgrep -I -U "hackli"
3045 bash
[[email protected] ~]# pkill -9 _U "hackli"
[[email protected] ~]# pgrep -I -U "hackli"
           

4.计划任务管理

(1)at命令

一次性计划任务

格式
at [HH:MM] [yyyy-mm-dd]
     时分     年月日
[[email protected] ~]# at 10:35 2021-9-12
at> pgrep -U root I wC -1> /tmp/ps.root
at> <EOT>
job 1 at Sun Sep 12 10:35:00 2021
[[email protected] ~]# cat /tmp/ps.root
202 
[[email protected] ~]# atq 查看未执行的任务列表
           

5.计划任务管理crontab

(1)crontab命令

①按照预先设置的时间周期(分钟、小时、天....... )重复执行用户指定的命令操作

②属于周期性计划任务

③主要设置文件

全局配置文件,位于文件: /etc/crontab

系统默认的设置,位于目录: /etc/cron.*/

用户定义的设置, 位于文件: /var/spool/cron/用户名

(2)管理crontab计划任务

编辑计划任务

crontab -e [-u 用户名]

查看计划任务

crontab -l [-u 用户名]

删除计划任务

crontab -r [-u 用户名]

(3)crontab任务配置格式

分 时 日 月 周   run_command

字段 说明
分钟 取值为从0到59之间的任意整数
小时 取值为从0到23之间的任意整数
日期 取值为从1到31之间的任意整数
月份 取值为从1到12之间的任意整数
星期 取值为从0到7之间的任意整数,0或7代表星期日
命令 要执行的命令或程序脚本

时间数值的特殊表示方法

字段 说明
* 表示该范围内的任意时间
表示间隔的多个不连续时间点
- 表示一个连续的时间范围
/ 指定间隔的时间频率

 五、总结

本章主要讲了进程和计划任务管理相关内容,希望可以帮助到大家理解!

继续阅读