云计算【第一阶段(22)】进程和计划任务管理

一、查看进程

1.1、程序和进程的关系

程序

  • 保存在硬盘,光盘等介质中的可执行代码和数据
  • 静态保存的代码

进程

  • 在cpu及内存中运行的程序代码
  • 动态执行的代码
  • 父,子进程:每个程序可以创建一个或多个进程

1.2、查看进程

1.2.1、静态查看进程信息ps

ps 参数

常用的参数

  • -a:显示当前终端下的所有进程信息,包括其他用户的进程。与"x"选项结合时将显示系统中所有的进程信息。
  • -u:使用以用户为主的格式输出进程信息。
  • -x:显示当前用户在所有终端下的进程信息。
  • -e:显示系统内的所有进程信息。
  • -1:使用长格式显示进程信息。
  • -f:使用完整的格式显示进程信息。

常用的选项组合
ps -aux #将以简单列表的形式显示出进程信

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

字段 描述
USER 启动该进程的用户账号的名称
PID 该进程在系统中的唯一数字ID号
%CPU CPU占用的百分比
%MEM 内存占用的百分比
VSZ 虚拟内存使用量(KB)
RSS 物理内存使用量(KB)
TTY 进程运行的终端。非终端启动的进程显示为? pts: 远程登录终端,tty1-tty6: 本地终端(可能包括图像界面和字符界面),?: 系统自身执行的进程
STAT 进程状态:D: 不可中断的休眠状态R: 运行状态S: 休眠状态T: 停止状态Z: 僵尸进程 其他状态如<, N, L, s, l, + 也有各自的含义
START 启动该进程的时间
TIME 该进程占用的CPU时间
COMMAND 启动该进程的命令的名称

STAT补充

状态代码 描述
D 不可中断的休眠状态。通常用于等待I/O操作完成。这并不意味着它是系统守护进程,但守护进程可能会处于此状态。
R 运行状态。进程正在运行或准备运行。
S 休眠状态。进程在等待某个条件成立以便继续执行。
T 停止状态。进程收到SIGSTOP、SIGTSTP、SIGTTIN或SIGTTOU信号后停止执行。
Z 僵尸状态。进程已经终止,但父进程尚未回收其资源。
< 进程运行在高优先级上(这个符号通常不直接出现在STAT列中,而是可能作为其他信息的一部分)。
N 进程运行在正常优先级上(这个符号通常不直接出现在STAT列中,而是可能作为其他信息的一部分)。
L 进程有页面锁定在内存中(这个状态代码可能不直接出现在STAT列中,而是作为进程属性的一部分)。
s 进程是控制终端的会话领导(session leader)。
l 进程是多线程的(这个状态代码可能不直接出现在STAT列中,而是作为进程属性的一部分)。
+ 进程在前台运行(这个状态代码可能不直接出现在STAT列中,而是作为进程状态的一部分)。
列名 解释
F 内核分配给进程的系统标记
S 进程的状态
UID 启动这些进程的用户
PID 进程的进程ID
PPID 父进程的进程号(如果该进程是由另一个进程启动的)
C 进程生命周期中的CPU利用率
PRI 进程的优先级(越大的数字代表越低的优先级)
NI 谦让度值用来参与决定优先级
ADDR 进程的内存地址
SZ 假如进程被换出,所需交换空间的大致大小
WCHAN 若该进程在睡眠,则显示睡眠中的系统函数名
STIME 进程启动时的系统时间
TTY 进程启动时的终端设备(pts/0-255代表虚拟终端,tty1-tty7代表本地控制台终端)
TIME 运行进程需要的累计CPU时间
CMD 进程的启动命令
状态 描述
D 不可被唤醒的睡眠状态,通常用于 I/O 情况
R 该进程正在运行
S 该进程处于睡眠状态,可被唤醒
T 停止状态,可能是在后台暂停或进程处于除错状态
W 内存交互状态(从 2.6 内核开始无效)
X 死掉的进程(应该不会出现)
Z 僵尸进程。进程已经中止,但是部分程序还在内存当中
< 高优先级(以下状态在 BSD 格式中出现)
N 低优先级
L 被锁入内存
s 包含子进程
l 多线程(小写 L)
+ 位于后台
C 进程占用CPU的百分比
1.2.1.1、实验

在终端A执行 编写vim a.txt

打开另一个终端B

ps -aux |grep a.txt

S 表示睡眠状态, + 表示前台

这个终端A上 按下: ctrl+z 停止

再次查看状态

查看状态 T 表示停止状态

扩展:

ctrl - c 是发送 SIGINT 信号,终止一个进程

ctrl - z 是发送 SIGSTOP 信号,挂起一个进程。将作业放置到后台(暂停)

ctrl - d 不是发送信号,而是表示一个特殊的二进制值,表示 EOF。代表输入完成或者注销

1.2.2、动态查看进程信息top

top 命令

类别 描述
系统任务(Tasks)
total 总进程数
running 正在运行的进程数
sleeping 休眠的进程数
stopped 中止的进程数
zombie 僵死无响应的进程数
CPU 占用
us 用户占用
sy 内核占用
ni 优先级调度占用
id 空闲CPU(百分比)
wa I/O 等待占用
hi 硬件中断占用
si 软件中断占用
st 虚拟化占用
内存占用(Mem)
total 总内存空间
free 空闲内存
used 已用内存
buff/cache 物理内存和交换内存的缓冲区总和
avail Mem 考虑buff/cache后可用的物理内存
交换空间(Swap)
total 总交换空间
free 空闲交换空间
used 已用交换空间
avail Mem 注意:这里的avail Mem与内存占用中的avail Mem意义不同,如果表示Swap的可用空间,则无需此列

下面白色那排扩展

|---------|----------------------------------------------|
| USER | 进程所有者的用户名 |
| PR | 优先级(由内核动态调整) |
| NI | nice 值(进程优先级)。负值表示高优先级,正值表示低优先级 |
| VIRT | 虚拟内存使用量(VSZ) |
| RES | 常驻内存使用量(RSS) |
| SHR | 共享内存大小(kb) |
| S | 进程状态(D=不可中断的睡眠,R=运行/可运行,S=睡眠,T=已跟踪/已停止,Z=僵停) |
| %CPU | CPU 时间占用百分比 |
| %MEM | 使用的物理内存百分比 |
| TIME+ | 使用的 CPU 时间总计(单位:1/100 秒) |
| COMMAND | 命令名/命令行 |

1.2.2.1、实验

当我运行I/O的时候,wa占用

dd if=/dev/zero of=/mnt/a.txt count=19 bs=100M

又恢复成

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

默认 3s 刷新一次,按 s 修改刷新时间按空格 :立即刷新。

P:按 CPU 排序

M:按内存排序

T:按时间排序

p: 进程 IP,查看某个进程状态

N 键根据启动时间进行排序

数字键 1:显示每个内核的 CPU 使用率

u/U:指定显示的用户

h:可以获得 top 程序的在线帮助信息

q:键可以正常地退出 top 程序

注:若通过 top 排名工具发现某个进程 CPU 占用率非常高,需要终止该进程的运行,可以在 top 操作界面中按 k 键,然后在列表上方将会出现"PID to signal/kill [default pid = 3180]:" 的提示信息,根据需要输入指定进程的 PID 号并按 Enter 键, 出现"Send pid 输入的能够ID signal [15/sigterm]"的二次确认的提示信息,然后按Enter 键确认即可终止对应的进程。

1.2.3、pgrep根据特定条件查询进程pid信息

pgrep -参数

常用的参数

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

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

结合以下常用的参数使用:

  • -p:选项使用时可以同时列出对应的PID号
  • -u:选项可以列出对应的用户名
  • -a:选项可以列出完整的命令信息

执行如下的"pstree -aup"命令可以查看当前系统的进程树,包括各进程对应的PID 号、用户名、完整命令等信息。从输出结果中可以看出,systemd 进程确实是 Linux 操作系统中所有进程的"始祖"。

二、控制进程

2.1、进程的启动方式

手工启动

  • 前台启动:用户输入命令,直接执行程序
  • 后台启动:在命令行尾加入"&"符号

例如,当使 用 cp 命令从光盘中制作镜像文件时,由于需要复制的数据较多,耗时较长,因此可结合"&" 符号将复制操作放到后台运行,以便用户可以继续执行其他命令操作。

输出信息中包括后:台任务序号【1】,pid号 35489

调度启动

在服务器维护工作中,经常需要执行一些比较费时而且较占用资源的任务(如数据备份),这些任务更适合在相对空闲的时候(如夜间)进行。这时就需要用户事先进行调度安排 ,指定任务运行的时间,当系统到达设定时间时会自动启动并完成指定的任务。调度启动的计划 任务进程均在后台运行,不会占用用户的命令终端。

进程的调度启动可以通过 at、crontab 命令进行设置,其中 at 命令用于设置一次性(如12:15 时重启网络服务)计划任务,crontab 命令用于设置周期性运行(如每周五 17:30 备份数据库)的计划任务。

2.2、进程的前后台调度

2.2.1、挂起当前的进程

当Linux操作系统中的命令正在前台执行时(运行尚未结束),按Ctrl+Z组合键可以将当前进程挂起(调入后台并停止执行),这种操作在需要暂停当前进程并进行其他操作时特别有用。例如,打包usr并且调入后台 ,可以按 Ctrl+Z 组合键将该下载任务调入后台并暂停执行

tar czvf usr.tar.gz /usr

2.2.2、jobs命令查看处于后台的任务列表

常用的参数

-l:选项可以同时显示该进程对应的PID号

job -l

查看处于后台的任务列表

2.2.3、fg、bg命令将后台的进程恢复运行

使用 bg(BackGround,后台)命令,可以将后台中暂停执行(如按 Ctrl+Z 组合键挂起)的任务恢复运行,继续在后台执行操作;(注意就不能再停止了)

使用 fg 命令(ForeGround,前台),可以将后台任务重新恢复到前台运行。

除非后台中的任务只有一个,否则 bg 和 fg 命令都需要指定后台进程的任务编号作为参数。

2.3、终止进程执行

当用户在前台执行某个进程时,可以按Ctrl+C组合键强制进行中断(如命令长时间没有响应的情况下)。

中断前台进程的运行后,系统将返回命令行提示符状态等待用户输入新的命令。

当按 Ctrl+C 组合键无法终止程序或者需要结束在其他终端或后台运行的进程时, 可以使用专用的进程终止工具 kill、killall 和 pkill。

2.3.1、使用 kill 命令终止进程

通过 kill 命令终止进程时,需要使用进程的 PID 号作为参数。无特定选项时,kill 命令将给该进程发送终止信号并正常退出运行,若该进程已经无法响应终止信号,则可以结合"-9" 选项强行终止进程。强制终止进程时可能会导致程序运行的部分数据丢失,因此不到不得已时不要轻易使用"-9"选项。(但是一般还是会用)

例如,若 SSH 服务的 sshd 进程的 PID 号为 93333,则执行"kill 93333"命令后可以将进程 sshd 终止

2.3.2、使用 pkill 命令终止进程

三、at一次性任务设置

一次性计划任务

在 Linux 操作系统中,除了用户即时执行的命令操作以外,还可以配置在指定的时间、指定的日期执行预先计划的系统管理任务(如定期备份、定期采集监测数据)。CentOS 系统中默认已安装了 at、cronie 软件包,通过 atd 和 crond 这两个系统服务实现一次性、周期性计划任务的功能,并分别通过 at、crontab 命令进行计划任务设置

使用at命令设置的计划任务只在指定的时间点执行一次,前提是对应的系统服务atd必须已经运行。需要注意的是,计划执行任务的时间、日期必须安排在当前系统的时刻之后, 否则将无法正确设置计划任务。

设置一次性计划任务时,在 at 命令行中依次指定计划执行任务的时间、日期作为参数(若只指定时间则表示当天的该时间,若只指定日期则表示该日期的当前时间),确认后将进入带"at>"提示符的任务编辑界面,每行设置一条执行命令,可以依次设置多条语句,最后按 Ctrl+D 组合键提交任务。所设置的命令操作将在计划的时间点被依次执行。

格式

at [HH:MM] [yyyy-mm-dd]

任务设置完毕后按Ctrl+D 组合键提交

如果错误,修改用ctrl+删除修改内容

3.1、实验

以下操作将设置一条计划任务,在当天的 21:30 自动关闭当前系统。

3.2、查询计划和删除计划

可以通过 atq 命令进行查询

用atrm +任务号 删除

四、crontab周期性任务设置

crontab命令

按照预先设置的时间周期 (分钟,小时,天。.....)重复执行用户指定的命令操作,属于周期性计划任务。

/etc/crontab 文件中设置的是维护 Linux 操作系统所需的任务,Linux 操作系统及相关程序在安装时可自动设置,不建议用户手动修改此文件。

该文件中包括设置 Shell 环境、可执行路径等变量的操作,以及每小时、每天、每周、每月需要执行的任务目录。执行如下的"cat /etc/crontab"命令可以查看/etc/crontab 文件的具体内容。

4.1、管理crontab计划任务

编辑计划任务

crontab -e【-u用户名】

查看计划任务

crontab -i【u用户名】

删除计划任务

crontab -r【-u用户名】

crontab -u 用户名 #指定XX用户的cron服务

crontab -l #列出当前用户下的cron的详细内容

crontab -u zx -l #列出zx用户下的cron的详细内容

crontab -r #删除所有用户的cron内容,普通用户执行,只删除自己的cron内容

crontab -r -u zx #删除zx用户的cron内容

crontab -e #编辑cron服务

4.1.1、-e编辑内容格式

50 3 2 1 * run command

分钟 小时 日期 月份 星期 命令

分时日月周

4.2、时间数值的特殊表示方法

  • *表示该范围内的任意时间
  • 减号"-":可以表示一个连续的时间范围,如"1-4"表示整数 1、2、3、4。
  • 逗号",":可以表示一个间隔的不连续范围,如"3, 4, 6, 8"。
  • 斜杠符号"/":可以用来指定间隔频率,如在日期字段中的"*/3"表示每隔 3 天。

示例

4.3、实验

普通用户执行"crontab -e"命令时,可以设置自己的计划任务(需要注意命令的执行权限)。

例如,用户 yc666设置一条计划任务:

在每晚上的 18:36 将/etc/passwd 文件的内容复制到宿主目录中,保存为 pwd.txt 文件

因各条计划任务在执行时并不需要用户登录,所以任务配置记录中的命令建议使用绝对路径,以避免因缺少执行路径而无法执行命令的情况。另外,在设置非每分都执行的任务时, "分钟"字段也应该填写一个具体的时间数值,而不要保留为默认的"*",否则将会在每分钟执行一次计划任务。

在root下可以-u查看其他人计划

补充

crontab -e:编辑的是当前系统用户作为执行者的的定时任务

conrtab -l:查看当前用户的定时任务

/etc/cronatab:是系统级别,可以包含所有用户的定时任务

其他的一些例子

例如,若要按固定的周期重复完成一些系统管理任务,任务内容如下:

①每天早上 7:50自动开启 sshd 服务,22:50 关闭 sshd 服务;

②每隔五天清空一cron 次 FTP 服务器公共目录/var/ftp/pub 中的数据;

③每周六的 7:30 重新启动系统中的 httpd 服务;

④每周一、周三、周五的下午 17:30,使用 tar 命令自动备份/etc/httpd 目录,则可由 root 用户通过 crontab 设置以下计划任务。

例如,若要按固定的周期重复完成一些系统管理任务,任务内容如下:①每天早上 7:50
自动开启 sshd 服务,22:50 关闭 sshd 服务;②每隔五天清空一cron		次 FTP 服务器公共目录
/var/ftp/pub 中的数据;③每周六的 7:30 重新启动系统中的 httpd 服务;④每周一、周三、周五的下午 17:30,使用 tar 命令自动备份/etc/httpd 目录,则可由 root 用户通过 crontab 设置以下计划任务。


[root@localhost ~]# crontab -e
50 7 * * * /usr/bin/systemctl start sshd.service 
50 22 * * * /usr/bin/systemctl stop sshd.servic 
0 0 */5 * * /usr/bin/rm -rf /var/ftp/pub/*
30 7 * * 6 /usr/bin/systemctl httpd restart
30 17 * * 1,3,5 /usr/bin/tar jcf httpdconf.tar.bz2 /etc/httpd/
*/2 * * * * ls -lh /home/*
相关推荐
LIKEYYLL1 小时前
GNU Octave:特性、使用案例、工具箱、环境与界面
服务器·gnu
云云3212 小时前
搭建云手机平台的技术要求?
服务器·线性代数·安全·智能手机·矩阵
云云3212 小时前
云手机有哪些用途?云手机选择推荐
服务器·线性代数·安全·智能手机·矩阵
cominglately2 小时前
centos单机部署seata
linux·运维·centos
魏 无羡2 小时前
linux CentOS系统上卸载docker
linux·kubernetes·centos
CircleMouse2 小时前
Centos7, 使用yum工具,出现 Could not resolve host: mirrorlist.centos.org
linux·运维·服务器·centos
Karoku0663 小时前
【k8s集群应用】kubeadm1.20高可用部署(3master)
运维·docker·云原生·容器·kubernetes
木子Linux3 小时前
【Linux打怪升级记 | 问题01】安装Linux系统忘记设置时区怎么办?3个方法教你回到东八区
linux·运维·服务器·centos·云计算
mit6.8243 小时前
Ubuntu 系统下性能剖析工具: perf
linux·运维·ubuntu
鹏大师运维3 小时前
聊聊开源的虚拟化平台--PVE
linux·开源·虚拟化·虚拟机·pve·存储·nfs