【Linux】进程和计划任务管理

目录

一、程序和进程

1.程序

2.进程

3.线程与进程

二、查看系统进程

1.ps-静态查看系统进程

  2.top-查看进程动态信息

3.pgrep-根据特定条件查询进程pid信息

4.pstree-查看进程树

三、控制进程

1.进程的启动方式

手工启动

调度启动

2.进程的前后台调度

3.终止进程

Ctrl+C组合键

kill、killall命令

pkill命令

四、计划任务管理

1.at-一次性计划任务

2.crontab-周期性计划任务


一、程序和进程

1.程序

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

静态保存的代码

2.进程

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

动态执行的代码

父、子进程

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

3.线程与进程

        进程是程序的一次执行,它是资源分配和管理的基本单位,包括代码、数据、堆栈、文件句柄等。
        线程是进程中的一个执行流程,是CPU调度的基本单位,共享进程的资源,包括内存、文件和其他系统资源。
        进程之间通常是相互独立的,每个进程有独立的内存空间,通过进程间通信(IPC)来实现数据共享和通信。
        线程之间共享相同的地址空间和其他进程资源,线程之间的数据共享和通信更为方便。

二、查看系统进程

1.ps-静态查看系统进程

    常用选项

a 显示当前终端下的所有进程信息,包括其他用户的进程
u 使用以用户为主的格式输出进程信息
x     显示当前用户在所有终端下的进程信息
-e 显示系统内的所有进程信息
-l 使用长格式显示进程信息
-f   使用完整的格式显示进程信息
-a 显示现行终端下的所有进程
-T 查看线程信息
–sort 属性 对属性排序,属性前加-表示倒序

ps aux-各列解释

USER 进程的用户
PID 进程的ID
%CPU 进程占用的CPU百分比,占用越高,进程越耗费资源
%MEM 占用内存的百分比
VSZ 该进程使用的虚拟内存量(KB)
RSS 该进程占用的实际物理内存量(KB)
TTY 启动进程的终端名。不是从终端启动的进程则显示为 ?
STAT

该进程的状态:

D:不可中断的休眠状态;

R:正在运行状态;

S:处于休眠状态,可被唤醒;

T:停止状态,可能是在后台暂停或进程处于跟踪调试状态;

Z:僵尸进程,进程已经中止,但是部分程序还在内存当中

START 该进程被启动时间
TIME 该进程实际使用CPU的时间
COMMAND 进程的名称与参数
[root@localhost ~]# ps -aT     #显示所有线程
 
[root@localhost ~]# ps -T -p <pid>       #查看指定进程中已经起的线程
 
[root@localhost ~]# ps -L <pid>      #查看指定进程中的线程信息

[root@localhost ~]#ps aux --sort -%cpu | head -10       #按cpu降序排列,-为降序,+为升序,p与%同义

[root@localhost ~]#ps aux --sort +pmem | head -n 10      #按内存升序排列

[root@localhost ~]#ps aux --sort -pcpu,+pmem | head -n 10

各列解释

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

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


  2.top-查看进程动态信息

常用命令

P 键 根据CPU使用百分比大小进行排序
M 键 根据驻留内存大小进行排序
N 键 根据启动时间进行排序
c 键 切换显示命令名称和完整命令行
h 键 可以获得 top程序的在线帮助信息
k 键 根据提示输入指定进程的 PID 号并按 Enter 键终止对应的进程
q 键 退出 top 程序
数字1 键 显示CPU个数和状态
[root@localhost ~]#top -H        #显示所有线程

[root@localhost ~]#top -H -p <pid>        #显示特定进程中的线程

  
 第一行:任务队列信息

11:06:48 系统时间
up 1:22 系统已运行时长
1 user 当前登录用户数
load average: 0.06, 0.60, 0.48 系统负载,即单位时间内系统处理的任务数,后面三个数值分别为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 可用物理空间

CPU使用率和CPU负载:
CPU使用率是指CPU在某个时间段内被使用的比例,以百分比表示。反映了CPU的使用强度
CPU负载是指CPU正在处理的任务数或等待CPU处理的任务数。反映了系统中的任务繁忙程度

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

3.pgrep-根据特定条件查询进程pid信息

[root@localhost ~]# pgrep -l "-log"    #-l:显示进程名  缺省时只输出PID号
 
2538 rsyslogd
 
2113 mcelog

 
[root@localhost ~]# pgrep -l -U teacher -t tty2   #-U:指定特定用户 -t:指定终端
 
27483 bash
 
27584 vim

4.pstree-查看进程树

-a 显示完整信息
-u 列出对应用户名
-p 列出对应pid号

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

三、控制进程

1.进程的启动方式

手工启动

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

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

调度启动

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

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

2.进程的前后台调度

Ctrl+Z组合键 将当前进程挂起,即调入后台并停止执行
jobs [-l] 查看处于后台的任务列表
fg+序号 将后台的进程恢复到前台运行,可指定任务序号

3.终止进程

Ctrl+C组合键

        中断正在执行的命令

kill、killall命令

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

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

        -9选项用于强制终止

kill是如何杀掉进程的?  向进程发送信号的方式杀掉进程

kill 默认选项为 -15,发送信号 SIGTERM,表示告诉进程自行停止运行并退出,进程可以忽略
kill -9 发送信号 SIGKILL,表示进程要立即退出,且不能被捕捉或忽略
kill -3 发送信号 SIGQUIT,表示进程自行退出,并打印进程各个线程的堆栈信息,保存路径为 /proc/${pid}/cwd,文件名为 antBuilderOutput.log
kill -1 发送信号 SIGHUP,表示进程重新加载配置文件,不退出
pkill命令

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

pkill <关键词> -U <用户名> -t <终端>            #U:根据进程所属的用户名终止相应进程;-t:根据进程所在的终端终止相应进程

[root@localhost ~]# pgrep -l -U "teacher"
 
3045 bash
 
[root@localhost ~]#pkill -9 -U "teacher"
 

四、计划任务管理

1.at-一次性计划任务

at HH:MM [yyyy-mm-dd] --> 输入命令列表 --> ctrl + d 提交任务 --> atq 查看没执行的任务列表和序号 --> atrm <序号> 删除指定的任务

[root@localhost ~]# date
 
Sun May 7 10:33:13 EDT 2017
 
[root@localhost ~]# at 10:35 2017-05-07
 
at> pgrep -U root |wc -l>/tmp/ps.root
 
at> <EOT>                                     #按Ctrl+D键提交任务
 
job 1 at Sun May 7 10:35:00 2017
 
[root@localhost ~]# cat /tmp/ps.root
 
202 

2.crontab-周期性计划任务

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

启动周期性任务必须确认对应的系统服务crond已经运行

crontab -e [-u 用户]    --> 自动对应文件  /var/spool/cron/用户名

分  时  日  月  周   执行命令或脚本路径

分 0 ~ 59  
时 0 ~ 23
日 1 ~ 31
月 1 ~ 12
周 0 ~ 7   , 0 和 7 都代表 周日

符号 说明
* 表示该范围内的任意时间
表示间隔的多个不连续的时间点
- 表示一个连续的时间范围
/ 指定间隔的时间频率 (写在第一个 */2 每隔2分钟)

相关推荐

最近更新

  1. TCP协议是安全的吗?

    2024-04-22 00:20:03       16 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-04-22 00:20:03       16 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-04-22 00:20:03       15 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-04-22 00:20:03       18 阅读

热门阅读

  1. Leetcode 104. 二叉树的最大深度

    2024-04-22 00:20:03       13 阅读
  2. 突破编程_C++_网络编程(Boost.Asio(简介))

    2024-04-22 00:20:03       13 阅读
  3. 【C++刷题】优选算法——动态规划第四辑

    2024-04-22 00:20:03       15 阅读
  4. 【LeetCode热题100】【动态规划】最长递增子序列

    2024-04-22 00:20:03       14 阅读
  5. 2015NOIP普及组真题 2. 扫雷游戏

    2024-04-22 00:20:03       11 阅读