一.进程
1.1 进程的定义:
1) 程序是静态的代码文件
2)进程是指程序运行时的形态
3) 进程是程序的一个副本
4)进程是有生命周期的(准备期,运行期,终止期)
1.2 线程的定义
1) 线程是cpu调度和执行的单位
2)线程会带来额外的开销,如cpu调用时间,并发控制开销.
3)每个线程在自己的工作内存交互,内存控制不当会造成数据不一致.
1.3线程和进程的区别
1)进程是资源调用的最小单位
2)线程是进程的最小单位
程序执行流是从上倒下贯穿运行的
当进程是多任务物,cpu是多核心,多任务应该同时被每个核心处理,每个核心处理的任务叫线程
线程资源是共享的.
1.4 进程的状态
R(TAKS_RUNNING) | 可执行态(running,ready) |
---|---|
S(TASK_INTRRUPTABLE) | 可唤醒休眠 |
D(TASK_UNINTRRUPTABLE) | 不可唤醒休眠 |
T(TASK_STOP) | 暂停状态 |
Z(EXIT_ZOMBIE) | 僵死状态 |
命令的查看:ps ax -o stat , comm
二.进程的查看
命令:
gnome-system-monitor 图形进程查看工具
2.1 ps
1)进程查看
2)ps 命令的三种执行风格 unix bsd GNU
unix风格:参数一般带 -
bsd风格:参数不带 -
2.2 ps命令
ps a | 与终端相关的进程 (当用户登陆系统后产生的进程都是带终端的) |
---|---|
ps x | 与终端无关相关的进程 |
ps u | 用户信息归类的查看方式 |
ps f | 进程层级关系 |
ps o | 显示指定参数 pid comm nice pri pcpu ppid stat,user,group |
注意:以上是unix风格
ps -e | 显示所有进程 |
---|---|
ps -f | 显示信息的完整格式 |
ps -H | 显示进程的层级结构 |
ps -o | 显示指定参数 |
ps --sort | 排序 (**-**为负序) |
2.3 ps ax显示信息:
PID | 进程id |
---|---|
TTY | 进程用到的终端 |
STAT | 进程状态 |
TIME | 进程占用cpu时长 |
COMMAND | 进程名称 |
2.4 ps aux显示信息:
USER | 进程所有人 |
---|---|
PID | 进程id |
%CPU | 进程使用cpu的用量 |
%MEM | 进程所用到的内存用量 |
VSZ | 进程使用的虚拟内存大小 |
RSS | 进程常驻内存中的数据大小 |
TTY | 进程用到的终端 |
STAT | 进程状态 |
START | 进程运行时长 |
TIME | 进程占用cpu时长 |
COMMAND | 进程名称 |
2.5 pgrep
进程过滤
pgrep - u uid | 显示指定用户进程 |
---|---|
pgrep - U user | 显示指定用户进程 |
pgrep - t tty | 显示指定终端进程 |
pgrep - l | 显示进程名称 |
pgrep - a | 显示进程的完整名称 |
pgrep - P | 显示进程的子进程 |
注:“-l -a -P要和前面三个配合使用其中-P后面加的是用户的PID”
2.6 pidof vim 查看vim的pid
三. top 动态进程查看
3.1 top中的内容显示信息
top中的内容显示信息
06:41:09 | 系统时间 |
---|---|
up 10:56 | 运行时长 |
1 users | 系统中有一个用户登陆 |
load average: | 0.18, 0.16, 0.06 |
1min 5min 15min
Tasks:
324 total | 任务总量 |
---|---|
1 running | 正在运行 |
323sleeping | 休眠人物数量 |
0 stopped | 被暂停数量 |
0 zombie | 僵死人物数量 |
%Cpu(s)
0.3 us | 用户空间 |
---|---|
0.3sy | 内核空间 |
0.0 ni nice | 值调整时间 |
99.2 id | 空闲时间 |
0.0 wa | 等待io时间 |
0.2 hi | 处理硬件中断时间 |
0.0 si | 处理软件中断时间 |
0.0 st | 被偷走的时间(vm使用时间) |
MiB Mem :
3758.6 total, | 总量 |
---|---|
1795.0 free | 空闲 |
1185.1 used | 占用 |
778.6 buff/cache | 缓存 |
MiB Swap: 交换分区用量
3.2 top参数
-d | 指定刷新频率(秒s) |
---|---|
-b | 以批次方式显示 |
-n | 指定显示的批次数量 |
3.3 top内部指令
P | cpu排序 |
---|---|
M | 内存排序 |
T | 累计展铜cpu时间排序 |
l | 关闭/开启uptime信息 |
t | 关闭/开启cpu&task |
s | 指定刷新频率 |
k | 操作进程 |
u | 查看指定用户进程 |
四.进程优先级
系统时多任务多用户的操作模式 任务的重要性是有区分的
4.1 如何确定任务的重要性
优先级:
范围: 0–139
内核自控优先级范围:0-99
用户可控优先级:100-139
nice值
-20 - 19
监控命令:watch -n1 “ps ax -o pid,comm,stat,nice”
renice -n nice值 进程号 | 更改优先级 |
---|
nice -n nice值 进程名称 | 指定优先级打开进程 |
---|
S | sleeping |
---|---|
< | 优先级高 |
s | 顶级进程 |
T | stop |
N | 优先级底 |
R | running |
+ | 运行在前台 |
五.进程前后台的调用
<ctrl>+<z> | 把占用shell的进程打入后台挂起 |
---|---|
bg | 把后台挂起的进程运行起来 |
fg | 把后台进程调回前台 |
& | 运行进程在后台 |
jobs | 查看当前shell中在后台的所有工作 |
六.进程信息号
6.1 进程信号
1 | 重新家在系统配置文件(source) |
---|---|
2 | 清空内存中的进程数据 |
3 | 清空内存中的鼠标(ctrl+) |
9 | 强行结束进程(不能被阻塞) |
15 | 正常关闭进程(会被阻塞) |
18 | 运行被暂停的进程 |
19 | 暂停进程(不会被阻塞) |
20 | 暂停进程(会被阻塞的) |
6.2 进程信号控制工具
kill + 进程信号 pid |
---|
killall + 进程信号 进程名字 |
pkill + 进程信号 进程条件 |
七. systemd 守护进程
远程操作主机
ssh 远程主机ip -l 远程主机用户
ssh 主机用户@远程主机ip
守护进程
替内核分担程序控管的程序
通常pid为1
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 | 有图形的网络模式 |
命令演示:
systemctl set-default multi-user.targey(开启无图形模式)
无图形模式:
开启有图形模式:systemctl set-default graphical.target
get-default 查看系统运行模式
系统运行模式:0-6
0 | POWEROFF |
---|---|
1 | single |
2 | noG+NETWORK |
3 | |
4 | |
5 | G+NETWORK |
6 | REBOOT |
命令演示:runlevel也可以显示系统运行模式
八. 系统中的登陆审计
w | 显示正在登陆系统的账号 |
---|---|
-i 显示登陆来源 | |
数据存放的地方 | /var/run/utmp |
last | 登陆成功现在已经退出的 |
---|---|
数据存放路径 | /var/log/wtmp |
lastb | 试图登陆但未成功 |
---|---|
数据存放路径 | /var/log/btmp |