进程和计划任务管理

目录

  • 程序和进程的关系
  • 查看进程消息
  • 启动进程
  • 计划任务管理

程序和进程的关系

程序

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

文件中静态保存的代码

进程

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

动态执行的代码

父、子进程,每个程序可以创建一个或多个进程

线程

线程是操作系统能够进行运算调度的最小单位

它被包含在进程之中,是进程中的实际运作单位

一条线程指的是进程中一个单一顺序的控制流,一个进程中可以并发多个线程,每条线程并行执行不同的任务

多个线程共享同一块内存,通过共享的内存空间来进行交互

线程是进程的一条流水线, 只用来执行程序,而不涉及到申请资源是程序的实际执行者最小的执行单元

 

查看进程信息

查看静态的进程统计信息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∶进程的启动命令。

 进程和计划任务管理

 

方法二∶

格式: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

top 命令——查看进程动态信息

 

第一行是任务队列信息

11∶06∶48——系统时间

up 1∶22——系统已运行时长

1 user——当前登录用户数 

load average: 0.06, 0.60,0.48

系统负载,即单位时间内系统处理的任务数,后面三个数值分别为1分钟、5分钟、15分钟前到现在的平均值Load average的值应该小于CPU个数X核数X0.7

 

第二行为 进程信息

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:优先级

Nl:谦让度值。 负值表示高优先级, 正值表示低优先级

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

 

top -H∶显示所有线程

top -H -p <pid>∶ 显示特定进程中的线程

 进程和计划任务管理

 

tty终端

Centos7系统,ttyl表示图形界面,tty2-tty6表示文字界面,可以用Ctrl+Alt+F1-F6切换。

pts说明是用远程工具连接的,比如xshell,后面的数字代表登录的时间顺序,越小证明登录的越早

 

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

格式:pgrep -l 参数

-l:显示进程名,缺省时只输出PID

-U:指定特定用户

-t:指定终端

例如:pgrep -llog

           pgrep -l -U teacher -t tty2——查询用户teachertty1终端上运行的进程及PID

 

查看进程树,以树形结构列出进程信息pstree

格式:pstree -aup

-a:显示完整信息

-u:列出对应用户名

-p:列出对应PID

例如:pstree -ap teacher 只查看指定用户teacher的进程树结构

进程和计划任务管理

 

启动进程

手工启动

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

例如:vim abc

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

例如:vim abc &

命令:iostat——查看磁盘读写

 

调度启动

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

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

进程的前后台调度

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

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

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

 进程和计划任务管理

进程和计划任务管理

 

终止进程的运行

Ctrl+C:中断正在执行的命令

kill:用于终止指定PID的进程

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

-9选项:用于强制终止(可能会造成一些未来及写入硬盘的进程数据丢失,谨慎使用)

pkill:根据特定条件终止相应的进程,大部分选项与pgrep相似,指定用户,指定终端等。

常用命令选项

-U:根据进程所属的用户名终止相应进程

-t:根据进程所在的终端终止相应进程

 

计划任务管理

at一次性计划任务

格式:at[HHMM][yyyy-mm-dd]

Ctrl+D提交任务

*HH为小时,MM为分钟,后面为年月日,如果为当天可以省略日期设置

 进程和计划任务管理

 

crontab命令

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

属于周期性计划任务

主要设置文件

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

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

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

 

编辑计划任务

格式:crontab -e [-u 用户名]

查看计划任务

格式:crontab -l [-u 用户名]

删除计划任务

格式:crontab -r [-u 用户名]

任务格式:* * * * * 命令

进程和计划任务管理

 

进程和计划任务管理

 

方法一

crontab -e[-u 用户名]

1.每分钟定时执行一次规则

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

每5分钟执行 */5 * * * *

2.每小时定时执行一次规则

每小时执行∶ 0 * * * *或者0 */1 * * *

每天上午7点执行0 7 * * *

每天上午7点10分执行 10 7 * * *

3.每天定时执行一次规则每天执行 0 0 * * *

4.每周定时执行一次规则每周执行 0 0 * * 1

5.每月定时执行一次规则每月执行 0 0 1 * *

6.每年定时执行一次规则每年执行 0 0 1 1 *

7.其他例子

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

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

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

30 5 8 6 * ls 指定每年的6月85∶ 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分钟执行1s命令]

30 6*/10 * * ls 每个月中,每隔10天6∶30执行一次1s命令[即每月的1、112131日是的6∶ 30执行一次1s命令。]

进程和计划任务管理

 

方法二∶

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

 

方法在配置文件/etc/crontab中写入

进程和计划任务管理

例如:vim /etc/crontab

30 6 * * 0 root /usr/bin/rm -rf /root/abc

保存退出

进程和计划任务管理

上一篇:进程管理 和 计划任务管理


下一篇:linux数据收集