30 linux 新建进程的进程号是如何分配的?

news2024/11/15 23:25:11

前言

呵呵 进程号是我们经常使用到的, 但是 却从来 没有深究过的东西 

这里 就来看一下 具体的进程号的生成方式 

linux 新建进程是以 fork + exec 的形式创建进程的 

子进程 是 复制自 父进程 

pid 是怎么生成的?

分配 pid 的地方调用堆栈如下, fork 之后, 会为 新进程 申请 pid, 具体的地方如下 

分配是基于 pid_namespace 

其中记录的有上一次分配的 pid 的大小, pid 为 上次的pid +1 

然后尝试在 pid_ns 的 pid_bitmap 中尝试更新 pid 为使用, 如果更新成功, 则使用当前 pid 

若果更新不成功, 则在 pid_ns 的 pid_bitmap 中获取下一个可用的索引, 然后 进行重试 

如果当前 pid_bitmap 尝试到末尾依然没有找到可用的 pid, 尝试查找下一块 pid_bitmap [如果当前是 最后一块 pid_bitmap, 则下一个 pid_bitmap 为第一块 pid_bitmap] 

关于这里的多个 pid_bitmap, 默认情况下是只会使用一个 pid_bitmap 

BITS_PER_PAGE 为 4k * 8 = 32768, pid_max 默认为 32768, 因此这里的 pid_bitmap 最多会使用一个元素 

这里的 pid_bitmap 的内存是使用的一个 物理页 来维护的 

按照大多数的正常情况 下一个进程号, 即为最大进程号 + 1 

如果 分配到了 pid_max[默认为 32768], 则从 第一个 pid_bitmap 的 第一个 pid 开始尝试 

测试 pid 的相关规则, 写一个脚本 一直 "ps -l" + "grep ps"

脚本大致如下 

ps -l | grep ps
ps -l | grep ps
ps -l | grep ps
ps -l | grep ps
ps -l | grep ps
ps -l | grep ps
ps -l | grep ps
ps -l | grep ps
ps -l | grep ps
ps -l | grep ps
ps -l | grep ps

测试输出大致如下

... 
R     0 14978   287  4680   844 0:0   06:41 00:00:00 {exe} ps -l
R     0 14979   287  4676   700 0:0   06:41 00:00:00 {exe} grep ps
S     0   287   275  4676  1468 0:0   03:33 00:01:47 {exe} ash ./psCmd.sh
R     0 14980   287  4680   840 0:0   06:41 00:00:00 {exe} ps -l
R     0 14981   287  4676   840 0:0   06:41 00:00:00 {exe} grep ps
S     0   287   275  4676  1468 0:0   03:33 00:01:47 {exe} ash ./psCmd.sh
R     0 14982   287  4680   712 0:0   06:41 00:00:00 {exe} ps -l
R     0 14983   287  4676   784 0:0   06:41 00:00:00 {exe} grep ps
S     0   287   275  4676  1468 0:0   03:33 00:01:47 {exe} ash ./psCmd.sh
R     0 14984   287  4680   792 0:0   06:41 00:00:00 {exe} ps -l
R     0 14985   287  4676   732 0:0   06:41 00:00:00 {exe} grep ps
S     0   287   275  4676  1468 0:0   03:33 00:01:47 {exe} ash ./psCmd.sh
R     0 14986   287  4680   680 0:0   06:41 00:00:00 {exe} ps -l
R     0 14987   287  4676   740 0:0   06:41 00:00:00 {exe} grep ps
S     0   287   275  4676  1468 0:0   03:33 00:01:47 {exe} ash ./psCmd.sh
R     0 14988   287  4680   784 0:0   06:41 00:00:00 {exe} ps -l
R     0 14989   287  4676   792 0:0   06:41 00:00:00 {exe} grep ps
S     0   287   275  4676  1468 0:0   03:33 00:01:47 {exe} ash ./psCmd.sh
R     0 14990   287  4680   696 0:0   06:41 00:00:00 {exe} ps -l
R     0 14991   287  4676   792 0:0   06:41 00:00:00 {exe} grep ps
S     0   287   275  4676  1468 0:0   03:33 00:01:47 {exe} ash ./psCmd.sh
R     0 14992   287  4680   692 0:0   06:41 00:00:00 {exe} ps -l
R     0 14993   287  4676   836 0:0   06:41 00:00:00 {exe} grep ps
S     0   287   275  4676  1468 0:0   03:33 00:01:47 {exe} ash ./psCmd.sh
R     0 14994   287  4680   696 0:0   06:41 00:00:00 {exe} ps -l
R     0 14995   287  4676   712 0:0   06:41 00:00:00 {exe} grep ps
S     0   287   275  4676  1468 0:0   03:33 00:01:47 {exe} ash ./psCmd.sh
R     0 14996   287  4680   716 0:0   06:41 00:00:00 {exe} ps -l
R     0 14997   287  4676   692 0:0   06:41 00:00:00 {exe} grep ps
S     0   287   275  4676  1468 0:0   03:33 00:01:47 {exe} ash ./psCmd.sh
R     0 14998   287  4680   676 0:0   06:41 00:00:00 {exe} ps -l
R     0 14999   287  4676   712 0:0   06:41 00:00:00 {exe} grep ps
S     0   287   275  4676  1468 0:0   03:33 00:01:47 {exe} ash ./psCmd.sh
R     0 15000   287  4680   688 0:0   06:41 00:00:00 {exe} ps -l
R     0 15001   287  4676   740 0:0   06:41 00:00:00 {exe} grep ps

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

全志V3S嵌入式驱动开发(基于usb otg的spi-nand镜像烧入)

【 声明:版权所有,欢迎转载,请勿用于商业用途。 联系信箱:feixiaoxing 163.com】 前面我们说过spi nand驱动,但是这个驱动是建立在linux系统从sd卡加载的情况下进行的。开发测试的情况下,这么做或许是可以的…

PWM详解(嵌入式学习)

这里写目录标题 前言定义参数工作原理应用练习 前言 在STM32微控制器中,PWM代表脉冲宽度调制(Pulse Width Modulation)。PWM是一种用于控制电子设备的技术,通过调整信号的脉冲宽度和周期,可以模拟出不同的电压或功率级…

【python】—— 基础语法(一)

序言: 在之前,我们已经对【python】的开发环境进行了相应的安装,紧接着本期我就讲给大家介绍它的相关语法。对于学过【C/C】或者其他语言的小伙伴来说,语法内容学习起来就会掌握的很快了。 目录 前言 (一&#xff0…

【架构师】零基础到精通——网关策略

博客昵称:架构师Cool 最喜欢的座右铭:一以贯之的努力,不得懈怠的人生。 作者简介:一名退役Coder,软件设计师/鸿蒙高级工程师认证,在备战高级架构师/系统分析师,欢迎关注小弟! 博主小…

vue服务端渲染SSR

一:ssr的理解 1、服务端渲染 Server Side Render SSR解决方案,后端渲染出完整的首屏的dom结构返回,前端拿到的内容包括首屏及完整spa结构,应用激活后依然按照spa方式运行,这种页面渲染方式被称为服务端渲染 (server si…

ISO C++ 26 并发和并行性重大完善

ISO C 委员会举行会议正式通过了 C 26 的时间表。ISO C 标准委员会主席兼微软语言架构师 Herb Sutte,并发和并行小组仍在按计划推进 C26 的 std::execution 和 SIMD 并行 一、 C23 与C 26 开发时间表: 二、C26标准属性三大规则。非正式总结是: [已经在c …

【Python 基础篇】Python数据序列推导式

文章目录 前言一、列表推导式二、字典推导式三、集合推导式总结 前言 在Python中,推导式(Comprehension)是一种简洁而强大的语法,用于快速创建列表、字典和集合。推导式使得在一个简单的语句中就能生成一个新的数据结构&#xff…

忘记Gmail谷歌账号密码或者密码错误怎么办?用这种方法轻松搞定

有些朋友以前注册过谷歌邮箱,但很久很久没有再去使用。现在注册ChatGPT需要谷歌邮箱,于是打算把尘封已久的谷歌邮箱找出来,可是这时候你突然发现,谷歌邮箱的密码忘了。 今天重点来说说如何找回谷歌账号的密码,希望能够…

英语口语进阶:让你的疲劳与口渴表达更地道

前言 🏠个人主页:我是沐风晓月 🧑个人简介:大家好,我是沐风晓月,阿里云社区博客专家 😉😉 💕 座右铭: 先努力成长自己,再帮助更多的人,一起加油进…

Web网页制作期末复习(4)——CSS盒子模型、弹性盒模型(flex box)、文档流、浮动、清除浮动、定位、圆角、阴影

目录 CSS盒子模型 概念 弹性盒模型(flex box) 内容 父元素上的属性 display属性 flex-direction属性 justify-content属性 align-items属性 子元素上的属性 flex 文档流(标准流) 浮动 定义 浮动的原理 清除浮动 …

用OpenCV进行OCR字符分割

1. 引言 本文重点介绍如何利用传统的图像处理的方法来进行OCR字符切分,进而可以用分割后的单个字符做相应的后续任务,虽然现在计算机视觉依然是卷积神经网络的天下,但是对于一些相对简单的落地场景传统方案还是很有效的。 闲话少说&#xff…

底盘线控悬架智能化趋势

摘要: 汽车的底盘主要由行驶系、传动系、转向系和制动系四部分组成,其中行驶系又由汽车的车架、车桥、车轮和悬架等系统组成。底盘的悬架系统不仅是汽车重要的组成部分,而且还关乎到一辆汽车在行驶过程中的质感,影响车辆的操控性…

CSDN周赛59期简要题解

本期题目相对比较友好,而且在比赛报名界面还提示了非编程题考察的章节——诚不欺我: 本期非编程题需要选手阅读的章节是第2章“逆向思考——从递推到递归”—2.3节“堆栈和队列:遍历的数据结构” 选择和判断都考到了栈的数据结构&#xff0…

【MySQL进阶】:子查询与HAVING/SELECT的完美结合

前言 ✨欢迎来到小K的MySQL专栏,本节将为大家带来MySQL子查询在HAVING/SELECT字句中使用、及相关子查询和WITH/EXISTS字句的讲解✨ 目录 前言一、在HAVING/SELECT字句中使用子查询二、相关子查询三、WITH/EXISTS、NOT EXISTS字句四、总结 一、在HAVING/SELECT字句中…

【Python 基础篇】Python 字典及字典常用函数

文章目录 导言一、字典的创建和访问二、字典的增删改查1、增加元素2、删除元素3、修改元素4、查找元素 三、字典常用函数及操作1、len()2、keys()3、values()4、items()5、字典的遍历 总结 导言 在Python中,字典(Dictionary)是一种无序的数据…

使用它或失去它!谷歌即将清理不活跃账号

如果你很长时间没有登录你的谷歌账号,最好尽快登录,否则你很可能会失去账号。 2023年5月16号,谷歌宣布,将开始删除至少两年不活跃的账号。 如果谷歌帐户至少两年未被使用或登录,可能会删除该帐户及其内容,包…

04. 青龙面板通知配置 邮箱 pushPlus 企业微信机器人(保姆级图文)

目录 1. qq邮箱通知2. pushPlus通知3. 企业微信机器人总结 欢迎关注 『青龙面板』 专栏,持续更新中 欢迎关注 『青龙面板』 专栏,持续更新中 1. qq邮箱通知 emailUser:填写你的邮箱 emailPass:填写邮箱密钥授权码 邮箱密钥获取教…

【从零开始学习JAVA | 第六篇】面向对象综合训练

目录 前言: 1.文字版格斗游戏: 2.对象数组1 前言: 前面我们已经讲解了JAVA面向程序对象思想的关键要素:封装。我们将利用本篇进行几个小型的练习,帮助我们更好的理解面向对象编程这种思想。 1.文字版格斗游戏&#x…

C++哈希表

目录 介绍哈希概念哈希冲突哈希函数解决哈希冲突 闭散列介绍线性探测二次探测负载因子 实现哈希表结构哈希函数元素查找插入元素删除元素 开散列介绍实现哈希表结构元素查找插入元素删除元素析构函数 介绍 哈希概念 了解过搜索二叉树与红黑树后,它们的结构特点主要…

8.批量消息发送与批量消息消费

highlight: arduino-light 4.4 批量消息 4.4.1 发送限制 生产者进行消息发送时可以一次发送多条消息,批量发送消息能显著提高传递小消息的性能。 不过需要注意以下几点: 批量发送的消息必须具有相同的Topic批量发送的消息必须具有相同的刷盘策略批量发送…