进程与计划任务管理

别裁伪体亲风雅,转益多师是汝师。这篇文章主要讲述进程与计划任务管理相关的知识,希望能为你提供帮助。
一、查看进程进程:指在系统中能独立运行并作为资源分配的基本单位,它是由一组机器指令、数据和堆栈等组成的,是一个能独立运行的活动实体。
进程是运行的程序
1.程序

  • 保存在硬盘、光盘等介质中的可执行代码和数据
  • 文件中静态保存的代码
2.进程
  • 在CPU及内存中运行的程序代码
  • 动态执行的代码
  • 父、子进程:
每个程序可以创建一个或多个进程
3.线程
1、一个进程可以有多个线程,但至少有一个线程;而一个线程只能在一个进程的地址空间内活动; 一个线程可以创建和撤销另一个线程; 同一个进程中的多个线程之间可以并发执行。
2、资源分配给进程,同一个进程的所有线程共享该进程所有资源。
3、CPU分配给线程,即真正在处理器运行的是线程。
4、线程在执行过程中需要协作同步,不同进程的线程间要利用消息通信的办法实现同步。
注:进程是操作系统最基本的资源拥有单位和调度单位,线程是程序执行的最小单位;通常都是把进程作为分配资源的基本单位,而把线程作为独立运行和独立调度的基本单位。
进程间通信方式:(1)消息传递(2)共享存储(3)管道通信
4.查看进程命令
1.ps命令
查看静态的进程统计信息
ps aux
a:显示终端上的所有进程,包括其他用户的进程
u:表示列出进程的用户
x:显示所有终端的进程
各列的解释
USER:进程的用户
PID:进程的ID。
%CPU:进程占用的CPU百分比。
%MEM:占用内存的百分比。
VSZ:该进程使用的虚拟内存量(KB) 。
RSS:该进程占用的物理内存量(KB) 。
TTY:启动进程的终端名。不是从终端启动的进程则显示为? pts代表使用远程连接工具
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会回收其占用的相关资源。
但是当子进程比父进程先结束,而父进程又没有回收子进程,释放子进程占用的资源,此时子进程将成为一个僵尸进程。


2.top命令
查看动态的进程排名信息top
会动态更新 默认为5秒一更新
第一行 任务队列信息
13:009:58 系统时间up 1 day,4:40 系统已运行时长 1 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命令名/高令行
常用命令:
P键:根据CPU使用百分比大小进行排序
M键:根据驻留内存大小进行排序
N键:根据启动时间进行排序
C键:切换显示命令名称和完整命令行
h键:可以获得top程序的在线帮助信息
k键:根据提示输入指定进程的PID号并按Enter键终止对应的进程
q键:退出top程序
数字1键:显示cPu个数和状态
top -H:显示所有线程
top -H -p < pid> :显示特定进程中的线程


查看load average的方法
top;w;uptime
3.pgrep 命令
根据特定条件查询进程PID信息
pgrep ssh -l【-l 显示进程名 不加只输出PID号 】
【-U 指定特定用户 -t指定终端】


4.pstree 命令
以树形结构列出进程信息
pstree -auppstree -ap tyx 指定用户显示
-a:显示完整信息
-u:列出对应用户名
-p:列出对应PID号



二、进程的控制1.手动启动
  • 前台启动:用户输入命令,直接执行程序
  • 后台启动:在命令行尾加入“& ”符号
cp -r /mnt /root/& 内容过大时进行后台处理
jobs -l 可用来查看

2.调度启动
  • 使用at命令,设置一次性计划任务
  • 使用crontab命令,设置周期性任务
Ctrl+Z组合键:将当前进程挂起,即调入后台并停止执行
jobs命令:jobs [-l]查看处于后台的任务列表
fg命令:将后台进程恢复到前台运行,可指定任务序号



3.终止进程的运行
  • Ctrl+C组合键:中断正在执行的命令
  • Kill、Killall命令
Kill用于终止指定PID号的进程
killall用于终止指定名称相关的所有进程
-9选项用于强制终止 (默认为15)
  • pkill命令
  1. 根据特定条件终止相应的进程
  2. 常用命令选项
-U
根据进程所属的用户名终止相应进程
-t
根据进程所在的终端终止相应的进程
【进程与计划任务管理】

    推荐阅读