linux进程管理
什么是进程/线程
1. 进程/线程
程序和进程:
程序是静态的代码文件,进程是指程序运行时的形态。
进程是程序的一个副本。
进程是有生命周期的(准备期,运行期,终止期)。
进程是资源调用的最小单位
线程:
因为cpu不再是单核,有了多个核心所以有了线程。
程序执行流是从上倒下贯穿运行的,当进程是多任务物,cpu是多核心,多任务应该同时被每个核心处理,每个核心处理的任务叫线程。
一个进程被分为多个线程,多个核心可以同时处理多个线程,减少进程占用cpu时间,加快运行速率。
线程资源是共享的。
线程是进程的最小单位。
2. 进程状态
详细讲解可看:https://blog.csdn.net/shenwansangz/article/details/51981459#google_vignette
R(TAKS_RUNNING) :可执行状态(running,ready)
分为两种:
1. 正在CPU上执行的进程,即RUNNING状态。
2. 可执行但是尚未被调度执行的进程,即READY状态。
S(TASK_INTRRUPTABLE) :可唤醒休眠/可中断的睡眠状态
处于这个状态的进程因为等待某某事件的发生(比如等待socket连接、等待信号量),而被挂起。
一般情况下,进程列表中的绝大多数进程都处于此状态。
D(TASK_UNINTRRUPTABLE) :不可唤醒休眠/不可中断的睡眠状态
进程处于睡眠状态,但是此刻进程是不可中断的。不可中断,指的并不是CPU不响应外部硬件的中断,而是指进程不响应异步信号。
而TASK_UNINTERRUPTIBLE状态存在的意义就在于,内核的某些处理流程是不能被打断的。
kill-9也杀不死。
T(TASK_STOPPED or TASK_TRACED) :暂停状态或跟踪状态
1. 暂停状态:
向进程发送一个SIGSTOP信号,它就会因响应该信号而进入TASK_STOPPED状态,发送一个SIGCONT信号,可以让其从TASK_STOPPED状态恢复到TASK_RUNNING状态。
2. 跟踪状态:
进程暂停下来,等待跟踪它的进程对它进行操作。比如在gdb中对被跟踪的进程下一个断点,进程在断点处停下来的时候就处于TASK_TRACED状态。
处于TASK_TRACED状态的进程不能响应SIGCONT信号而被唤醒。
Z(TASK_DEAD - EXIT_ZOMBIE):退出状态,然后进程成为僵尸进程
在进程退出的过程种,进程占有的所有资源将被回收,除了task_struct结构(以及少数资源)以外。于是进程就只剩下task_struct这么个空壳,故称为僵尸进程。
X(TASK_DEAD - EXIT_DEAD),退出状态,进程即将被销毁
进程被立刻彻底的释放。
查看进程
1. 图形化界面查看
gnome-system-monitor命令或者如图手动打开
2. ps进程查看
ps 命令有三种执行风格 :UNIX、BSD、GNU
##带-和不带-相同字母含义不同!!!
##下述命令都可以用 管道符 less
命令来方便查看。
##下述命令可以用grep命令来筛选想看的进程
- BSD风格:
a ##与终端相关的进程(当用户登陆系统后产生的进程都是带终端的)
x ##与终端无关相关的进程
u ##用户信息归类的查看方式
上图名称代表的意思:
f ##进程层级关系ps aux 显示信息如下: USER 进程所有人 PID 进程id %CPU 进程使用cpu的用量 %MEM 进程所用到的内存用量 VSZ 进程使用的虚拟内存大小 RSS 进程常驻内存中的数据大小 #被多个程序使用,所以常驻 TTY 进程用到的终端 STAT 进程状态 START 进程运行时长 TIME 进程占用cpu时长 COMMAND 进程名称
o ##显示指定参数如 pid comm nice pri pcpu ppid
- UNIX风格
-e ##显示所有进程
-f ##显示信息的完整格式
-H ##显示进程的层级结构
-o ##显示指定参数,和BSD风格的用法一样
--sort=
##排序,默认从小到大,加上负号表示从大到小排
3. pgrep进程过滤
-u uid ##显示指定用户进程
-U user ##显示指定用户进程
-t tty ##显示指定终端进程
-l ##显示进程名称
-a ##显示进程的完整名称
-P ##显示进程的子进程
4. pidof查看进程号pid
pidof vim ##查看vim的pid
5. top动态查看进程!!!
输入top以后显示的界面:
第一行显示的内容为:
21:42:28 系统时间
up 49min 运行时长
1 users 系统中有1个用户登陆
load average: 0.34, 0.09, 0.03
负载(cpu队列中任务等待的时间1、5、15分钟内的平均进程数):1min之内平均有0.34个进程在等待 5min之内平均有0.09个进程在等待 15min之内平均有0.03个进程在等待
第二行Tasks显示内容:
322 total 任务总量,共有322个进程
1 running 1个进程正在运行
321 sleeping 321个进程正在休眠
0 stopped 0个进程被暂停
0 zombie 0个进程处于僵尸状态
第三行%Cpu(s)显示内容:
0.3 us 用户空间占用cpu百分比
0.0 sy 内核空间占用cpu百分比
0.0 ni 用户进程空间内改变过优先级的进程占用CPU百分比
99.3 id 有99.3%的处理器资源处于空闲
0.0 wa 等待io(输入输出)的时间
0.3 hi 处理硬件中断时间
0.0 si 处理软件中断时间
0.0 st 被偷走的时间(虚拟机占用cpu的时间)
第四行MiB Mem显示内容:
1800.6 total 总量
138.4 free 空闲
1265.1 used 占用
397.1 buff/cache 缓存
buff:
指的是在程序中生成数据,最后要保存下来写到硬盘里。内存到硬盘。处理完的结果放buff。
比如说用vim写一个文件,在还没保存的时候,是放到buff里的。
cache:
执行一个命令,cpu给cache,cache再从硬盘里调用所需文件。
第五行MiB Swap显示内容: 交换分区用量
从硬盘上开辟一个分区,存放内存暂时不用的数据。
下面列表名指的是:
PID 进程id
USER 进程所有者的用户名
PR 优先级
NI nice值。负值表示高优先级,正值表示低优先级
VIRT 进程使用的虚拟内存总量,单位kb。VIRT=SWAP+RES(分区+真实)
RES 进程使用的、未被换出的物理内存大小,单位kb。(真实内存)RES=CODE+DATA
SHR 共享内存大小,单位kb
S 进程状态(D=不可中断的睡眠状态,R=运行,S=睡眠,T=跟踪/停止,Z=僵尸进程)
%CPU 上次更新到现在的CPU时间占用百分比,即cpu占用率
%MEM 进程使用的物理内存百分比
TIME+ 进程使用的CPU时间总计,单位1/100秒
COMMAND 命令名/命令行
top命令的参数:
-d ##指定刷新频率,默认刷新频率是3秒一次
-b ##以批次方式显示,不是一个页面实时刷新
-b -n 2 ##指定显示的批次数量,比如显示两批后退出
top内部指令:
P ##cpu排序(%CPU)
M ##内存排序(%MEM)
T ##累计占用cpu时间排序(TIME+)
l ##关闭/开启uptime信息(第一行内容)
t ##关闭/开启cpu&task
s ##指定刷新频率
k ##操作进程,按了后输入进程id,再输入进程信号(下边会讲)执行相应操作
u ##查看指定用户进程
进程信息号
1 ##重新加载系统配置文件(source),防止企业因重启产生的空档期而造成损失,进程号不会变,还是之前的进程。相当于不停服更新!
2 ##清空内存中的进程数据,比如在shell里输入一行字已被放入内存,想清空可以用信号2
3 ##清空内存中的鼠标(按ctrl+\
就消失,动下鼠标就出现) ,看视频鼠标会消失就是发送的信号3
9 ##强行结束进程(不能被阻塞,不管三七二十一直接关掉)
15 ##正常关闭进程(会被阻塞即拒绝,系统认为这个进程很重要还不能关闭)
18 ##运行被暂停的进程
19 ##暂停进程(不会被阻塞)
20 ##暂停进程(会被阻塞的)
进程信号控制工具:
kill 进程信号 pid
killall 进程信号 进程名字 ##可以批量处理
pkill 进程信号 进程条件
pkill举例:
进程前后台调用
<ctrl>+<z>
##把占用shell的进程打入后台挂起
bg ##把后台挂起的进程运行起来,但不会回到前台,不会占用shell
fg ##把后台进程调回前台运行
& ##运行进程在后台
jobs ##查看当前shell中在后台的所有工作
进程优先级
系统是多任务多用户的操作模式,任务的重要性是有区分的,如何确定任务的重要性,就要使用“优先级”。
优先级范围: 0–139
- 内核自控优先级范围:0-99 ##这是不可更改的,系统自己设定,除非对内核进行编译,在这个优先级范围内的进程都是实时进程
- 用户可控优先级:100-139 ##映射成nice值,共40个,用户可自己更改,这个范围内的进程都是非实时进程
静态优先级nice: -20到19
##-20对应100,19对应139。nice数值越小优先级越高,数值越大优先级越低
动态优先级priority:nice值设定好了之后,除非我们用renice去改它,否则它是不变的。而priority的值在之前内核的O1调度器上表现是会变化的,所以也叫做动态优先级。
renice -n -5 43331 ##更改优先级
nice -n -5 cat ##指定优先级打开进程
ps ax -o nice,pri,pid,stat,comm | grep cat ##查看进程优先级变化
上图stat中符号意思:
S sleeping
< 优先级高
s 顶级进程
T stop
N 优先级低
R running
+ 运行在前台