Linux进程管理

简介: 程序:存放在磁盘中的静态代码(文件)进程:在内存中允许运行的程序,动态的状态进程是资源调度最小的单位线程:线程是存在在进程中的线程(thread)是任务执行的最小单位

@[toc]

程序:存放在磁盘中的静态代码(文件)
进程:在内存中允许运行的程序,动态的状态
进程是资源调度最小的单位
线程:线程是存在在进程中的
线程(thread)是任务执行的最小单位

进程间资源隔离,线程间资源共用

ps命令:

ps 静态查看进程信息
ps aux 查看进程信息(a是all全部,u是用户,x是详细信息)
ps elf 详细查看进程
ps -o 指定内容输出
ps -o tid 查看线程
ps -u 指定用户

使用方法:

查看进程过滤出nginx的进程:
ps -ef | grep nginx

netstat命令:

netstat 查看网络连接情况
-a 查看所有链接
-p 显示pid和进程名
-u 显示UDP
-t 显示TCP
-n 以数字形式显示
-l 显示处于监听状态的连接

使用方法:

查看端口,并过滤出自己想找的端口
netstat -anput | grep 8099

top命令:

top 动态查看进程信息

uptime 查看top第一行

lscpu 查看cpu负载的核数

load average: 0.00, 0.01, 0.05
系统1分钟,5分钟,15分钟平均负载

%Cpu(s): 0.0 us, 0.0 sy, 0.0 ni,100.0 id, 0.0 wa, 0.0 hi, 0.0 si, 0.0 st
CPU使用情况

进程需要占用系统资源(cpu,内存,磁盘,网络,显卡)

CPU密集型
IO密集型

us 用户态CPU
sy 内核态CPU
ni 优先级
id 空闲的CPU
wa 等待输入输出设备的CPU
hi 硬中断
si 软中断
st 虚拟化占用CPU资源

KiB Mem : 995896 total, 487280 free, 121580 used, 387036 buff/cache

buff 写缓冲 解决空间问题
cache 读缓存 解决速率问题

renice优先级:

renice 调整运行进程的优先级
renice -n 优先级等级 pid 进程优先级命令/程序
只有root用户可以设置负值

nice 设置进程运行时的优先级

linux系统中进程状态:

R 运行中的进程
S 睡眠状态(可以中断)
D 不可中断的,通常发生在IO操作
Z 僵尸进程
T 表示停止状态
X 退出状态
W 正在换页
< 高优先级
N 低优先级
s 表示该进程下有子进程
l 多线程
+ 前台运行的进程

僵尸进程:

什么是僵尸进程:

子进程结束,父进程没有回收子进程

解决僵尸进程:

1.重新启动系统
2.杀死父进程,将僵尸进程变为孤儿进程,此时孤儿进程由系统中的systemd接管,会自动清理。


kill -9 pid 根据进程的pid强制杀死某个进程

父进程派生子进程

pstree 查看进程树

yum provides pstree 直接下载不了pstree,就可以利用这个命令找到pstree是哪个包

结束(杀死)进程:

kill PID 杀进程
killall 进程名 根据进程名杀进程
pkill 根据条件杀进程

在这里插入图片描述

kill -l 查看进程的所有进程
kill -1 HUP挂起进程
kill -2 INT中断进程(与ctrl+c以一样)
kill -3 QUIT退出
kill -9 KILL强制杀进程
kill -15 TERM终止进程
kill -18 CONT继续进程
kill -19 STOP暂停进程

常用的杀进程是:

kill -9 进程pid

pgrep命令:

pgrep 根据特定条件查进程
-l 根据进程名查进程的PID
-u 根据用户名或用户id查进程的pid

pidof 进程名 根据进程查进程号

在这里插入图片描述              总文章在:Linux常用命令在这里插入图片描述

目录
相关文章
|
2月前
|
算法 Linux 调度
深入理解Linux操作系统的进程管理
本文旨在探讨Linux操作系统中的进程管理机制,包括进程的创建、执行、调度和终止等环节。通过对Linux内核中相关模块的分析,揭示其高效的进程管理策略,为开发者提供优化程序性能和资源利用率的参考。
110 1
|
4天前
|
存储 网络协议 Linux
【Linux】进程IO|系统调用|open|write|文件描述符fd|封装|理解一切皆文件
本文详细介绍了Linux中的进程IO与系统调用,包括 `open`、`write`、`read`和 `close`函数及其用法,解释了文件描述符(fd)的概念,并深入探讨了Linux中的“一切皆文件”思想。这种设计极大地简化了系统编程,使得处理不同类型的IO设备变得更加一致和简单。通过本文的学习,您应该能够更好地理解和应用Linux中的进程IO操作,提高系统编程的效率和能力。
50 34
|
8天前
|
消息中间件 Linux C++
c++ linux通过实现独立进程之间的通信和传递字符串 demo
的进程间通信机制,适用于父子进程之间的数据传输。希望本文能帮助您更好地理解和应用Linux管道,提升开发效率。 在实际开发中,除了管道,还可以根据具体需求选择消息队列、共享内存、套接字等其他进程间通信方
39 16
|
1月前
|
消息中间件 Linux
Linux:进程间通信(共享内存详细讲解以及小项目使用和相关指令、消息队列、信号量)
通过上述讲解和代码示例,您可以理解和实现Linux系统中的进程间通信机制,包括共享内存、消息队列和信号量。这些机制在实际开发中非常重要,能够提高系统的并发处理能力和数据通信效率。希望本文能为您的学习和开发提供实用的指导和帮助。
117 20
|
2月前
|
存储 监控 Linux
嵌入式Linux系统编程 — 5.3 times、clock函数获取进程时间
在嵌入式Linux系统编程中,`times`和 `clock`函数是获取进程时间的两个重要工具。`times`函数提供了更详细的进程和子进程时间信息,而 `clock`函数则提供了更简单的处理器时间获取方法。根据具体需求选择合适的函数,可以更有效地进行性能分析和资源管理。通过本文的介绍,希望能帮助您更好地理解和使用这两个函数,提高嵌入式系统编程的效率和效果。
121 13
|
2月前
|
SQL 运维 监控
南大通用GBase 8a MPP Cluster Linux端SQL进程监控工具
南大通用GBase 8a MPP Cluster Linux端SQL进程监控工具
|
3月前
|
缓存 监控 Linux
linux进程管理万字详解!!!
本文档介绍了Linux系统中进程管理、系统负载监控、内存监控和磁盘监控的基本概念和常用命令。主要内容包括: 1. **进程管理**: - **进程介绍**:程序与进程的关系、进程的生命周期、查看进程号和父进程号的方法。 - **进程监控命令**:`ps`、`pstree`、`pidof`、`top`、`htop`、`lsof`等命令的使用方法和案例。 - **进程管理命令**:控制信号、`kill`、`pkill`、`killall`、前台和后台运行、`screen`、`nohup`等命令的使用方法和案例。
219 4
linux进程管理万字详解!!!
|
2月前
|
运维 监控 Linux
Linux操作系统的守护进程与服务管理深度剖析####
本文作为一篇技术性文章,旨在深入探讨Linux操作系统中守护进程与服务管理的机制、工具及实践策略。不同于传统的摘要概述,本文将以“守护进程的生命周期”为核心线索,串联起Linux服务管理的各个方面,从守护进程的定义与特性出发,逐步深入到Systemd的工作原理、服务单元文件编写、服务状态管理以及故障排查技巧,为读者呈现一幅Linux服务管理的全景图。 ####
|
3月前
|
缓存 算法 Linux
Linux内核的心脏:深入理解进程调度器
本文探讨了Linux操作系统中至关重要的组成部分——进程调度器。通过分析其工作原理、调度算法以及在不同场景下的表现,揭示它是如何高效管理CPU资源,确保系统响应性和公平性的。本文旨在为读者提供一个清晰的视图,了解在多任务环境下,Linux是如何智能地分配处理器时间给各个进程的。
|
3月前
|
存储 运维 监控
深入Linux基础:文件系统与进程管理详解
深入Linux基础:文件系统与进程管理详解
107 8