【运维知识基础篇】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的迁移。
目录
相关文章
|
1月前
|
资源调度 Linux 调度
Linux c/c++之进程基础
这篇文章主要介绍了Linux下C/C++进程的基本概念、组成、模式、运行和状态,以及如何使用系统调用创建和管理进程。
37 0
|
17天前
|
缓存 监控 Linux
linux进程管理万字详解!!!
本文档介绍了Linux系统中进程管理、系统负载监控、内存监控和磁盘监控的基本概念和常用命令。主要内容包括: 1. **进程管理**: - **进程介绍**:程序与进程的关系、进程的生命周期、查看进程号和父进程号的方法。 - **进程监控命令**:`ps`、`pstree`、`pidof`、`top`、`htop`、`lsof`等命令的使用方法和案例。 - **进程管理命令**:控制信号、`kill`、`pkill`、`killall`、前台和后台运行、`screen`、`nohup`等命令的使用方法和案例。
50 4
linux进程管理万字详解!!!
|
7天前
|
存储 运维 监控
深入Linux基础:文件系统与进程管理详解
深入Linux基础:文件系统与进程管理详解
47 8
|
25天前
|
运维 监控 网络协议
|
11天前
|
缓存 运维 监控
【运维必备知识】Linux系统平均负载与top、uptime命令详解
系统平均负载是衡量Linux服务器性能的关键指标之一。通过使用 `top`和 `uptime`命令,可以实时监控系统的负载情况,帮助运维人员及时发现并解决潜在问题。理解这些工具的输出和意义是确保系统稳定运行的基础。希望本文对Linux系统平均负载及相关命令的详细解析能帮助您更好地进行系统运维和性能优化。
32 3
|
16天前
|
算法 Linux 定位技术
Linux内核中的进程调度算法解析####
【10月更文挑战第29天】 本文深入剖析了Linux操作系统的心脏——内核中至关重要的组成部分之一,即进程调度机制。不同于传统的摘要概述,我们将通过一段引人入胜的故事线来揭开进程调度算法的神秘面纱,展现其背后的精妙设计与复杂逻辑,让读者仿佛跟随一位虚拟的“进程侦探”,一步步探索Linux如何高效、公平地管理众多进程,确保系统资源的最优分配与利用。 ####
50 4
|
17天前
|
缓存 负载均衡 算法
Linux内核中的进程调度算法解析####
本文深入探讨了Linux操作系统核心组件之一——进程调度器,着重分析了其采用的CFS(完全公平调度器)算法。不同于传统摘要对研究背景、方法、结果和结论的概述,本文摘要将直接揭示CFS算法的核心优势及其在现代多核处理器环境下如何实现高效、公平的资源分配,同时简要提及该算法如何优化系统响应时间和吞吐量,为读者快速构建对Linux进程调度机制的认知框架。 ####
|
18天前
|
消息中间件 存储 Linux
|
1月前
|
存储 运维 搜索推荐
|
25天前
|
运维 Linux
Linux查找占用的端口,并杀死进程的简单方法
通过上述步骤和命令,您能够迅速识别并根据实际情况管理Linux系统中占用特定端口的进程。为了获得更全面的服务器管理技巧和解决方案,提供了丰富的资源和专业服务,是您提升运维技能的理想选择。
30 1

热门文章

最新文章