【运维知识基础篇】Linux进程管理

简介: 【运维知识基础篇】Linux进程管理

本篇文章介绍什么是进程和程序,如何管理进程,隐藏进程,调整进程的优先级

进程

我们运行一个程序,那么我们将运行的程序叫进程

PS1,当程序运行为进程后,系统会为该进程分配内存,以及进程运行的身份和权限。

PS2,在进程运行的过程中,服务器上会有各种状态来表示当前进程的指标信息。

进程生命周期

一个对象从无到有,从有到无的过程称为生命周期

父进程一般不干活,子进程干活,父进程给子进程派生资源, 子进程完成任务后,父进程回收资源,父进程被杀掉后,子进程会成为僵尸进程,没法干活,浪费资源。

CentOS,父进程被杀掉后,还有systemed祖先进程来回收资源。

每个进程都有PID,子进程叫PPID

监控进程状态

ps -auxf
用户     祖先进程是1 cpu占用百分比 内存百分比 虚拟内存 实际内存   终端类型   状态  
USER       PID           %CPU      %MEM   VSZ      RSS      TTY      STAT START   TIME COMMAND
基本状态:R表示状态在运行中(CPU处理进程只能同时处理一个,但是处理速度很快),S可中断睡眠(其他程序不调用它,它就可以待在那里,但是随时可以调用),T进程被暂停,D不可中断睡眠,Z僵尸进程
状态符号:s是父进程,<进程运行在高优先级上,ssh比web服务器优先级高,当服务器压力过满时,可以保证能优先连接处理,N表示进程运行在低优先级上,+表示进程在前台操作,l表示进程是多线程的,一个进程可以有多个线程,同一时间可以做很多事情
虚拟内存是多个服务调用同一进程,每一个服务都调用了此内存,所以会高
USER       PID %CPU %MEM    VSZ   RSS TTY      STAT START   TIME COMMAND
root          2  0.0  0.0      0     0 ?        S    08:50   0:00 [kthreadd]
root          4  0.0  0.0      0     0 ?        S<   08:50   0:00  \_ [kworker/0:0H]
root          5  0.0  0.0      0     0 ?        S    08:50   0:00  \_ [kworker/u256:0]
root          6  0.0  0.0      0     0 ?        S    08:50   0:00  \_ [ksoftirqd/0]
root          1  0.1  0.3  46340  6888 ?        Ss   08:50   0:02 /usr/lib/systemd/systemd --switched-ro
ot --system --deserialize 22
[root@VMware-koten ~]#top
top - 10:16:02 up  1:25,  1 user,  load average: 0.
Tasks:  93 total,   1 running,  92 sleeping,   0 st
%Cpu(s):  0.0 us,  0.0 sy,  0.0 ni,100.0 id,  0.0 w
    用户占用cpu百分比  内核占用的百分比 可以看是硬件还是软件导致系统慢
KiB Mem :  2027868 total,  1685548 free,   222692 u
KiB Swap:  1048572 total,  1048572 free,        0 u
   PID USER      PR  NI    VIRT    RES    SHR S 
   833 root      20   0  199244   4736   3636 S 
  1766 root      20   0       0      0      0 S 
     1 root      20   0   46340   6888   4136 S 
     2 root      20   0       0      0      0 S 
     4 root       0 -20       0      0      0 S 
     5 root      20   0       0      0      0 S 
     6 root      20   0       0      0      0 S 
     7 root      rt   0       0      0      0 S 
     8 root      20   0       0      0      0 S 

硬中断与软中断

中断是终止当前在做的事情,去执行另一端程序,一般主动中断是软中断,没有随机性和突发性,没有中断响应周期,中断类型号的提供方法由固定或由指令提供,硬中断是强制突然被中断,不可控的事情,中断类型号的提供方法由中断控制器提供。

管理进程状态

  1. 使用kill-l列出当前系统所支持的信号

sighup 重新加载配置文件 1 不停机维护

sigkill 强制杀死进程 9 不等待程序将数据写入到磁盘中,直接杀死,类似关机直接拔电源

sigterm 终止进程,默认kill使用该信号 15 也叫平滑杀死,等待用户将数据写入到磁盘中,然后再灭亡,类似windows使用关机按钮

直接拔电源会导致系统无法开机,可能会导致系统文件丢失

开机会加载系统的内核(引导文件)到内存中,内存文件在拔电源时来不及释放,导致在内存中直接丢失,引导文件丢了就需要重装系统了

[root@VMware-koten ~]#kill -l
 1) SIGHUP     2) SIGINT     3) SIGQUIT     4) SIGILL     5) SIGTRAP
 6) SIGABRT     7) SIGBUS     8) SIGFPE     9) SIGKILL    10) SIGUSR1
11) SIGSEGV    12) SIGUSR2    13) SIGPIPE    14) SIGALRM    15) SIGTERM
16) SIGSTKFLT    17) SIGCHLD    18) SIGCONT    19) SIGSTOP    20) SIGTSTP
21) SIGTTIN    22) SIGTTOU    23) SIGURG    24) SIGXCPU    25) SIGXFSZ
26) SIGVTALRM    27) SIGPROF    28) SIGWINCH    29) SIGIO    30) SIGPWR
31) SIGSYS    34) SIGRTMIN    35) SIGRTMIN+1    36) SIGRTMIN+2    37) SIGRTMIN+3
38) SIGRTMIN+4    39) SIGRTMIN+5    40) SIGRTMIN+6    41) SIGRTMIN+7    42) SIGRTMIN+8
43) SIGRTMIN+9    44) SIGRTMIN+10    45) SIGRTMIN+11    46) SIGRTMIN+12    47) SIGRTMIN+13
48) SIGRTMIN+14    49) SIGRTMIN+15    50) SIGRTMAX-14    51) SIGRTMAX-13    52) SIGRTMAX-12
53) SIGRTMAX-11    54) SIGRTMAX-10    55) SIGRTMAX-9    56) SIGRTMAX-8    57) SIGRTMAX-7
58) SIGRTMAX-6    59) SIGRTMAX-5    60) SIGRTMAX-4    61) SIGRTMAX-3    62) SIGRTMAX-2
63) SIGRTMAX-1    64) SIGRTMAX    
[root@VMware-koten ~]#

killall 和pkill只需要知道名字就可以杀掉,杀掉它相关的进程,不需要查PID

&把进程挂起放在后台

jobs 显示在后台运行的程序

[root@VMware-koten ~]#sleep 500 & #放到后台,关窗口就停止运行
[1] 1906
[root@VMware-koten ~]#jobs
[1]+  Running                 sleep 500 &
[root@VMware-koten ~]#bg %2 #放到后台
[root@VMware-koten ~]#fg %1 #放到前台
sleep 500
[root@VMware-koten ~]#kill %1 #终止后台PID为1的进程
sleep 500

screen的使用

1、安装

yum -y install screen

2、使用screen (类似储物袋)

screen 指定一个任务名称后进入到一个新bash中,断开连接也存在

screen -S test_wget 指定名称进去

执行命令

ctrl+a+d 平滑退出

screen -list 查询所有储物空间

screen -r test_wget 指定名字或PID进去

exit 退出并销毁空间

[root@VMware-koten ~]#screen -S test_wget
[root@VMware-koten ~]#wget https://pkg.jenkins.io/redhat-stable/jenkins-2.190.1-1.1.noarch.rpm --no-check-certificate #下载会下载到真正的家目录
#ctrl+a+d退出储物空间
[root@VMware-koten ~]#screen -list
There is a screen on:
    1939.test_wget    (Detached)
1 Socket in /var/run/screen/S-root.
[root@VMware-koten ~]#screen -r 1939 #再次进入指定空间
[root@VMware-koten ~]#  exit  #通过exit退出就没有了
exit
[screen is terminating]
[root@VMware-koten ~]#screen -list
No Sockets found in /var/run/screen/S-root.
[root@VMware-koten ~]#

Nohup的使用(比较常用)

nohup wget https://pkg.jenkins.io/redhat-stable/jenkins-2.190.1-1.1.noarch.rpm --no-check-certificate &

nohup在运行过程中会在当前的目录生成一个nohup.out的临时文件

一般下载不放在后台,是把服务放在后台

nohup python3.5 test.py &

进程的优先级

在启动进程时,为不同的进程使用不同的调度策略

nice值越高,表示优先级越低,例如+19,该进程容易将CPU让给别

nice值越低,表示优先级越高,例如-20,改进程更不倾向于让出CPU

ps查看uid或者top查看,renice -n -20 PID 更改优先级

不要调ssh的优先级,ssh优先级高了,用户访问的就慢了


我是koten,10年运维经验,持续分享运维干货,感谢大家的阅读和关注!

相关实践学习
CentOS 7迁移Anolis OS 7
龙蜥操作系统Anolis OS的体验。Anolis OS 7生态上和依赖管理上保持跟CentOS 7.x兼容,一键式迁移脚本centos2anolis.py。本文为您介绍如何通过AOMS迁移工具实现CentOS 7.x到Anolis OS 7的迁移。
目录
相关文章
|
30天前
|
算法 Linux 调度
深入理解Linux操作系统的进程管理
本文旨在探讨Linux操作系统中的进程管理机制,包括进程的创建、执行、调度和终止等环节。通过对Linux内核中相关模块的分析,揭示其高效的进程管理策略,为开发者提供优化程序性能和资源利用率的参考。
66 1
|
18天前
|
存储 监控 Linux
嵌入式Linux系统编程 — 5.3 times、clock函数获取进程时间
在嵌入式Linux系统编程中,`times`和 `clock`函数是获取进程时间的两个重要工具。`times`函数提供了更详细的进程和子进程时间信息,而 `clock`函数则提供了更简单的处理器时间获取方法。根据具体需求选择合适的函数,可以更有效地进行性能分析和资源管理。通过本文的介绍,希望能帮助您更好地理解和使用这两个函数,提高嵌入式系统编程的效率和效果。
84 13
|
13天前
|
Prometheus 运维 监控
Prometheus+Grafana+NodeExporter:构建出色的Linux监控解决方案,让你的运维更轻松
本文介绍如何使用 Prometheus + Grafana + Node Exporter 搭建 Linux 主机监控系统。Prometheus 负责收集和存储指标数据,Grafana 用于可视化展示,Node Exporter 则采集主机的性能数据。通过 Docker 容器化部署,简化安装配置过程。完成安装后,配置 Prometheus 抓取节点数据,并在 Grafana 中添加数据源及导入仪表盘模板,实现对 Linux 主机的全面监控。整个过程简单易行,帮助运维人员轻松掌握系统状态。
100 3
|
19天前
|
运维 监控 Ubuntu
【运维】如何在Ubuntu中设置一个内存守护进程来确保内存不会溢出
通过设置内存守护进程,可以有效监控和管理系统内存使用情况,防止内存溢出带来的系统崩溃和服务中断。本文介绍了如何在Ubuntu中编写和配置内存守护脚本,并将其设置为systemd服务。通过这种方式,可以在内存使用超过设定阈值时自动采取措施,确保系统稳定运行。
46 4
|
25天前
|
SQL 运维 监控
南大通用GBase 8a MPP Cluster Linux端SQL进程监控工具
南大通用GBase 8a MPP Cluster Linux端SQL进程监控工具
|
1月前
|
运维 监控 Linux
Linux操作系统的守护进程与服务管理深度剖析####
本文作为一篇技术性文章,旨在深入探讨Linux操作系统中守护进程与服务管理的机制、工具及实践策略。不同于传统的摘要概述,本文将以“守护进程的生命周期”为核心线索,串联起Linux服务管理的各个方面,从守护进程的定义与特性出发,逐步深入到Systemd的工作原理、服务单元文件编写、服务状态管理以及故障排查技巧,为读者呈现一幅Linux服务管理的全景图。 ####
|
2月前
|
缓存 监控 Linux
linux进程管理万字详解!!!
本文档介绍了Linux系统中进程管理、系统负载监控、内存监控和磁盘监控的基本概念和常用命令。主要内容包括: 1. **进程管理**: - **进程介绍**:程序与进程的关系、进程的生命周期、查看进程号和父进程号的方法。 - **进程监控命令**:`ps`、`pstree`、`pidof`、`top`、`htop`、`lsof`等命令的使用方法和案例。 - **进程管理命令**:控制信号、`kill`、`pkill`、`killall`、前台和后台运行、`screen`、`nohup`等命令的使用方法和案例。
153 4
linux进程管理万字详解!!!
|
2月前
|
缓存 算法 Linux
Linux内核的心脏:深入理解进程调度器
本文探讨了Linux操作系统中至关重要的组成部分——进程调度器。通过分析其工作原理、调度算法以及在不同场景下的表现,揭示它是如何高效管理CPU资源,确保系统响应性和公平性的。本文旨在为读者提供一个清晰的视图,了解在多任务环境下,Linux是如何智能地分配处理器时间给各个进程的。
|
2月前
|
运维 监控 网络协议
运维工程师日常工作中最常用的20个Linux命令,涵盖文件操作、目录管理、权限设置、系统监控等方面
本文介绍了运维工程师日常工作中最常用的20个Linux命令,涵盖文件操作、目录管理、权限设置、系统监控等方面,旨在帮助读者提高工作效率。从基本的文件查看与编辑,到高级的网络配置与安全管理,这些命令是运维工作中的必备工具。
165 3
|
3月前
|
运维 监控 网络协议

热门文章

最新文章