linux中的进程管理
一、进程定义
1.进程的定义:
1)程序是静态的代码文件
2)进程是指程序运行时的形态
3)进程是程序的一个副本
4)进程是有生命周期的(准备期,运行期,终止期)
2.进程与线程:
1)进程是资源调用的最小单位,而线程是进程的最小单位
2)程序执行流是从上倒下贯穿运行的
3)当进程是多任务物,cpu是多核心,多任务应该同时被每个核心处理,每个核心处理的任务叫线程,线程资源是共享的。
3.进程状态
进程状态 | |
---|---|
R(TAKS_RUNNING) | 可执行态(running,ready) |
S(TASK_INTRRUPTABLE) | 可唤醒休眠 |
D(TASK_UNINTRRUPTABLE) | 不可唤醒休眠 |
T(TASK_STOP) | 暂停状态 |
Z(EXIT_ZOMBIE) | 僵死态 |
二.进程查看命令
gnome-system-monitor 图形进程查看工具
pidof vim 查看vim的pid
ps
ps | 进程查看 |
---|---|
unix bsd GNU | ps 命令的三种执行风格 |
a | 与终端相关的进程(当用户登陆系统后产生的进程都是带终端的) |
x | 与终端无关相关的进程 |
u | 用户信息归类的查看方式 |
f | 用进程层级关系 |
o | 显示指定参数 pid comm nice pri pcpu ppid stat user group |
-e | 显示所有进程 |
-f | 显示信息的完整格式 |
-H | 显示进程的层级结构 |
-o | 显示指定参数 |
–sort= | 排序 |
a:
x:
u:
h:
f:
o:
–sort=:
ps ax
ps ax显示信息如下:
PID 进程id
TTY 进程用到的终端
STAT 进程状态
TIME 进程占用cpu时长
COMMAND 进程名称
ps aux
ps aux显示信息如下:
USER 进程所有人
PID 进程id
%CPU 进程使用cpu的用量
%MEM 进程所用到的内存用量
VSZ 进程使用的虚拟内存大小
RSS 进程常驻内存中的数据大小
TTY 进程用到的终端
STAT 进程状态
START 进程运行时长
TIME 进程占用cpu时长
COMMAND 进程名称
pgrep
pgrep | 进程过滤 |
---|---|
-u uid | 显示指定用户进程 |
-U user | 显示指定用户进程 |
-t tty | 显示指定终端进程 |
-l | 显示进程名称 |
-a | 显示进程的完整名称 |
-P | 显示进程的子进程 |
-u uid:
-U user:
-t tty:
-l:
-P:
-a:
top
top 动态进程查看
top
top中的内容显示信息
09:48:51 系统时间
up 18:54 运行时长
2 users 系统中有两个用户登陆
load average: 0.75/1min, 0.53/5min, 0.41/15min
Tasks:
331 total 任务总量
3 running 正在运行
329 sleeping 休眠人物数量
0 stopped 被暂停数量
0 zombie 僵死人物数量
%Cpu(s)
1.5 us 用户空间
1.9 sy 内核空间
0.0 ni nice值调整时间
58.9 id 空闲时间
0.0 wa 等待io时间
2.1 hi 处理硬件中断时间
0.2 si 处理软件中断时间
0.0 st 被偷走的时间(vm使用时间)
MiB Mem :
7664.6 total 总量
5383.9 free 空闲
1312.1 used 占用
968.8 buff/cache 缓存
MiB Swap: 交换分区用量
top命令的参数
-d 指定刷新频率
-b 以批次方式显示
-n 指定显示的批次数量
-d:
-b:
-n:
top内部指令
P cpu排序
M 内存排序
T 累计cpu时间排序
l 关闭/开启uptime信息
t 关闭/开启cpu&task
s 指定刷新频率,默认3s
k 操作进程
u 查看指定用户进程
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时间占用百分比
%MEM 进程使用的物理内存百分比
TIME+ 进程使用的CPU时间总计,单位1/100秒
COMMAND 命令名/命令行
P:
M:
T:
三.进程优先级
定义:系统运行时采用多任务多用户的操作模式,任务的重要性是有区分的,因此采用优先级确定任务的重要性。
优先级范围:0~139
内核自控优先级范围:0~99
用户可控范围:100~139
在linux使用nice更改优先级
nice:-20~19
renice -n nice值 进程端口号 更改优先级
nice -n nice值 进程名 指定优先级打开进程
ps ax -o pid,nice,comm | grep 进程名
ps与pri转换:
ps ---- > pri :39~0
nice -20~19
priority 0~139 (100 ~139)
优先级 | 说明 |
---|---|
S | sleeping |
< r | 优先级高 |
s | 顶级进程 |
T | stop |
N | 优先级低 |
R | running |
+ | 运行在前台 |
四.进程前后台调用
说明 | |
---|---|
ctrl+z | 把占用shell的进程打入后台挂起 |
bg | 把后台挂起的进程运行起来 |
fg | 把后台进程调回前台 |
& | 运行进程在后台 |
jobs | 查看当前shell中在后台的所有工作 |
五.进程信息号
进程信号 | 说明 |
---|---|
1 | 重新家在系统配置文件(source) |
2 | 清空内存中的进程数据 |
3 | 清空内存中的鼠标(ctrl+) |
9 | 行结束进程(不能被阻塞) |
15 | 正常关闭进程(会被阻塞) |
18 | 运行被暂停的进程 |
19 | 暂停进程(不会被阻塞) |
20 | 暂停进程(会被阻塞的) |
kill 进程信号 pid | 运行进程在后台 |
killall 进程信号 进程名 | 查看当前shell中在后台的所有工作 |
pkill 进程信号 进程条件 | 把占用shell的进程打入后台挂起 |
六.systemd守护进程
实验环境:
服务端ip:172.25.254.110 westosa
客户端ip:172.25.254.210 westosb
远程连接操作:ssh 主机ip -l 主机ip
守护进程:
1)是替内核分担程序控管的程序,通常pid为1。
2)在linux系统中,我们会发现在系统启动的时候有很多的进程就已经开始跑了,也称为服务,这也是我们所说的守护进程。
3)守护进程是脱离于终端并且在后台运行的进程,脱离终端是为了避免在执行的过程中的信息在终端上显示,并且进程也不会被任何终端所产生的终端信息所打断。
systemd -----> systemctl
systemctl 管理系统服务
服务指在系统中开启的共享系统资源到网络中的程序
cs client ------ server
systemctl | 说明 |
---|---|
start | 开启 |
stop | 关闭 |
status | 查看状态 |
reload | 重新加载(不改变进程号) |
restart | 重新启动服务 (重新建立进程) |
enable | 设定服务开机启动 |
enable --now | 设定服务开机启动并当前开启服务 |
disable | 设定服务开启不启动) |
list-units | 看系统所有服务当前状态 |
list-unit-files | 查看服务开机状态 |
list-dependencies | 列出服务依赖性 |
mask | 冻结服务 |
unmask | 解锁 |
set-default | 设定系统运行模式 |
multi-user.target | 无图形网络模式 |
graphical.target | 有图形的网络模式 |
get-default | 查看系统运行模式 |
start /status:
reload:
restart:
enable:
list-units:
list-dependencies:
get-default:
系统运行模式 | 说明 |
---|---|
0 | POWEROFF |
1 | single |
2 | noG+NETWOR |
3 | |
4 | |
5 | G+NETWORK |
6 | REBOOT |
七.系统中的登陆审计
w 显示正在登陆系统的账号
-i 显示登陆来源
位置:/var/run/utmp
last 登陆成功现在已经退出的
位置/var/log/wtmp
lastb 试图登陆但未成功
位置/var/log/btmp
w:
last:
lastb: