Linux之进程管理

Linux之进程管理

一、 进程定义

进程的定义:

程序是静态的代码文件;
进程是指程序运行时的形态;
进程是程序的一个副本;
进程是有生命周期的(准备期,运行期,终止期)

进程与线程:

进程是资源调用的最小单位;
线程是进程的最小单位。
程序执行流是从上到下贯穿运行的;
当进程是多任务、CPU是多核心的,多任务应该同时被毎个核心处理,每个核心处理的任务叫线程。线程资源是共享的。

进程状态

R(TASK_RUNNING) 	可执行态(runing,ready)
S(TASK_INTRRUPTABLE)可唤醒休眠
D (TASK_UNINTRRUPTABLE)不可唤醒休眠
T (TASK_STOP) 暂停状态
Z (EXIT_ZOMBLE) 僵死态

ps 进程查看命令

ps命令有三种执行风格 unix bsd GNU
以下是unix风格(无-)

ps a 与终端相关的进程(当用户登陆系统后产生的进程都是带终端的)

在这里插入图片描述

在这里插入图片描述

ps x与终端无关的相关进程

在这里插入图片描述

ps u用户信息归类的查看方式

在这里插入图片描述

ps f进程层级关系

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

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

在这里插入图片描述

ps -e显示所有进程

在这里插入图片描述
在这里插入图片描述

ps -f 显示信息的完整格式

在这里插入图片描述

ps -H显示进程的层级结构

在这里插入图片描述

ps -o=

在这里插入图片描述
=显示指定参数

ps -参数 --sort=参数   按sort=排序

在这里插入图片描述
在这里插入图片描述

pgrep 进程过滤命令

1. pgrep -u uid 『u可大写』 显示指定用户ID的进程

在这里插入图片描述
重新打开一个bash
在这里插入图片描述

2. pgrep -u user 「u可大写」显示指定用户名的进程

在这里插入图片描述

3.pgrep -t tty 显示指定终端进程

在这里插入图片描述

4.pgrep -l 显示进程名称

在这里插入图片描述在这里插入图片描述

5.pgrep -a 进程名部分 显示进程完整名称

在这里插入图片描述

6.==pgrep -P == 时下进程子进程

在这里插入图片描述

pidof 进程名 查看进程的pid !有待查证

top 动态进程查看

top列表名称解释

在这里插入图片描述在这里插入图片描述

top命令参数

top -d 指定刷新频率
top -b 以批次方式显示????
top -n 指定显示的批次数量

top内部命令

P 按CPU排序

在这里插入图片描述

M 按内存排序

在这里插入图片描述

T 累计占用CPU时间排序

在这里插入图片描述

l开启/关闭uptime信息

在这里插入图片描述

t 开启关闭cpu&task

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述在这里插入图片描述

s 修改刷新频率

在这里插入图片描述

k 操作进程 !!!操作有风险,下手需谨慎!!!

在这里插入图片描述

u 查看指定用户进程

在这里插入图片描述

在这里插入图片描述

三、进程优先级

reason

系统是多任务多用户的的操作模式,任务的重要性是有区分的,如何确定任务的重要性?
“优先级”

范围:0-139

内核自控优先级范围:0-99
用户可按优先级:100-139
nice : “-20” -“19”
renice -n -5 pid 更改pid的优先级为-5

[root@student_26 Desktop]# ps  -o pid,comm,nice,pri,priority,stat

在这里插入图片描述nice -n -5 cat指定优先级打开进程

[root@student_26 Desktop]# nice -n -7 cat

在这里插入图片描述

pri39-0
nice20-19
priority0-139(100-139)

STAT
S sleeping
< 优先级高
s 顶级进程
T stop
R running
+ 运行在前台

四、进程前后台调用

ctrl+z 把占用shell的进程打入后台挂起

[root@student_26 Desktop]# gedit

在这里插入图片描述终端阻塞,弹出一个新edit窗口
在这里插入图片描述

ctrl+z

在这里插入图片描述edit窗口阻塞

bg 把后台运行的进程运行起来

[root@student_26 Desktop]# bg

在这里插入图片描述edit窗口正常运行

fg把后台进程调回前台

[root@student_26 Desktop]# fg

在这里插入图片描述
终端阻塞

命令 &运行进程在后台

[root@student_26 Desktop]# gedit &

在这里插入图片描述弹出一个新edit窗口,终端不阻塞。

jobs查看当前shell中在后台的所有工作
在这里插入图片描述

五、进程信息号

进程信号

1 重新加载系统配置文件(source)
2 清空内存中的进程数据
在这里插入图片描述重新打开一个终端
在这里插入图片描述
原终端,未enter数据自动加ctrl+c
在这里插入图片描述

3 清空内存中的鼠标(ctrl+\)
9 强行结束进程(不能被阻塞)

在这里插入图片描述
ps:查到此终端pid
在这里插入图片描述
打开另一个终端

[root@node126 ~]# kill -9 3257

在这里插入图片描述
原终端关闭
在这里插入图片描述

15 正常关闭进程(会被阻塞)
在这里插入图片描述

18 运行被暂停的进程

[root@node126 ~]# gedit
^Z   							  ##打入后台并挂起
[1]+  Stopped                 gedit
[root@node126 ~]# ps
    PID TTY          TIME CMD
   2700 pts/1    00:00:00 bash
   3920 pts/1    00:00:00 dbus-launch
   3993 pts/1    00:00:00 gedit
   4000 pts/1    00:00:00 ps
[root@node126 ~]# kill -18 3993  ##后台进程运行
[root@node126 ~]# jobs
[1]+  Running                 gedit &
[root@node126 ~]# 



19 暂停进程(不会被阻塞)
20 暂停进程(会被阻塞的)##相当于ctrl+Z

在这里插入图片描述重新打开一个终端

在这里插入图片描述原终端并不会被暂停,为什么?

在这里插入图片描述弹出edit窗口,

在这里插入图片描述

[root@node126 ~]# ps
    PID TTY          TIME CMD
   3370 pts/0    00:00:00 bash
   3462 pts/0    00:00:00 dbus-launch
   3681 pts/0    00:00:00 gedit
   3698 pts/0    00:00:00 ps

[root@node126 ~]# kill 20 3681

3681被关闭,为什么?

在这里插入图片描述弹出edit窗口,

在这里插入图片描述
在这里插入图片描述

[root@node126 ~]# kill 20 3750

edit 被阻塞

进程信号控制工具

kill 进程信号 pid

killall 进程信号 进程名字
在这里插入图片描述

pkill 进程信号 进程条件
在这里插入图片描述另一个终端

[root@student_26 Desktop]# kill -9 -u westos

在这里插入图片描述搞掉了westos用户的所有进程。

六、systemd守护进程

实验环境

node1.westos.org ---------------> 172.25.254.126
node2.westos.org ----------------->172.25.254.226

###远程操作主机
ssh 远程主机ip -l 远程主机用户

守护进程

替内核分担程序控管的程序 #通常pid为1
systemd -------------->systemctl

systemctl 管理系统服务

服务,指在系统中开启的 共享系统资源到网络中的程序
cs: client -----server
systemctl 命令的用法
systemctl start 开启
systemctl stop 关闭
systemctl status 查看状态
systemctl reload 重新加载
systemctl restart 重新启动服务
systemctl enable 设定服务开机启动
systemctl enable --now 设定服务开机启动并当前开启服务
systemctl disable 设定服务开机不启动
systemctl list-units 查看系统所有服务当前状态
systemctl list-unit-files 查看服务开机状态
systemctl list-dependencies 列出服务依赖性
systemctl mask 冻结服务
systemctl unmask 解锁
systemctl set-default 查看系统运行模式
0-6
0 POWEROFF
1 single
2 noG+NETWORK
3
4
5 G+NETWORK
6 REBOOT

systemctl status 查看状态

[root@node126 ~]# systemctl status sshd

在这里插入图片描述

systemctl stop 关闭
关闭并查看状态

[root@node126 ~]# systemctl stop sshd
[root@node126 ~]# systemctl status sshd

在这里插入图片描述
systemctl start 开启

开启并查看状态

[root@node126 ~]# systemctl start sshd
[root@node126 ~]# systemctl status sshd

在这里插入图片描述

systemctl reload 重新加载

[root@node126 ~]# systemctl status sshd

在这里插入图片描述

[root@node126 ~]# systemctl reload sshd.service 
[root@node126 ~]# systemctl status sshd

在这里插入图片描述reload之后,main pid 不会变。

systemctl restart 重新启动服务

[root@node126 ~]# systemctl status sshd

在这里插入图片描述

[root@node126 ~]# systemctl restart sshd
[root@node126 ~]# systemctl status sshd

在这里插入图片描述restart之后,main pid会变。

systemctl enable 设定服务开机启动

[root@node126 ~]# systemctl disable --now sshd
[root@node126 ~]# systemctl enable sshd

在这里插入图片描述

systemctl disable 设定服务开机不启动

[root@node126 ~]# systemctl status sshd

在这里插入图片描述

[root@node126 ~]# systemctl disable sshd

Removed /etc/systemd/system/multi-user.target.wants/sshd.service.

[root@node126 ~]# systemctl status sshd

在这里插入图片描述systemctl disable --now 设定服务开机启动并当前开启服务

[root@node126 ~]# systemctl disable --now sshd

在这里插入图片描述

systemctl list-units 查看系统所有服务当前状态
在这里插入图片描述在这里插入图片描述在这里插入图片描述

systemctl list-unit-files 查看服务开机状态

[root@node126 ~]# systemctl list-unit-files 

在这里插入图片描述systemctl list-dependencies 列出服务依赖性

[root@node126 ~]# systemctl list-dependencies 

在这里插入图片描述

systemctl mask 冻结服务

[root@node126 ~]# systemctl stop sshd
[root@node126 ~]# systemctl start sshd
[root@node126 ~]# systemctl stop sshd
[root@node126 ~]# systemctl mask sshd
Created symlink /etc/systemd/system/sshd.service → /dev/null.
[root@node126 ~]# systemctl start sshd
Failed to start sshd.service: Unit sshd.service is masked.

在这里插入图片描述

systemctl unmask 解锁

[root@node126 ~]# systemctl start sshd
Failed to start sshd.service: Unit sshd.service is masked.
[root@node126 ~]# systemctl unmask sshd.service 
Removed /etc/systemd/system/sshd.service.
[root@node126 ~]# systemctl start sshd
[root@node126 ~]# 

在这里插入图片描述

systemctl get-default 查看系统运行模式
在这里插入图片描述multi-user.target 无图形的网络模式
graphical.target 有图形的网络模式
系统运行模式
0-6
0 POWEROFF
1 single
2 noG+NETWORK
3
4
5 G+NETWORK
6 REBOOT

[root@node126 ~]# runlevel
N 5     #当前系统的运行级别为5,有图形的网络模式
[root@node126 ~]# init 3  ##修改系统运行级别为3
[root@node126 ~]# systemctl get-default 
graphical.target    ##当前仍为有图形的网络模式
[root@node126 ~]# runlevel
5 3   ## init 3是临时设定
[root@node126 ~]# 

在这里插入图片描述
虚拟机变成了这样。

[root@node126 ~]# reboot
Connection to 172.25.254.126 closed by remote host.
Connection to 172.25.254.126 closed.
[root@student_26 Desktop]# 

在这里插入图片描述
重启之后,图形又回来了。

[root@node126 ~]# systemctl set-default multi-user.target 
Removed /etc/systemd/system/default.target.
Created symlink /etc/systemd/system/default.target → /usr/lib/systemd/system/multi-user.target.

无反应

[root@node126 ~]# reboot
Connection to 172.25.254.126 closed by remote host.
Connection to 172.25.254.126 closed.
[root@student_26 Desktop]# 

在这里插入图片描述
虚拟机变成了这样。

[root@student_26 ~]# ssh -Xl root 172.25.254.126
root@172.25.254.126's password: 
Activate the web console with: systemctl enable --now cockpit.socket

This system is not registered to Red Hat Insights. See https://cloud.redhat.com/
To register this system, run: insights-client --register

Last login: Fri Jan 22 12:23:28 2021 from 172.25.254.26
[root@node126 ~]# runlevel 
N 3    ##永久修改runlevel为3
[root@node126 ~]#
[root@node126 ~]# reboot
Connection to 172.25.254.126 closed by remote host.
Connection to 172.25.254.126 closed.

在这里插入图片描述还是这样

[root@node126 ~]# systemctl set-default graphical.target   ##永久修改运行级别为5
Removed /etc/systemd/system/default.target.
Created symlink /etc/systemd/system/default.target → /usr/lib/systemd/system/graphical.target.
[root@node126 ~]# reboot
Connection to 172.25.254.126 closed by remote host.
Connection to 172.25.254.126 closed.
[root@student_26 ~]# 

在这里插入图片描述虚拟机图形回来了

[root@student_26 ~]# ssh -Xl root 172.25.254.126
root@172.25.254.126's password: 
Activate the web console with: systemctl enable --now cockpit.socket

This system is not registered to Red Hat Insights. See https://cloud.redhat.com/
To register this system, run: insights-client --register

Last login: Fri Jan 22 12:37:16 2021 from 172.25.254.26
[root@node126 ~]# runlevel
N 5
[root@node126 ~]# 

七、系统中的登录审计

w 显示正在登陆系统的账号
w -i 显示登陆来源
/var/run/utmp
在这里插入图片描述在这里插入图片描述

[root@node126 ~]# vim /var/run/utmp 
[root@node126 ~]# cat /var/run/utmp 

在这里插入图片描述

last 登陆成功现在已经退出的
/var/log/wtmp
在这里插入图片描述

[root@node126 ~]# cat /var/log/wtmp #乱码

在这里插入图片描述

[root@node126 ~]# > /var/log/wtmp  ##清空last记录

在这里插入图片描述

lastb 试图登陆但未成功
/var/log/btmp
在这里插入图片描述

[root@node126 ~]# cat /var/log/btmp  ## 乱码

在这里插入图片描述

[root@node126 ~]# > /var/log/btmp  ##清空lastb记录

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值