Linux进程和计划任务管理

一、程序和进程的关系

1、程序

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

2、进程

  • 在CPU及内存中运行的程序代码
  • 动态执行的代码
    ◆父、子进程

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

补充:

进程:资源分配的最小单位

  • 进程 是程序执行时的一个实例,即它是程序已经执行到课中程度的数据结构的汇集。
  • 从内核的观点看,进程的目的就是担当分配系统资源(CPU时间、内存等)的基本单位

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

  • 线程 是CPU调度的最小单位(程序执行流的最小单元),它被包含在进程之中,是进程中的实际运作单元。
  • 一条线程是进程中一个单一顺序的控制流,一个进程中可以并发多个线程,每条线程并行执行不同的任务

僵尸进程:
僵尸进程 一个进程结束了,但是如果该进程的父进程已经先结束了,那么该进程就不会变成僵尸’进程,因为每个进程结束的时候,系统都会扫描当前系统中所运行的所有进程,看有没有哪个进程是刚刚结束的这个进程的子进程,如果是的话,就由Init来接管它,成为它的父进程,子进程退出后init会回收其占用的相关资源

但是当子进程比父进程先结束,而父进程又没有回收子进程,释放子进程占用的资源,此时子进程将成为一个僵尸进程

总的来说:进程有独立的地址空间,线程没有单独的地址空间(同一进程内的线程共享进程的地址空间)

二、查看进程信息 ps

ps命令

方法一:

查看静态的进程统计信息
ps aux

 

a: 显示终端上的所有进程,包括其它用户的进程
u:表示列出进程的用户
x: 显示所有终端的进程

各列解释:

USER: 进程的用户

PID: 进程的ID

%CPU: 进程占用的CPU百分比

%MEM: 占用内存的百分比

VSZ: 该进程使用的虚拟内存量(KB)

RSS: 该进程占用的物理内存量(KB)

TTY: 启动进程的终端名。不是从终端启动的进程则显示为?

STAT: 该进程的状态(D:不可中断的休眠状态;R:正在运行状态;S:处于休眠状态,可被唤醒;T:停止状态,可能是在后台暂停或进程处于跟踪调试状态;;Z:僵尸进程,进程已经中止,但是部分程序还在内存当中)

START: 该进程被触发启动时间

TIME: 该进程实际使用CPU运行的时间

COMMAND: 进程的启动命令

Linux进程和计划任务管理

Linux进程和计划任务管理

方法二:

查看静态的进程统计信息
ps -elf

 

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

各列解释:

F: 内核分配给进程的系统标记

S: 进程的状态

UID: 启动这些进程的用户

PID: 进程的进程ID

PPID: 父进程的进程号(如果该进程是由另一个进程启动的)

C:进程生命周期中的CPU利用率

PRI: 进程的优先级(越大的数字代表越低的优先级)

NI: 谦让度值用来参与决定优先级

ADDR: 进程的内存地址

SZ: 假如进程被换出,所需交换空间的大致大小

WCHAN: 若该进程在睡眠,则显示睡眠中的系统函数名

STIME: 进程启动时的系统时间

TTY: 进程启动时的终端设备

TIME: 运行进程需要的累计CPU时间

CMD: 进程的启动命令

Linux进程和计划任务管理

三、查看进程信息 top

1、top命令

查看动态的进程排名信息

top

 

第一行任务队列信息

12 : 00 : 30
系统时间

up 4:31
系统已运行时长

3 user
当前登录用户数

load average: 0.00, 0.01, 0.05
系统负载,即单位时间内系统处理的任务数,后面三个数值分别为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
命令名/命令行

Linux进程和计划任务管理

2、top常用命令:

P键: 根据CPU使用百分比大小进行拥序

M键: 根据驻留内存大小进行排序

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

c键: 切换显示命令名称和完整命令行

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

k键: 根据提示输入指定进程的PID号并按Enter 键终止对应的进程

q键: 退出top程序

数字1键: 显示CPU个数和状态

tty终端

Centos7系统,tty1表示图形界面,tty2-tty6表示文字界面,可以用Ctrl+Alt+F1-F6切换
pts说明是用远程工具连接的,比如xshell,后面的数字代表登录的时间顺序,越小证明登录的越早

查看线程 top -H;ps -T

Linux进程和计划任务管理

Linux进程和计划任务管理

Linux进程和计划任务管理

Linux进程和计划任务管理

四、查看进程信息 pgrep

pgrep命令

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

pgrep -l "log"
#-l 显示进程名,缺省时只输出PID号

pgrep -l -U 指定特定用户 -t 指定终端

 

Linux进程和计划任务管理

Linux进程和计划任务管理

Linux进程和计划任务管理

五、查看进程树 pstree

pstree 命令

以树形结构列出进程信息

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

pstree -ap 指定用户

 

Linux进程和计划任务管理

六、进程的启动方式

1、手工启动

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

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

cp /dev/cdrom mycd.iso &

 

Linux进程和计划任务管理

2、调度启动

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

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

七、进程的前后台调度

1、Ctrl + Z组合键

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

2、jobs 命令

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

 

3、fg 命令

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

fg 1

 

4、举例

Linux进程和计划任务管理

Linux进程和计划任务管理

八、终止进程的运行

1、Ctrl + C 组合键

中断正在执行的命令

2、Kill、Killall命令

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

Linux进程和计划任务管理

Linux进程和计划任务管理

Linux进程和计划任务管理

Linux进程和计划任务管理

3、pkill命令

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

  • 常用命令选项
    -∪: 根据进程所属的用户名终止相应进程
    -t: 根据进程所在的终端终止相应进程

pgrep -l -U "指定用户”
#查看
pkill -9 -U "指定用户”
#强杀
pgrep -l -U "指定用户”

 

Linux进程和计划任务管理

Linux进程和计划任务管理

Linux进程和计划任务管理

八、计划任务管理

1、at命令

一次性计划任务

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

atq
#查看未执行的任务列表

atrm 1
#删除第一条任务

 

Linux进程和计划任务管理

2、crontab 命令

  • 按照预先设置的时间周期 分钟、小时、天、月、周重复执行用户指定的命令操作按照预先设置的时间周期 分钟、小时、天、月、周重复执行用户指定的命令操作
  • 属于周期性计划任务
  • 主要设置文件

◆全局配置文件,位于文件: /etc/crontab
◆系统默认的设置,位于目录: /etc/cron.*/
◆用户定义的设置,位于文件: /var/spool/cron/用户名

管理crontab计划任务:
编辑计划任务
crontab -e [-u 用户名]
#-u缺省默认是针对当前用户

查看计划任务
crontab -l [-u 用户名]

删除计划任务
crontab -r [-u 用户名]

 

Linux进程和计划任务管理

Linux进程和计划任务管理

crontab任务配置格式:

分钟-小时-日期-月份-星期 命令或者脚本文件

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

周的数字为0或7时,都代表“星期天”的意思

时间数值的特殊表示方法

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

示例

? 0 17 * * 1-5
周一到周五每天17:00

? 30 8 * * 1,3,5
每周一、三、五的8点30分

? 0 8-18/2 * * *
8点到18点之间每2小时

? 0 * */3 * *
每3天

crontab -e [-u root]

① 每分钟定时执行一次规则:

每1分钟执行: * /1 * * * * 或者 * * * * *
每5分钟执行: * /5 * * * *

② 每小时定时执行一次规则

每小时执行: 0 * * * * 或者 0 * /1 * * *
每天.上午7点执行: 0 7 * * *
每天上午7点10分执行: 10 7 * * *

③ 每天定时执行一次规则:

每天执行 0 0 * * *

④ 每周定时执行一次规则:

每周执行 0 0 * *1

⑤ 每月定时执行一次规则:

每月执行 0 0 1 * *

⑥ 每年定时执行–次规则:

每年执行 0 0 1 1 *

其他例子

5 * * * * ls
指定每小时的第5分钟执行一次ls命令

30 5 * * * ls
指定每天的5:30执行ls命令

30 7 8 * * ls
指定每月8号的7: 30分执行ls命令

30 5 8 6 * ls
指定每年的6月8日5: 30执行ls命令

30 6 * * 0 ls
指定每星期日的6:30执行ls命令
[注: 0表示星期天,1表示星期1,以此类推,也可以用英文来表示,sun表示星期天,mon表示星期一等]

30 3 10,20 * * ls
每月10号及20号的3: 30执行ls命令
[注: “,"用来连接多个不连续的时段]

25 8-11 * * * ls
每天8-11点的第25分钟执行ls命令
[注: “-”用来连接连续的时段]

*/15 * * * * ls
每15分钟执行一次ls命令
[ 即每个小时的第 0 15 30 45 60分钟执行ls命令]

30 6 */10 * * ls
每个月中,每隔10天6:30执行一 次ls命令
[即每月的1、11、21、31日是的6: 30执行一次ls命令 ]

*/10 10-16 * 1,6 6 /usr/bin/ls -l
1,6月的每个周六从上午10点到下午的4点的每10分钟执行ls -l

方法二:

echo ‘30 7 * * 6 /usr/bin/systemctl httpd restart’ >> /var/spool/cron/ root

总结

  • 查看进程的命令(ps、 top、pgrep、 pstree)

  • 进程控制

启动进程、调度进程、终止进程

  • at命令 设置计划任务 (一次性任务)

  • crontab计划任务的配置字段 (周期性任务)

Linux进程和计划任务管理

上一篇:Linux系统启动过程


下一篇:性能基础之理解Linux系统平均负载和CPU使用率