RHCE9学习指南 第17章 进程管理

在这里插入图片描述

17.1 进程介绍

在Windows下打开任务管理器就可以查看到系统所有进程,如图17-1所示。
file
图17-1 Windows下的任务管理器
这里列出了系统中所有的进程。不过也可以使用命令行工具来查看进程。每个进程都会有一个process ID,简称为pid。

17.2 查看进程

也可以使用ps命令来查看系统中的进程,当执行不加任何选项的ps时显示的是当前终端的进程,命令如下。

[root@server ~]# ps
    PID TTY        TIME CMD
  11667 pts/1      00:00:00 bash
  51848 pts/1      00:00:00 ps
[root@server ~]#

使用ps查看当前终端进程如图17-2所示。
file
图17-2 查看当前终端的进程
有很多进程不属于任何终端,这些进程都是后台进程。如上图,在终端1上运行了A,B两个进程,当在终端1上执行ps命令时只能看到终端1上的三个进程(包括ps本身),看不到其他终端及后台进程。如果想查看系统所有进程,就需要加上选项了。

基本上不同版本的UNIX系统上都有自己的ps命令,但是这些命令却没有一个统一的选项约定,Linux中的ps命令尽可能地包括所有的这些选项以适应不同UNIX背景的人群。所以,Linux中ps包括了UNIX风格和Linux风格的选项,最常见的用法包括ps aux和ps -ef。

ps aux 可以列出系统中所有的进程,如图17-3所示。
file
图17-3 通过ps aux查看进程的结果
因为ps aux显示内容太多,这里通过head只截取前11行,这里每列的意思如下。

(1)USER:进程所属用户。
(2)PID:进程ID。
(3)%CPU:进程占用CPU百分比。
(4)%MEM:进程占用内存百分比。
(5)VSZ:虚拟内存占用大小      单位:kb。
(6)RSS:实际内存占用大小      单位:kb。
(7)TTY:终端类型。
(8)STAT:进程状态。
(9)START:进程启动时刻。
(10)TIME:进程运行时长。
(11)COMMAND:启动进程的命令。

TTY一列如果是“?”,则说明是后台进程。
练习:
下面练习查看进程信息,先在系统中打开一个Firefox浏览器,如图17-4所示。
file
图17-4 打开一个firefox浏览器
如果要查看某进程的pid可以结合grep一起来使用,例如,查看Firefox的pid,命令如下。

[root@server ~]# ps aux | grep firefox
lduan      53797  ..../usr/lib64/firefox/firefox
lduan      53878  ....childID 1 ... /usr/lib64/firefox/browser 53797 tab
lduan      53963  ...-childID 4 ... /usr/lib64/firefox/browser 53797 tab
lduan      53996  ...-childID 5 ... /usr/lib64/firefox/browser 53797 tab
lduan      54250  ...-childID 7 ... /usr/lib64/firefox/browser 53797 tab
root       55877  0.0  0.0  12348  1148 pts/1    S+   18:30   0:00 grep --color=auto firefox
[root@server ~]# 

在执行此命令时grep命令中也含有firefox关键字,所以也找出来了,明显grep那行并不是我们想要的,所以一般可以再加上grep -v grep过滤,命令如下。

[root@server ~]# ps aux | grep -v grep | grep firefox 
lduan      53797  ..../usr/lib64/firefox/firefox
lduan      53878  ....childID 1 ... /usr/lib64/firefox/browser 53797 tab
lduan      53963  ...-childID 4 ... /usr/lib64/firefox/browser 53797 tab
lduan      53996  ...-childID 5 ... /usr/lib64/firefox/browser 53797 tab
lduan      54250  ...-childID 7 ... /usr/lib64/firefox/browser 53797 tab
[root@server ~]# 

这里可以看到,firefox的主进程的PID是53797,其他几个是对应的子进程。
找出某进程的pid除使用如上的方法外,还可以使用pgrep命令,用法如下。
pgrep 名称
例如,现在要查看firefox的PID,命令如下。

[root@server ~]# pgrep firefox
53797
[root@server ~]#

这里只查看到了firefox主进程的PID,如果要看到每个子进程的PID,需要加-f选项,命令如下。

[root@server ~]# pgrep -f firefox
53797
53878
53963
53996
54250
[root@server ~]#

除了pgrep也可以使用pidof,命令如下。

[root@server ~]# pidof firefox
54250 53996 53963 53878 53797
[root@server ~]#

pidof和pgrep的区别在于,pidof必须要跟上完整的名称,pgrep则不需要,命令如下。

[root@server ~]# pgrep -f firefo
53797
53878
53963
53996
54250
[root@server ~]# pidof firefo
[root@server ~]# 

pgrep会把进程COMMAND中含有firefo的进程的PID全部找出来,pidof找的是COMMAND是firefo的。

对于ps来说,查看的是执行命令那一瞬间的情况,如果想动态的查看进程则可以使用top命令。默认情况下top每隔3s更新一次,可以用-d来指定更新间隔,例如,1秒更新一次可以用top -d 1 指定,如图17-5所示。
file
图17-5 使用top -d 1查看进程的结果
按q退出。

17.3 发送信号

有时可能要关闭进程,单击右上角的“关闭”按钮就可以关闭正在运行的程序,不过有时这种方式是关闭不了,如图17-6所示。
file
图17-6 Windows下关不掉程序的情况

此时单击“关闭程序”选项,强制关闭此程序。

关闭一个正在运行的程序时,本质上是系统给此程序对应的进程发送一个关闭信号。不同的关闭方式,信号是不一样的,查看系统有多少信号可以用kill -l进行查看,如图17-7所示。
file
图17-7 所有能用的信号

也可以用kill命令手动给进程发送信号,这里介绍3个常用的信号,15号信号、9号信号和2号信号。
15号信号,当单击右上角“关闭”按钮去关闭一个程序时,系统发送的就是15号信号,这也是默认信号,在命令行用kill命令时如果不指定信号则是15号。
在后台运行sleep命令,同时也显示了进程的pid,如下所示。

[root@server ~]# sleep 1000 &
[1] 56227
[root@server ~]#

这里可以看到,sleep进程的PID是56227,下面给这个进程发送一个9号信号,命令如下。

[root@server ~]# kill 56227
[root@server ~]# 
[1]+  已终止               sleep 1000
[root@server ~]#

2号信号,当我们按【Ctrl +C】组合键时,本质上就是发送了一个2号信号。运行sleep命令,后面没加 &就是放在前台运行,命令如下。

[root@server ~]# sleep 1000
^C
[root@server ~]#

按【Ctrl+C】组合键会终止正在运行的程序即对对应的进程发送了2号信号。
再次运行sleep命令,并把它放在后台运行,命令如下。

[root@server ~]# sleep 1000 &
[1] 56230
[root@server ~]#

这里sleep进程的PID是56230,给这个进程发送一个2号信号,命令如下。

[root@server ~]# kill -2 56230
[root@server ~]# 
[1]+  中断                  sleep 1000
[root@server ~]#

当一个程序关闭不掉时,需要强制关闭,此时可以对进程发送9号信号,命令如下。

[root@server ~]# sleep 1000 &
[1] 56241
[root@server ~]# kill -9 56241
[root@server ~]# 
[1]+  已杀死               sleep 1000
[root@server ~]#

这样就强制关闭了。
使用kill命令后面需要跟上进程的PID,这里还需要查找出进程的PID,如果想直接杀死某个运行的程序,则可以使用killall命令。先在后台运行几个程序。

[root@server ~]# sleep 1000 &
[1] 56258
[root@server ~]# sleep 1000 &
[2] 56259
[root@server ~]# sleep 1000 &
[3] 56260
[root@server ~]# sleep 1000 &
[4] 56261
[root@server ~]#

这里要杀死所有sleep所对应的进程,命令如下。

[root@server ~]# killall -9 sleep 
[1]   已杀死               sleep 1000
[2]   已杀死               sleep 1000
[3]-  已杀死               sleep 1000
[4]+  已杀死               sleep 1000
[root@server ~]# 

17.4 进程优先级

系统中所有的进程都要消耗CPU的资源,CPU会为每个进程分配一个时间片,轮到某进程了则CPU会处理这个进程的请求,时间片到期,则会把进程暂停放回队列等待下一轮的时间片。在同一颗CPU上如果运行了太多的程序就会导致CPU的资源不够,可以调整进程的优先级,让指定进程获取更多的资源,更优先地去执行。

好比在驾校学车时,教练车就是CPU资源,每个学员就是一个个等待的进程。每个学员上车练习10分(时间片),10分钟过了之后就要下车让下一个学员上车练习,再次练习需要等待下一轮。如果学员太多等待的时间就会很久,如果想多练习一些,可以让教练设置下优先级,别人练习一次10分钟,我练习一次2小时即可。

进程的优先级有两个值决定:优先顺序(priority)和优先级(niceness),其中优先顺序由内核对它进行动态的更改我们不需要做太多干预,对用户而言,只需要通过nice来修改即可。nice值的取值范围在-20~19,nice的值越小进程就越优先执行。

多个进程如果运行在不同的CPU上是互不干扰的,不会发生抢资源的情况,进程只有运行在同一颗CPU上才会发生资源的抢占。所以,做实验时要确保多个进程是运行在同一颗CPU上的,首先查看一下CPU的情况,命令如下。

[root@server ~]# lscpu 
架构:           x86_64
CPU 运行模式:  32-bit, 64-bit
字节序:         Little Endian
CPU:             2
在线 CPU 列表:  0,1
每个核的线程数: 1
...
[root@server ~]# 

可以看到,现在有两颗CPU(一颗CPU两个核认为是2颗CPU)编号分别是0和1,现在关闭1号CPU,命令如下。

[root@server ~]# echo 0 > /sys/devices/system/cpu/cpu1/online 
[root@server ~]# lscpu 
架构:           x86_64
CPU 运行模式:   32-bit, 64-bit
字节序:         Little Endian
CPU:              2
在线 CPU 列表:  0
离线 CPU 列表:  1
每个核的线程数: 1
	...输出...
[root@server ~]# 

这样就可以看到1号CPU已经离线了,注意/sys/devices/system/cpu/cpu1/online中的值如果是0则表示CPU离线,如果是1则表示CPU在线。
下面运行两个cat进程,命令如下。

[root@server ~]# cat /dev/zero > /dev/null &
[1] 56550
[root@server ~]# cat /dev/zero > /dev/null &
[2] 56551
[root@server ~]#

然后再打开一个终端用top 进行查看,结果如图17-8所示。
file
图17-8 两个cat的CPU的消耗基本差不多
可以看到,两个cat进程消耗的CPU是差不多的,因为他们nice值相同,可以平等的消耗CPU资源。下面使用renice修改进程56550的nice值,改为-10,命令如下。

[root@server ~]# renice -n -10 56550
56550 (process ID) 旧优先级为 0,新优先级为 -10
[root@server ~]#

这样进程56550进程会比56551占用更多的CPU资源,再次到top中查看,结果如图17-9所示。
file
图17-9 一个cat被改变了优先级
可以看到,56550占用的资源比56551多了很多。
刚才讲nice越小越可得到更多CPU资源,越大越不容易抢到资源,这里改成最大值19,命令如下。

[root@server ~]# renice -n 19 56550
56550 (process ID) 旧优先级为 -10,新优先级为 19
[root@server ~]#

然后再到top中查看,结果如图17-10所示。
file
图17-10 一个cat被改变了优先级
可以看到,56550只获取到了很少的CPU资源。

关闭cat进程,命令如下。

[root@server ~]# killall -9 cat
[root@server ~]# 
[1]-  已杀死               cat /dev/zero > /dev/null
[2]+  已杀死               cat /dev/zero > /dev/null
[root@server ~]

刚才是在程序运行起来之后再使用renice修改的nice值,也可以直接以某个特定的nice启动进程,只要在运行的命令前面加上nice -n 优先级即可,命令如下。

[root@server ~]# nice -n 10 cat /dev/zero > /dev/null &
[1] 56613
[root@server ~]#

关闭这个cat进程,命令如下。

[root@server ~]# killall -9 cat
[root@server ~]# 
[1]+  已杀死               nice -n 10 cat /dev/zero > /dev/null
[root@server ~]#

开启1号CPU,命令如下。

[root@server ~]# echo 1 > /sys/devices/system/cpu/cpu1/online 
[root@server ~]# 

作业

  1. 下面哪个命令能查出Firefox的pid?
    a. pgrep firefo
    b. pidof firefo
    c. ps aux | grep -v firefox
    d. ps aux | grep firefox

2.下面哪个命令可以把pid=1000的进程杀死?
a. kill
b. killall

3.假设系统中存在firefox进程,请用一条命令杀死firefox进程。

方法1______________________________

方法2______________________________

4.现在Firefox在系统中运行,请写出三种方法查询Firefox pid的命令。

方法1____________________________

方法2____________________________

方法3____________________________

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/307164.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

解决录制的 mp4 视频文件在 windows 无法播放的问题

解决录制的 mp4 视频文件在 windows 无法播放的问题 kazam 默认录制保存下来的 mp4 视频文件在 windows 中是无法直接使用的,这是由于视频编码方式的问题。解决办法: 首先安装 ffmeg 编码工具: sudo apt-get install ffmpeg 然后改变视频的…

鸿鹄云商B2B2C:JAVA实现的商家间直播带货商城系统概览

【saas云平台】打造全行业全渠道全场景的saas产品,为经营场景提供一体化解决方案;门店经营区域化、网店经营一体化,本地化、全方位、一站式服务,为多门店提供统一运营解决方案;提供丰富多样的营销玩法覆盖所有经营场景…

使用Python打造一个爱奇艺热播好剧提前搜系统

目录 一、系统功能设计 二、数据获取与处理 三、搜索功能实现 四、用户界面设计 五、系统部署与维护 六、总结 随着互联网的普及和人们对于娱乐需求的增加,视频网站成为了人们观看电视剧、电影等视频内容的主要渠道。爱奇艺作为国内知名的视频网站之一&#x…

ChatGLM3-6B的本地api调用

ChatGLM3-6B的本地api调用方式 1.运行openai_api_demo路径下的openai_api.py 启动后界面: 注意:本地api调到的前提是——本地部署了ChatGLM3-6B,本地部署的教程可参考: 20分钟部署ChatGLM3-6B 部署了若CUDA可用,默认会以CUDA方…

【读书笔记】《白帽子讲web安全》浏览器安全

目录 第二篇 客户端脚本安全 第2章 浏览器安全 2.1同源策略 2.2浏览器沙箱 2.3恶意网址拦截 2.4高速发展的浏览器安全 第二篇 客户端脚本安全 第2章 浏览器安全 近年来随着互联网的发展,人们发现浏览器才是互联网最大的入口,绝大多数用户使用互联…

锂电池制造设备中分布式IO模块优势

在“碳达峰、碳中和”目标推动下,新能源汽车当下发展势头正盛,而纯电动车的核心部件则是:锂电池。动力型锂电池作为新能源汽车核心零部件,其发展与新能源汽车行业息息相关,迎来广阔的市场空间。 为何采用I/O模块&#…

【python可视化大屏】使用python实现可拖拽数据可视化大屏

介绍: 我在前几期分享了关于爬取weibo评论的爬虫,同时也分享了如何去进行数据可视化的操作。但是之前的可视化都是单独的,没有办法在一个界面上展示的。这样一来呢,大家在看的时候其实是很不方便的,就是没有办法一目了…

centos安装redis并配置开机自启动

目录 前言 redis安装 1、下载redis 2、安装redis 3、修改配置文件 redis配置服务并实现开机自启动 前言 Redis(Remote Dictionary Server)是一个开源的内存数据结构存储系统,它支持多种数据结构,包括字符串、哈希表、列表、集…

毛泽东,如何熬过人生至暗时刻?

文章目录 一、8年内三次蒙冤1、第一次蒙冤2、第二次蒙冤3、第三次蒙冤 二、毛泽东是怎么面对逆境的?三、极致的乐观精神四、结语参考文献 一件事,你做对了,立了功,但结果却是严厉的惩罚,甚至让你回到原点,你…

Fiddler -- https配置

首先,我们先在官网(https://www.telerik.com/fiddler)下载fiddler 下载好后双击 “.exe” 文件即完成安装 配置HTTPS 打开fiddler,在tools --> options --> https – 一次性勾选所有内容,点击 OK,…

Web开发SpringBoot SpringMVC Spring的学习笔记(包含开发常用工具类)

开发框架学习笔记 一.Spring SpringMVC SpringBoot三者的联系SpringMVC工作原理 二.SpringBoot的学习框架学习 2.各个类之间的继承和实现关系3.理解面向对象的思想(其实这个想写在2中的)四.开发常用工具Lombok4.0说在前面(如何快速使用Lombok)4.1了解Lombok4.2Lombok的作用一:减…

BERT Intro

继续NLP的学习,看完理论之后再看看实践,然后就可以上手去kaggle做那个入门的project了orz。 参考: 1810.04805.pdf (arxiv.org) BERT 论文逐段精读【论文精读】_哔哩哔哩_bilibili (强推!)2023李宏毅讲解大模型鼻祖BERT,一小时…

2023年后,AI 还有什么研究方向有前景?

什么是AI ​ AI代表人工智能,它是指通过计算机科学技术使机器能够执行需要智力的任务的一种技术。这些任务包括学习、推理、问题解决和感知等,通常是人类智能的表现。人工智能的目标是使计算机系统能够执行需要人类智力的任务,而不需要人类的…

一文读懂服务器带外管理

带外管理 服务器带外管理(Out-of-Band Management)是指在服务器正常运行时,通过专门的管理通道对服务器进行监控、配置和控制,而无需依赖服务器的主操作系统 管理通道是独立于服务器主处理器和操作系统的,通常是通过专…

世邦spon IP网络对讲广播系统任意文件上传漏洞

产品介绍 世邦通信IP网络对讲广播系统采用领先的IPAudio™技术,将音频信号以数据包形式在局域网和广域网上进行传送,是一套纯数字传输系统。 漏洞描述 spon IP网络对讲广播系统存在任意文件上传漏洞,攻击者可以通过构造特殊请求包上传恶意后门文件,从…

5.MapReduce之Combiner-预聚合

目录 概述本地预计算 Combiner 意义实践前提代码日志观察 结束 概述 在 MR、Spark、Flink 中,常用的减少网络传输的手段。 通常在 Reducer 端合并,shuffle 的数据量比在 Mapper 端要大,根据业务情况及数据量极大时,将大幅度降低效…

前端-基础 表格标签 - 基本使用及表头单元格 详解

基本使用 : 主要作用 : 即 主要 用于显示,展示数据,因为它可以让数据显示的非常的规整,可读性非常好。 特别是后台展示数据的时候,能够熟练运用表格就显得很重要。 一个清爽简约的表格能够把繁杂 的…

TOPS、MIPS、DMIPS、MFLOPS、吞吐量与推理效率

1.概述 在深度学习对应的神经推理中经常涉及几个重要概念,TOPS、MIPS、DMIPS,MFLOPS,下文对其做对比说明。 2.概念对比 2.1 MIPS Million Instructions Per Second的缩写,每秒处理的百万级的机器语言instructions。这是衡量处…

coredump+gdb调试

1、什么是coredump Coredump(核心转储)是操作系统在程序异常终止(例如由于段错误或其他严重错误)时创建的一种文件。这个文件包含了程序崩溃时刻进程的内存镜像,通常还包括程序计数器、寄存器内容和堆栈内存等信息&am…

我在考 pmp,想知道如何去学习 pmbok?

PMP新版大纲加入了ACP敏捷管理的内容,而且还不少,敏捷混合题型占到了 50%,很多人都觉得考试难度提升了,我最开始备考的时候也被折磨过一段时间,但是后面还是找到了方法,3A通过了考试,也算有点经…