1.进程
进程的定义
程序是静态的代码文件;进程是指程序运行时的形态
进程是程序的一个副本(copy程序到内存,相当于副本)
进程是有生命周期的
准备期:准备资源(类似于执行“打扫教室任务”前,“拿扫把”)
运行期:执行过程
终止期:执行后程序所占用的系统资源被回收
进程和线程
进程:进程是资源调用的最小单位。所有事件由cpu处理,当一个事件cpu,其他事件就无法占用处于,等待用完才可以使用cpu。
双核、三核cpu:为使充分使用cpu,一个事件细划分成若干个小的线程,加速cpu同时处理。
线程是进程的最小单位
程序执行流是从上到下贯穿运行的
当进程是多任务,cpu是多核心时,多任务应该同时被每个核心处理,每个核心处理的任务叫线程资源。 线程资源是共享的
进程状态
R(TASK_RUNNING)
##可执行态:正在被cpu处理,或已经加载好等待被cpu处理
S(TASK_INTRRUPTABLE)
##可唤醒休眠:使用cpu超时,进入休眠,再次使用时需要被激活
D(TASK_UNINTRRUPTABLE)
##不可唤醒休眠:使用cpu超时,仍有资源没有被加载好,不可以使用cpu
T(TASK_STOP)
##暂停状态:关闭无法使用程序,但可以人为唤醒
Z(EXIT_ZOMBLE)
##僵死态:进程已经结束,却占用资源不放,需要手动结束程序。“bug”
2.进程查看命令
gnome-system-monitor ##图形进程查看工具

ps
进程查看
ps 命令的三种执行风格
unix bsd GNU
ps a 与终端相关的进程
(
当用户登陆系统后产生的进程都是带终端的
)
ps x 与终端无关相关的进程
ps u 用户信息归类的查看方式
ps f 进程层级关系

ps o 显示指定参数 pid comm nice pri pcpu ppid stat,user,group

ps
ps -e 显示所有进程
ps -f 显示信息的完整格式
ps -H 显示进程的层级结构

ps -o 显示指定参数

ps --sort= #排序
正序,从小到大,例:ps axo %cpu --sort=%cpu
倒序,从大到小,例:ps axo %cpu --sort=-%cpu

#ps ax显示信息如下:
#PID 进程id
#TTY 进程用到的终端
#STAT 进程状态
#TIME 进程占用cpu
时长
#COMMAND
进程名称
#ps aux显示信息如下:
#USER 进程所有人
#PID 进程id
#%CPU 进程使用cpu的用量
#%MEM 进程所用到的内存用量
#VSZ 进程使用的虚拟内存大小
#RSS 进程常驻内存中的数据大小
#TTY 进程用到的终端
#STAT
进程状态
#START 进程运行时长
#TIME 进程占用cpu
时长
#COMMAND 进程名称
pgrep #进程过滤
#
-
u uid 显示指定用户进程
#
-
U user 显示指定用户进程
#
-
t tty 显示指定终端进程
#
-
l 显示进程名称
#
-
a 显示进程的完整名称
#
-
P 进程的子进程
pidof
pidof vim ##查看vim
的
pid
top ##动态进程查看
##top中的内容显示信息
#09:48:51 系统时间
#up 18:54 运行时长
#2 users 系统中有两个用户登陆
#load average: 0.75, 0.53, 0.41
1min 5min 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 指定显示的批次数量
#top
内部指令(键盘操作)
#P cpu排序
#M 内存排序
#T 累计占用cpu时间排序
#l 关闭
/
开启
uptime
信息
#t 关闭
/
开启
cpu
&
task
#s 指定刷新频率
#k 操作进程
(按k,默认处理资源占用最多的,输入pid选择要关闭的进程,15正常关闭,9强制关闭)
#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 命令名/命令行

3.进程优先级
系统时多任务多用户的操作模式
任务的重要性是有区分的
如何确定任务的重要性
“
优先级
”
范围: 0--139
内核自控优先级范围:0-99
用户可控优先级:100-139
nice :-20 - 19
renice -n -5 43331
##更改优先级
(普通用户只能把自己的优先级改低)
nice -n -5 ca
t ##指定优先级打开进程
ps ax -o pid,nice,comm | grep cat
ps ---- > pri --- 39-0
nice -20 - 19
priority 0-139 (100-139)
S #sleeping
< #优先级高
s #顶级进程
T #stop
N #优先级底
R #running
+ #运行在前台
4.进程前后台调用
<ctrl>+<z> ##把占用shell的进程打入后台挂起
bg ##把后台挂起的进程运行起来
fg ##把后台进程调回前台
& ##运行进程在后台
jobs ##查看当前shell中在后台的所有工作
5.进程信息号
man
7
signal
#
进程信号
1
#重新家在系统配置文件
(source)
2
#清空内存中的进程数据
3
#清空内存中的鼠标
(ctrl
+\
)
9
#强行结束进程
(
不能被阻塞
)
15
#正常关闭进程
(
会被阻塞
)
18
#运行被暂停的进程
19
#暂停进程
(
不会被阻塞
)
20
#暂停进程
(
会被阻塞的
)
#
进程信号控制工具
kill 进程信号 pid
killall 进程信号 进程名字
pkill 进程信号 进程条件

6.systemd守护进程
##实验环境
#linux.westos.com -------- > 172.25.254.10
#node1.westos.com ----------> 172.25.254.20
查找ip
#远程操作主机
#ssh 远程主机ip -l 远程主机用户
ssh -l root 172.25.254.20
#
守护进程
#
替内核分担程序控管的程序
#
通常
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 有图形的网络模式
get-default ##查看系统运行模式


##系统运行模式
#0-6
init 0 POWEROFF
init 1 single
init 2 noG+NETWORK(开机2,3,4都无图形)
init 3
init 4
init 5 G+NETWORK 开机有图形
init 6 REBOOT 重启
7.系统中的登陆审计
w ##
显示正在登陆系统的账号
##
-
i
显示登陆来源
#
/
var
/
run
/
utmp
last ##
登陆成功现在已经退出的
##
/
var
/
log
/
wtmp
lastb ##
试图登陆但未成功
##
/
var
/
log
/
btmp