Linux中的进程管理
#进程定义
程序是静态的代码文件
进程是指程序运行时的形态
进程是程序的一个副本
进程是有生命周期的(准备期,运行期,终止期)
#进程,线程
进程是资源调用最小单位
线程是进程的最小单位
程序执行流是从上到下贯穿运行的
但进程是多任务物,cpu是多核心,多任务应该同时被每个核心处理,每个核心处理的任务叫线程
线程资源是共享的
#进程状态
#R 可执行态
#S 可唤醒休眠
#D 不可唤醒休眠
#T 暂停
#Z 僵尸
#进程查看命令
gnome-system-monitor 图形进程查看工具
ps #进程查看
a与终端相关的进程
x与终端无关的进程
u用户信息归类的查看方式
f进程层级结构
o显示指定参数 pid comm nice pri pcpu ppid stat user group
-e显示所有进程
-f显示信息的完整格式
-H显示进程的层级结构
-o
--sort=排序
ps ax显示信息如下:
pid 进程id
tty 进程用到的终端
stat 进程状态
time 占用cpu时长
command 进程名称
ps aux显示:
user
pid
%cpu
%mem 内存用量
vsz 进程使用的虚拟内存大小
rss 常住内存的数据大小
tty
stat
start 进程运行时长
time 占用cpu时长
command
pgrep 进程过滤
-u uid 显示指定用户进程
-U user 显示指定用户名称进程
-t tty 显示指定终端进程
-l 显示进程名称
-a 显示进程的完整名称
-P 下时进程的子进程
pidof vim 查看vim的pid
top 动态进程查看
-d 指定刷新频率
-b 批次方式显示
-n 显示批次数量
内部指令
P cpu排序
M 内存排序
T 累计占cpu时间排序
l 关闭/开 uptime 信息
t 关/开 cpu&task
s 指定刷新频率
k 操作进程
u 查看指定用户进程
#进程前后台调用
ctrl+z 把占用shell的进程打入后台挂起
bg 把后台挂起的进程运行起来
fg 把后台进程调回前台
& 运行进程在后台
jobs 查看当前shell中在后台的所有工作
#进程优先级
系统是多任务多用户的操作模式
任务的重要性是有区分的
如何确定任务的重要性
“优先级”
范围:0-139
内核自控优先级范围:0-99
用户可自控优先级:100-139
nice :-20~19
(越小优先级越高)
ps ax -o nice,pid,stat,comm | grep cat 查看cat进程
renice -n -5 2330 更改2781的优先级
nice -n 5 cat 指定优先级打开进程
S sleeping
< 优先级高
s 顶级进程
T stop
N 优先级低
R running
- 运行在前台
#进程信息信号
信息信号
-1 重新加载系统配置文件source
-2 清空内存中的进程数据
-3 …鼠标(ctrl+\)
-9 强行结束进程
-15 正常关闭进程
-18 运行被暂停的进程
-19 暂停进程(不会被阻塞)
-20 暂停进程(会被阻塞)
#进程信号控制工具
kill 进程信号 pid
killall 进程信号 进程名字
pkill 进程信号 进程条件
eg:
kill -9 11302
killall -9 vim
pkill -9 -u westos
#systemd守护进程
实验环境
linux.westos.com >>>> 172.25.254.10
nodel.westos.com >>>> 172.25.254.20
操作如下
在shell中敲入nm-connection-editor
选择 以太网
选择ipv4 settings
manual
172.25.254.126
netmask:24
ping ip地址 查看连没连上网
远程操作主机
ssh 远程主机ip -l 远程主机用户
守护进程
替内核分担程序控管的程序
通常pid为1
systemd >>>>> systemctl
systemctl 管理系统服务
服务指在系统中开启的共享资源到网络的程序
cs:client和server
systemctl 命令用法
start 开启
stop 关闭
status 查看状态
reload 重新加载
restart 重新启动服务
enable 设定服务开机启动
enable --now 设定服务开机启动并并当前开启服务
disable 设定服务开启不启动(与enable同理)
list-units 查看系统所有服务当前状态
list-unit-files 查看服务开机状态
list-dependencies列出服务依赖性
mask 冻结服务
unmask 解锁
set-default 设定系统运行模式
multi-user.target 无图形网络模式
graphical.target 有图形…
get-default 查看系统运行模式
系统运行模式
0 poweroff
1 single
2-4 noG(无图)+network
5 G(有图)+network
6 reboot(重启)
eg:
systemctl start sshd
systemctl status sshd
##系统中的登陆审计
w 显示正在登录系统的账号
-i 显示登陆来源
/var/run/utmp
last 登陆成功现在已经退出的
/var/log/wtmp
lastb 试图登陆但未成功
/var/log/btmp