【Linux】3.10 进程管理(重点)
进程管理
1. 进程管理基础
- 在Linux中,每个执行的程序(代码)都称为一个进程。每个进程都分配一个ID号
- 每一个进程,都会对应一个父进程,而这个父进程可以复制多个子进程。例如www服务器。
- 每个进程都可能以两种方式存在。前台和后台。
- 前台进程:用户目前的屏幕上可以进行操作的。
- 后台进程:实际在操作,但由于屏幕上无法看到的进程,通常使用后台方式执行。
- 一般系统的服务都是以后台进程的方式存在,而且都会常驻在系统中,直到关机才结束。
2. 显示系统执行的进程
2.1 ps指令详细介绍
ps [选项]:查看目前系统中,有哪些正在执行,以及它们执行的状况
- ps -a:显示当前终端的所有进程信息。
- ps -u:以用户的格式显示进程信息。
- ps -x:显示后台进程运行的参数。
- ps -axu | grep xxx:过滤得到xxx的信息。
- ps -ef:以全格式显示当前所有的进程,查看进程的父进程。
- -e:显示所有进程。
- -f:全格式。
ps -axu显示信息选项

System V 展示风格
| 字段 | 说明 |
|---|---|
| USER | 用户说明 |
| PID | 进程识别号 |
| %CPU | 进程占用cpu百分比 |
| %MEM | 进程占用物理内存百分比 |
| VSZ | 进程占用虚拟内存大小(KB) |
| RSS | 进程占用物理内存大小(KB) |
| TTY | 终端机号 |
| STAT | 进程状态,S睡眠,s代表是会话的先导进程,N代表进程拥有比普通进程更高的优先级,R正在运行,D短期等待,Z僵死进程,T被跟踪或被停止 |
| STARTED | 进程启动的时间 |
| TIME | 此进程所消耗的CPU时间 |
| COMMAND | 正在执行的命令或进程名 |
ps -ef显示信息解释

BSD展示风格
| 字段 | 说明 |
|---|---|
| UID | 用户id |
| PID | 进程id |
| PPID | 父进程 |
| C | CPU用于执行优先级的因子,数值越大,表明cpu密集型运算,执行优先级会降低,数值越小,表明是I/O密集运算,执行优先级会提高 |
| STIME | 进程启动时间 |
| TTY | 终端机号 |
| TIME | 此进程所消耗的CPU时间 |
| CMD | 启动所用的命令和参数 |
3. 终止进程
若是某个进程执行一半需要停止时,或是消耗了很大的系统资源时,此时可以考虑停止该进程,使用kill命令来完成此任务
- kill [选项] 进程号:通过进程号杀死进程
- -9:表示强迫进程立刻停止
- killall 进程名称:通过进程名称杀死进程,也支持通配符,这在系统因负载过大而变得很慢时很有用
案例1:踢掉某个非法用户

案例2:终止远程服务

案例3:终止多个gedit编辑器

案例4: 强制杀掉一个终端

4. 查看进程树
- 查看进程树:pstree [选项]
- -p:显示进程的PID
- -u:显示进程的所属用户
5. 服务(Service)管理
服务(Service)本质就是进程,但是是运行在后台的,通常都会监听某个端口,等待其它程序的请求,比如(mysql,sshd 防火墙等),因此我们又称为守护进程。

5.1 service管理指令
service管理指令:service 服务名 [start | stop | restart | reload | status]
在CentOS7.0之后,不再使用service,而是systemctl
查看防火墙情况:
- service iptables status
- systemctl status firewalld(7.0之后的版本)

测试某个端口是否在监听:telnet
5.2 服务查看方式
方式1:setup指令

方式2:ls -l /etc/init.d/
5.3 服务的运行级别(runlevel)
- 查看或修改默认级别:vim /etc/inittab
- 每个服务对应的每个运行级别都可以设置
详细见3.5实用指令第一部分
5.4 开机流程

5.5 chkconfig指令
chkconfig:可以给每个服务的各个运行级别设置自启动/关闭
5.5.1 基本语法
- 查看xxx服务:chkconfig –list | grep xxx
- 查看服务的状态:chkconfig 服务名 --list
- 给服务的运行级别设置自启动:chkconfig –level 5 服务名 on/off
- 要所有运行级别关闭或开启:chkconfig 服务名 on/off
- chkconfig重新设置后需要重新启动才能生效
6. 动态监控进程
top与ps相似,都是用来显示正在执行的进程,top的不同之处在于top执行一段时间可以更新正在运行的进程
6.1 基本语法
top [选项]
- -d 秒数:指定top命令每隔几秒更新。默认是3秒。
- -i:使top不显示任何闲置或者僵死进程。
- -p:通过指定监控进程ID来仅仅监控某个进程的状态。
- 交互操作说明:
| 操作 | 功能 |
|---|---|
| P | 以CPU使用率排序,默认就是此项 |
| M | 以内存的使用率排序 |
| N | 以PID排序 |
| q | 退出top |
动态进程监控图例

6.2 应用案例
6.2.1 监控特定用户
- top查看进程;
- u
- 输入用户名。
6.2.2 终止指定的进程
- top查看进程;
- k输入要结束的进程。
7. 查看网络情况
7.1 基本语法
netstat [选项]
- -an:按一定顺序排列输出
- -p:显示哪个进程在调用
7.2 应用案例
查看所有的网络服务
- netstat -anp | more
查看sshd的服务的信息
- netstat -anp | grep sshd
【Linux】3.10 进程管理(重点)的更多相关文章
- Linux系统管理10——进程和计划任务管理
Linux系统管理10——进程和计划任务管理 一.程序和进程的关系 1.程序 ·保存在硬盘.光盘等介质中的可执行代码和数据 ·静态保存的代码 2.进程 ·在CPU及内存中运行的程序代码 ·动态执行的代 ...
- Linux学习之进程管理(十九)
Linux学习之进程管理 进程查看 查看系统中所有进程,使用BSD操作系统的格式 语法:ps aux 选项: a:显示所有前台进程 x:显示所有后台进程 u:显示这个进程是由哪个用户产生的 语法:ps ...
- 【Linux学习】Linux系统管理1—进程管理
Linux系统管理1-进程管理 一.Linux的三种进程 Linux包括3中不同类型的进程: 交互进程:由一个shell启动的进程.交互进程可以在前后台运行 批处理进程:该进程和终端无联系,是一个进程 ...
- Linux系列之进程管理
前言 进程是正在运行的程序,Linux系统通常有数百个进程同时运行.本文就来介绍下Linux是如何进行进程管理的. 我们可以看到: 查看进程(Viewing processes) 查找进程(Findi ...
- Linux学习之进程管理
|-进程管理 进程常用命令 |- w查看当前系统信息 |- ps进程查看命令 |- kill终止进程 |- 一个存放内存中的特殊目录/p ...
- Linux网络和进程管理
1) 计算机网络是通过外围的设备和连接,将分布在相同或不同区域的多台计算机 连接在一起所形成的集合.网络中的计算机实现彼此间互相通信,并且可以共 同使用硬件.软件和数据资源,实现资源共享.Lin ...
- Linux网络配置&进程管理
原理图 查看ip和网关
- 深入Linux内核架构——进程管理和调度(下)
五.调度器的实现 调度器的任务是在程序之间共享CPU时间,创造并行执行的错觉.该任务可分为调度策略和上下文切换两个不同部分. 1.概观 暂时不考虑实时进程,只考虑CFS调度器.经典的调度器对系统中的进 ...
- Linux系统编程@进程管理(一)
课程目标: 构建一个基于主机系统的多客户即时通信/聊天室项目 涉及的理论知识 进程控制:僵尸进程/孤儿进程.进程控制.守护进程... 进程间通信:管道.命名管道.信号... 多线程编程: 锁.信号量. ...
- Linux进阶之进程管理
本节内容 1.进程管理 2.ps 3.uptime 4.top 5.ss -tnl------ lsof -i :22 一. 进程管理的概念 程序:二进制文件,静态 /bin/date,/usr/sb ...
随机推荐
- torque提交作业
PBS(Protable Batch System)是功能最为齐全,历史最悠久,支持最广泛的本地集群调度器之一. PBS的目前包括openPBS,PBS Pro和Torque三个主要分支.其中Open ...
- pip在线安装
# 下载安装脚本 curl https://bootstrap.pypa.io/get-pip.py -o get-pip.py # 运行安装脚本 sudo python3 get-pip.py # ...
- 为什么 .NET8线程池 容易引发线程饥饿
一:背景 1. 讲故事 最近时间相对比较宽裕,多写点文章来充实社区吧,这篇文章主要还是来自于最近遇到的几例线程饥饿(Task.Result)引发的一系列的反思和总结,我觉得.NET8容易引发饥饿的原因 ...
- Springboot 整合 xxl-job
前言 很久很久以前写过好几篇关于定时任务的使用系列的文章: 这一篇是最简单的,就是单纯跑跑定时任务,那你看这篇就行,没必要用xxljob(因为xxljob要跑服务端,然后自己服务作为客户端接入): 文 ...
- Netty的实现原理、特点与优势、以及适用场景
Netty 1.介绍 Netty是由JBOSS提供的一个java开源框架. Netty是一个高性能.异步事件驱动的NIO框架,它提供了对TCP.UDP和文件传输的支持.作为当前最流行的NIO框架,Ne ...
- java多线程---总结(2)
ThreadPoolExecutor 官方API解释线程池的好处: (1)通过重用线程池中的线程,来减少每个线程创建和销毁的性能开销. (2)对线程进行一些维护和管理,比如定时开始,周期执行,并发数控 ...
- 一个简易socket通信结构
服务端 基本的结构 工作需要又需要用到socketTCP通讯,这么多年了,终于稍微能写点了.让我说其实也说不出个啥来,看了很多的异步后稍微对异步socket的导流 endreceive后 再begin ...
- DPDK简介和原理
本文分享自天翼云开发者社区<DPDK简介和原理>,作者:s****n DPDK是一种绕过内核直接在用户态收发包来解决内核性能的瓶颈技术. 什么是中断 了解DPDK之前,首先需要先了解什么是 ...
- 【Spring】Spring的@Autowire注入Bean的规则测试
背景 在项目中使用Spring的Bean,一般都使用默认的Bean的单例,并且结合@Autowire使用. 实在有同一个类型多个实例的情况,也使用@Qualifier或@Resource实现注入. 所 ...
- 2024.11.21随笔&联考总结(补)
前言 都过了几天了,但是还是大概写一下吧,希望不要耽误太多时间. 考试 第一题签到题直接做. 第二题一眼是矩阵乘法优化 dp,然后大概看了几眼先不管去看第三题.然后第三题是数学题,感觉很可做.然后看到 ...