Linux系列之进程管理
前言
进程是正在运行的程序,Linux系统通常有数百个进程同时运行。本文就来介绍下Linux是如何进行进程管理的。
我们可以看到:
- 查看进程(Viewing processes)
- 查找进程(Finding processes)
- 管理进程(Managing processes)
- 进程的优先级(Prioritizing processes)
- 杀死进程(Killing processes)
- 在后台运行进程(Running processes in the background)
- 调度进程(Scheduling processes)
查看进程
ps
Linux内核在创建进程时,会按顺序给每个进程分配一个唯一的进程ID(PID)。一般来说,在进程上执行任何操作,我们必须指定PID,有时我们可以使用名称。
ps命令是查看进程的主要工具。不使用任何选项来运行该命令,会列出当前登录用户所启动(调用)的进程,以及终端上正在运行的进程。
如果我们添加了aux选项:
a= 显示所有用户的进程u= 显示进程的用户/所有者x= 显示未连接到终端的进程
进程按照它们被启动的顺序进行展示,因此你会看到列表是根据PID进行排序的。
让我们简单来看看下面几列的信息:
USER:调用进程的用户。PID:进程的ID。%CPU:进程占用CPU的百分比。%MEM:进程占用内存的百分比。COMMAND:启动进程的命令。
查找命令
grep
我们可以使用grep命令来查找指定的进程,假设我们想要查找所有名称中包含mfsconsole的进程。
ps aux | grep msfconsole
top
我们可以使用top命令来动态地罗列出,按照资源使用情况排序的进程,从最大的开始罗列。默认情况下,该列表将每3秒刷新一次。
top
管理进程
优先级
内核对进程的优先级有最终决定权,但是我们可以使用nice命令,来建议应该提升进程的优先级。nice命令的值范围是从-20(最有可能得到优先权)到+19(最不可能得到优先权)。
较高的nice值转换为低优先级,较低的nice值转换为高优先级。
当一个进程启动后,所有的标准进程都以nice值0来进行启动。
我们可以使用nice命令来设置一个进程启动时的nice值,我们可以使用renice来调整一个运行中的进程的nice值。
当我们使用nice命令启动一个进程但没有提供任何值时,默认的nice值是10。
nice命令要求你递增nice值,renice命令想要一个绝对的nice值。
设置优先级
我们可以使用nice命令来调整一个程序的nice值。这允许我们提高或降低内核提供给该进程的优先级,相对于其他进程而言。
在左边,我执行watch -n1 free 来展示系统内存使用情况的细节。在右边,我让top命令运行,你可以看到watch命令的PID是9717,nice的值为0。
让我们继续执行watch命令,只不过这次是用nice命令。
nice -15 watch -n1 free
现在我们可以看到watch的nice值为15。这里要牢记的几件事:
- 这个
watch命令的PID与之前的watch命令不同。这是因为nice会启动一个新的进程,而不是更改一个现有的进程。 nice命令后面的-15意味着15。如果我们想要指定一个负数(高优先级),我们可以使用双中划线-。- 下面是执行
sudo nice --10 watch -n1 free后的样子。是的,如果你要提高优先级,你必须使用sudo。任何人都可以降低优先级,但只有sudo可以提高优先级。
改变优先级
renice命令接收-20到19的绝对值,并接收进程的PID。
让我们再次运行watch命令。
watch -n1 free
让我们来检查下nice值,既然我们没有指定nice值,它应该为0。比起使用top,这里我将会使用ps和grep,用以简化输出。
我们可以看到,第八列的值为0,该值为nice的值,PID的值位于第三列。让我们使用renice试试:
sudo renice -15 14318
我们可以看到,现在nice的值是-15。我们也可以使用top工具来改变nice值。
在top中,按下R键,并提供一个PID:
按下回车键,并提供一个新的nice值:
top成功的改变了nice值:
杀死进程
kill
你可以通过kill命令来停止一个有问题的进程。kill命令有64种不同的kill信号,以及语法是kill -signal PID 。如果没有显示的提供信号位,将会默认为SIGTERM 。这里我将重点介绍以下几种:
| 信号名称 | 数值 | 描述 |
|---|---|---|
| SIGHUP | 1 | 挂断(HUP)信号。它停止指定的进程,并以相同的PID重新启动它。 |
| SIGINIT | 2 | 中断(INT)信号。这是一个微弱的kill信号,不保证能起作用,但确实有这样的情况。 |
| SIGQUIT | 3 | 核心转储。终止进程并将进程信息保存在内存中,然后它将这些信息保存在当前工作目录下一个名为core的文件中。 |
| SIGTERM | 15 | 终止(TERM)信号。它是kill命令的默认kill信号。 |
| SIGKILL | 9 | 这是一个绝对的kill信号。它通过将进程的资源发送到一个特殊的设备/dev/null来迫使进程停止。 |
下面的命令会通过HUP信号来重启我们的watch命令。
kill -1 14318
下面的命令会确保进程被终止。
kill -9 16318
如果我们不知道PID,我们可以使用killall命令,它接收进程的名称。
killall -9 watch
在后台运行进程
&
当你执行一个命令时,shell会进行等待,直到命令完成后才提供另一个命令提示。我们可以在后台运行一个进程,它将继续运行而不需要终端,把终端腾出来做其他工作。我们在命令的末尾添加&来做到这一点。
geany sample.txt &
geany不再占用整个终端。
fg
我们如何让它回到前台?可以使用带有PID的fg命令。
fg 18345
bg
你也可以使用bg命令来移动一个进程到后台。
bg 18345
调度进程
在Linux中,我们可以使用at和crond来调度进程。crond有点复杂,这里重点介绍at。
at
at命令对于安排一项工作在未来某个时间点运行一次很有用。它设置了atd守护进程。守护进程是一个位于后台的程序,在没有任何用户界面的情况下做自己的事情。
下面是at命令执行进程的时间的语法,时间可以以多种格式提供。
| 时间格式 | 含义 |
|---|---|
| at 7:20pm | Run at 7:20 PM of current day. |
| at 7:20pm June 25 | Run at 7:20 PM on June 25 |
| at now + 20 minutes | Run in 20 minutes |
| at 7:25pm 06/10/2021 | Run at 7:25 pm on June 10, 2021 |
at noon
我们可以看到,at将我们带入了交互模式,在这里我们输入了我们希望在指定时间执行的命令。完成后按下CTRL+D。
atq
使用atq来罗列出所有预定的at工作。
Linux系列之进程管理的更多相关文章
- Linux学习之进程管理(十九)
Linux学习之进程管理 进程查看 查看系统中所有进程,使用BSD操作系统的格式 语法:ps aux 选项: a:显示所有前台进程 x:显示所有后台进程 u:显示这个进程是由哪个用户产生的 语法:ps ...
- 【Linux学习】Linux系统管理1—进程管理
Linux系统管理1-进程管理 一.Linux的三种进程 Linux包括3中不同类型的进程: 交互进程:由一个shell启动的进程.交互进程可以在前后台运行 批处理进程:该进程和终端无联系,是一个进程 ...
- Linux学习之进程管理
|-进程管理 进程常用命令 |- w查看当前系统信息 |- ps进程查看命令 |- kill终止进程 |- 一个存放内存中的特殊目录/p ...
- Linux网络和进程管理
1) 计算机网络是通过外围的设备和连接,将分布在相同或不同区域的多台计算机 连接在一起所形成的集合.网络中的计算机实现彼此间互相通信,并且可以共 同使用硬件.软件和数据资源,实现资源共享.Lin ...
- Linux网络配置&进程管理
原理图 查看ip和网关
- Linux系统分区 进程管理 软件包安装
对于一块新的磁盘来说,系统能够使用需要有分区.格式化文件系统.挂载等主要操作,下面通过命令的方式对一块磁盘进行操作. 一. Linux系统分区 1.1 在虚拟机开机前选择虚拟机配置,添加一个新的SCS ...
- 深入Linux内核架构——进程管理和调度(下)
五.调度器的实现 调度器的任务是在程序之间共享CPU时间,创造并行执行的错觉.该任务可分为调度策略和上下文切换两个不同部分. 1.概观 暂时不考虑实时进程,只考虑CFS调度器.经典的调度器对系统中的进 ...
- 深入Linux内核架构——进程管理和调度(上)
如果系统只有一个处理器,那么给定时刻只有一个程序可以运行.在多处理器系统中,真正并行运行的进程数目取决于物理CPU的数目.内核和处理器建立了多任务的错觉,是通过以很短的间隔在系统运行的应用程序之间不停 ...
- Linux系统编程@进程管理(一)
课程目标: 构建一个基于主机系统的多客户即时通信/聊天室项目 涉及的理论知识 进程控制:僵尸进程/孤儿进程.进程控制.守护进程... 进程间通信:管道.命名管道.信号... 多线程编程: 锁.信号量. ...
随机推荐
- windows 文件hash校验,字符串加密,base64转换工具
对下载的文件使用hash校验验证文件完整性 1 import hashlib 2 def md5(): 3 md5_value = hashlib.md5() 4 with open('C:\Inte ...
- 使用python脚本+zabbix前端监控云联网底层TCP数据流所负载的链路质量,并在丢包时联动保存MTR记录
背景 目前国内各家云联网跨区域数据传输,会将数据流通过哈希运算负载到不同的底层链路上,而底层链路质量差异较大,这种情况导致的现象就是,使用传统的icmp监控线路正常,但是业务一直不稳定,所以才有了使用 ...
- strlen获取字符数组为什么是255
为什么是255呢? strlen函数的规则是,读取到0则判断字符串结束. char为1字节,只有8位. 所以...... -1就是 1111 1111, -2就是 1111 1110, 直到-128: ...
- Spring 源码(14)Spring Bean 的创建过程(6)对象的提前暴露
知识回顾 解析完Bean信息的合并,可以知道Spring在实例化Bean之后,属性填充前,对Bean进行了Bean的合并操作,这里的操作主要做了对Bean对象标记了@Autowired.@Value. ...
- 陈胡:Apache SeaTunnel实现 非CDC数据抽取实践
导读: 随着全球数据量的不断增长,越来越多的业务需要支撑高并发.高可用.可扩展.以及海量的数据存储,在这种情况下,适应各种场景的数据存储技术也不断的产生和发展.与此同时,各种数据库之间的同步与转化的需 ...
- 203. Remove Linked List Elements - LeetCode
Question 203. Remove Linked List Elements Solution 题目大意:从链表中删除给定的数 思路:遍历链表,如果该节点的值等于给的数就删除该节点,注意首节点 ...
- Linux文件拷贝脚本
在工作中,我们经常遇到要从Linux服务器拷贝日志至本地或者定期清理日志的需求,在服务器上,大型系统的日志是按模块存储的,这就导致日志的文件目录较多且层级不统一.我们从众多的目录手工筛选要下载或者删除 ...
- HtmlParse:一款超轻量级的HTML文件解析和爬取工具
HtmlParse 是一款基于windwos平台的HTML文档解析工具,可快速构建DOM树,从而轻松实现网页元素的爬取工作.DOM树就是一个HTML文档的节点树,每个节点由:标签(Tag).属性(At ...
- 26.MySQL数据库基础
MySQL数据库基础 目录 MySQL数据库基础 数据库的概念 数据 表 数据库 数据库的管理系(DBMS) 数据库系统 访问数据库的流程 数据库系统发展史 当今主流数据库介绍 关系数据库 关系数据库 ...
- 【.NET 6】多线程的几种打开方式和代码演示
前言: 多线程无处不在,平常的开发过程中,应该算是最常用的基础技术之一了.以下通过Thread.ThreadPool.再到Task.Parallel.线程锁.线程取消等方面,一步步进行演示多线程的一些 ...