Linux中的进程管理

进程的定义

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

进程&线程

  • 进程是资源调用的最小单位
  • 线程是进程的最小单位
  • 程序执行流是从上倒下贯穿运行的,当进程是多任务物,cpu是多核心,多任务应该同时被每
  • 个核心处理,每个核心处理的任务叫线程 线程资源是共享的.

进程状态 

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

进程查看命令     

gnome-system-monitor         图形进程查看工具

ps 命令的三种执行风格 unix bsd GNU

命令参数命令含义
ps 进程查看
psa与终端相关的进程(当用户登陆系统后产生的进程都是带终端的)
psx与终端无关相关的进程
psu用户信息归类的查看方式
psf进程层级关系
ps o显示指定参数( pid comm nice pri pcpu ppid stat,user,group)
ps-e 显示所有进程
ps-f显示信息的完整格式
ps-H显示进程的层级结构
ps-o显示指定参数

ps ax显示信息如下:

PID进程id
TTY进程用到的终端
STA进程状态
TIME进程占用cpu时长
COMMAND进程名称

ps aux显示信息如下: 

USER 进程所有人
PID进程id
%CPU进程使用cpu的用量
%MEM进程所用到的内存用量
VSZ 进程使用的虚拟内存大小
RSS 进程常驻内存中的数据大小
TTY   进程用到的终端
STAT进程状态
START进程运行时长
TIME 进程占用cpu时长
COMMAND进程名称

pgrep   进程过滤          

pgrep -P进程的子进程
pgrep -u uid显示指定用户进程
pgrep -U use显示指定用户进程
pgrep -t tty显示指定终端进程
pgrep  -l 显示进程名称
pgrep -a显示进程的完整名称

pidof vim          查看vim的pid

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命令的参数:

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

top内部指令:

命令参数含义
top Pcpu排序
topM内存排序
top T 累计展铜cpu时间排序
top  l关闭/开启uptime信息
top t 关闭/开启cpu&task
top s指定刷新频率
top操作进程
top u查看指定用户进程

PID进程id
 USER进程所有者的用户名
PR优先级
NInice值。负值表示高优先级,正值表示低优先级
VIRT 进程使用的虚拟内存总量,单位kb。VIRT=SWAP+RES
RES进程使用的、未被换出的物理内存大小,单位kb。RES=CODE+DATA
SHR共享内存大小,单位kb
进程状态(D=不可中断的睡眠状态,R=运行,S=睡眠,T=跟踪/停止,Z=僵尸进程)
%CPU次更新到现在的CPU时间占用百分比
%MEM 进程使用的物理内存百分比
TIME+进程使用的CPU时间总计,单位1/100秒 
COMMAND命令名/命令行

                 

进程优先级

系统时多任务多用户的操作模式 任务的重要性是有区分的

如何确定任务的重要性

“优先级”

范围: 0--139

内核自控优先级范围:0-99

用户可控优先级:100-139 nice -20-19

nice范围-20-19

renice -n -5 进程号       更改优先级

nice -n -5 进程             指定优先级打开进程

ps ax -o pid,nice,comm | grep cat      优先级更改后的查看命令

ps ---- > pri        --- 39-0

nice              20-19

priority          0-139 (100-139)

Ssleeping
<优先级高
stop
N优先级底
running
运行在前台
s顶级进程

进程前后台调用 

ctrl+z把占用shell的进程打入后台挂起
bg把后台挂起的进程运行起来
fg把后台进程调回前台
&运行进程在后台
jobs查看当前shell中在后台的所有工作

进程信息号

man 7 signal   进程信号

重新家在系统配置文件(source)
2清空内存中的进程数据
3清空内存中的鼠标(ctrl+\)
9   强行结束进程(不能被阻塞)
15正常关闭进程(会被阻塞)
18运行被暂停的进程
19暂停进程(不会被阻塞)
20暂停进程(会被阻塞的

进程信号控制工具

kill进程信号pid
killall进程信号进程名字
pkill进程信号进程条件

systemd守护进程

实验环境:

克隆一台虚拟机

配置网络

node1 -------- > 网络ID

node2 ----------> 网络ID

使得两台虚拟机可以互相ping通

虚拟机克隆

远程操作主机

ifconfig     查看IP地址

ssh 远程主机ip -l 远程主机用户

守护进程

替内核分担程序控管的程序

通常pid为1

systemd -----> systemctl

systemctl     管理系统服务

/user/lib/systemd/system    此目录中存在的所有及程序脚本是可以用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

                                                 0     POWEROFF   (关机)

                                                 1     single     (单用户模式)

                                                 2     noG+NETWORK(2-4无图形的网络模式)

                                                 3

                                                 4

                                                 5     G+NETWORK     (有图形的网络模式)

                                                 6     REBOOT             (重新启动)

系统中的登陆审计

w                       显示正在登陆系统的账号

            -i           显示登陆来源

                         /var/run/utmp

last                   登陆成功现在已经退出的

                         /var/log/wtmp

lastb                 试图登陆但未成功

                         /var/log/btmp

配置虚拟机网络环境,使得两台虚拟机可以互相ping通

 ping另一台虚拟机得到回应,设置成功

远程登陆另一台虚拟机:

 在另一台虚拟机查看登录情况:

输入exit,退出登陆的另一台虚拟机:

posted @ 2023-03-16 19:48  yunyeblog  阅读(24)  评论(0编辑  收藏  举报  来源