进程和计划任务管理

一、查看进程

1、程序和进程的关系

(1)程序

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

(2)进程

在CPU及内存中运行的程序代码
动态执行的代码
父、子进程--每个程序可以创建一个或多个进程

2、查看进程信息

(1)ps命令

查看静态的进程统计信息
方法一:

       ps aux

常用选项 说明
a 显示终端上的所有进程,包括其他用户的进程
u 表示列出进程的用户
x 显示所有终端的进程
主要信息 说明
USER 进程的用户
PID 进程的ID
%CPU 进程占用的CPU百分比
%MEM 占用内存的百分比
VSZ 该进程使用的虚拟内存量(KB)
RSS 该进程占用的物理内存量(KB)
TTY 启动进程的终端名,不是从终端启动的进程则显示为?
STAT 该进程的状态(D:不可终端的休眠状态;S:处于休眠状态,可被唤醒;T:停止状态,可能是在后台暂停或进程处于跟踪调试状态;Z:僵尸进程,进程已经终止,但是部分程序还在内存当中)
  START
COMMAND 进程的启动命令
  • 注:TTY终端:CentOS 7系统中,tty1表示图形界面,tty2-tty6表示文字界面,可用Ctrl+Alt+F1-F6进行切换。pts说明是用远程工具连接的,比如xshell,后面的数字代表登录的时间顺序,数字越小证明登录的越早。
  • 注:僵尸进程--一个进程结束了,但是如果该进程的父进程已经先结束了,那么该进程就不会变成僵尸进程,因为每个进程结束的时候,系统都会扫描当前系统中所运行的所有进程,看有没有哪个进程是刚刚结束的子进程,如果是的话,就由init来接管它,成为它的父进程,子进程退出后init会挥手其占用的相关资源。但是当子进程比父进程先结束,而父进程又没有回收子进程,释放子进程占用的资源,此时子进程将成为一个僵尸进程。

方法二:

  ps -elf

 

常用选项 说明
-e 显示系统内的所有进程信息
-l 使用长格式显示进程信息
-f 使用完整的进程显示进程信息
-a 显示所有进程pid
-T 查看线程信息
主要信息 说明
F 内核分配给进程的系统标记
S 进程的进程
UID 启动这些进程的用户
PID 进程的进程ID
PPID 父进程的进程号(如果该进程是由另一个进程启动的)
C 进程生命周期中的CPU利用率
PRI 进程的优先级(越大的数字代表越低的优先级)
NI 谦让度值用来参与决定优先级
ADDR 进程的内存地址
SZ 加入进程被换出,所需交换空间的大致大小
WCHAN 若该进程在睡眠,则显示睡眠中的系统函数名
STIME 进程启动时的系统时间
TTY 进程启动时的终端设备
TIME 运行进程需要的累计CPU时间
CMD 进程的启动命令

(2)top命令

查看动态的进程排名信息

前五行说明:
第一行--任务队列信息

  • 11:06:48 #系统时间
  • up 1:22 #系统已运行时长
  • 1 user #当前登录用户数
  • load average:0.06,0.60,0.48 #系统负载,即单位时间内系统处理的任务数,后面三个数制分别为1分钟、5分钟、15分钟前到现在的平均值,也可通过w命令调出查看

第二行--进程信息

  • 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时间占用百分比
%MEN 进程使用的物理内存百分比
TIME+ 进程使用的CPU时间总计,单位1/100秒
COMMAND 命令名/命令行
常用命令 说明
P 根据CPU使用百分比大小进行排序
M 根据驻留内存大小进行排序
N 根据启动时间进行排序
c 切换显示命令名称进行排序
h 可以获得top程序的在线帮助信息
k 根据提示输入指定进程的PID号并按Enter键终止对应的进程
q 退出top程序
1 显示CPU个数和状态

top -H         #显示所有线程
top -H -p    #显示特定进程中的线程

(3)pgrp命令

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

常用选项 说明
-l 显示进程名(缺省时只输出PID号)
-U 指定特定用户
-t 指定终端

(4)pstree命令

以树形结构列出进程信息

常用选项 说明
-a 显示完整信息
-u 列出对应用户名
-p 列出对应PID号

pstree -ap 用户名 #只查看属于指定用户的进程数结构

二、控制进程

1、进程的启动方式

(1)手工启动

前台启动:用户输入命令,直接执行程序
后台启动:在命令行尾加入“&”符号,执行成功会显示任务序号以及PID号

(2)自动启动

at一次性启动
crontab周期性启动

2、进程的前后台调度

(1)Ctrl+Z组合键

将当前进程挂起

(2)jobs命令

jobs [-l]
查看处于后台的任务列表

(3)fg命令

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

3、终止进程的运行

(1)Ctrl+C组合键

中断正在执行的命令

(2)kill、killall命令

kill用于终止指定PID号的进程
killall用于终止指定名称相关的所有进程
-9选项用于强制终止

(3)pkill命令

根据特定条件终止相应进程
常用命令选项:
-U:根据进程所属的用户名终止相应进程
-t:根据进程所在的终端终止相应进程
-9:强制终止

三、at一次性任务设置

1、at命令(一次性任务)

一次性计划任务

2、一次性任务创建步骤

第一步:at [HH:MM] [yyyy-mm-dd]
第二步:输入指定命令
第三步:Ctrl+D提交任务
注:若不设定年月日将默认为当天启动

3、atq命令

查看未执行的任务列表及任务序号

4、atrm命令

删除指定未执行任务
格式为:atrm 任务序号

四、crontab周期性任务设置

1、crontab命令(周期性任务)

按照预先设置的时间周期(分时日月周)重复执行用户指定的命令操作
属于周期性计划任务
主要设置文件:
全局配置文件,位于文件:/etc/crontab
系统默认的设置,位于目录:/etc/ron.*/
用户定义的设置,位于文件:/var/spool/cron/用户名

2、管理contab计划任务

(1)编辑计划任务

crontab -e [-u 用户名]

(2)查看计划任务

crontab -l [-u 用户名]

(3)删除计划任务

crontab -r [-u 用户名]

3、crontab任务配置格式

配置格式为:时间周期设置 任务内容设置
时间设置格式:分 时 日 月 周
任务内容设置:命令或者脚本文件(命令最好通过绝对路径表示)

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

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

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

例如:
0 17 * * 1-5表示每周一到周五每天17点整
30 8 * * 1,3,5表示每周一、三、五的8点30分
0 8-18/2 * * *表示每天8点到18点之间的每两个小时
0 * */3 * *表示每3天的每个整点

5、设置周期任务的三种方式

(1)crontab -e编辑

30 1 * * * /usr/bin/cp -a /var/log/messages /root/log-$(date +%Y%m%d)
每天1点半将系统日志复制到root目录下并重命名为log加日期标注(避免覆盖)
常用日期表达命令有:
date +%F显示格式为YYYY-MM-DD,例如:2021-06-24
date +%Y%m%d显示格式为YYYYMMDD,例如:20210624

(2)echo重定向追加

echo '30 1 * * * /usr/bin/cp -a /var/log/messages /root/log-$(date +%Y%m%d)' >> /var/spool/cron/root

(3)vim /etc/crontab编辑

不同于前两种方式,此方法需指定执行任务的用户,且无法通过crontab命令进行查看、编辑以及删除,如需操作需进入/etc/crontab,编辑格式如下:
30 1 * * * root /usr/bin/cp -a /var/log/messages /root/log-$(date +%Y%m%d)

上一篇:LINUX留后门--教程(五)—— crontab隐藏后门


下一篇:Crontab 权限不够 crontab: edits left in /tmp/crontab.HaZsu1