0

0

Linux /proc/sys/kernel/pid_max 的进程数上限与 32bit/64bit 兼容性

冷漠man

冷漠man

发布时间:2026-02-23 18:48:11

|

837人浏览过

|

来源于php中文网

原创

pid_max 设置不生效需检查是否持久化:临时写入/proc/sys仅当前有效,应配置/etc/sysctl.d/并运行sysctl --system;32位内核默认32768非硬件限制,但建议不超过65536;容器中须在宿主机修改;超限后内核会重试回收僵尸进程而非立即失败。

linux /proc/sys/kernel/pid_max 的进程数上限与 32bit/64bit 兼容性

pid_max 设置后不生效?检查内核是否真的加载了新值

改完 /proc/sys/kernel/pid_max 看似成功,但新进程 PID 还是卡在 32768,大概率是只写了临时值,没持久化或被 systemd/sysctl 覆盖。Linux 内核启动时会从 /etc/sysctl.conf/etc/sysctl.d/*.conf 加载初始值,之后你用 echo 1000000 > /proc/sys/kernel/pid_max 只影响当前运行时——一旦重启就回退。

  • 确认当前生效值:cat /proc/sys/kernel/pid_max
  • 写入永久配置:在 /etc/sysctl.d/99-pidmax.conf 里加一行 kernel.pid_max = 1048576,再执行 sysctl --system
  • 注意 systemd 环境下,systemd-sysctl 服务可能在 boot 时覆盖手动 echo 的值,所以必须走 sysctl 配置文件路径

32bit 系统上 pid_max 最大只能设到 32768?不是内核限制,是默认编译选项

很多老服务器跑的是 32bit x86 内核(比如 i686),pid_max 默认确实是 32768,但这不是硬件级天花板,而是内核编译时 CONFIG_BASE_SMALL=0 下的保守设定。64bit 内核默认上限是 2^22(4194304),而 32bit 内核只要重新编译、打开 CONFIG_PID_MAX_DEFAULT 并设足够大(比如 1048576),也能支持——但实际极少这么做,因为 32bit 用户空间进程本身受限于地址空间,大量 fork() 容易 OOM。

  • 查当前内核架构:uname -m(输出 i386i686 是 32bit;x86_64 是 64bit)
  • 32bit 内核最大安全值建议不超过 65536,再高会导致 struct pid 哈希表膨胀、调度延迟上升
  • 64bit 系统别盲目拉到 4194304——如果容器密度高(如 k8s node),PID 哈希冲突概率上升,fork() 平均耗时可能增加 5%~10%

容器环境(Docker / containerd)里改 pid_max 没用?得进 init namespace 改

在容器里执行 echo 1000000 > /proc/sys/kernel/pid_max 会报 Permission denied,因为容器默认运行在非 init PID namespace,而 /proc/sys/kernel/pid_max 是全局参数,只能由 host 的 init namespace(即 PID 1 所在 namespace)修改。即使你用 --privileged 启动容器,也改不了这个值——它不属于容器自己的 cgroup 控制域。

  • 真正有效的做法:在宿主机改(见第一个副标题),然后重启容器
  • 如果用 systemd + cgroup v2,可通过 TasksMax 单独限制某 service 的 PID 数量,和 pid_max 无关,别混淆
  • Pod 中看到 fork: Resource temporarily unavailable,先看 cat /proc/sys/kernel/pid_maxps -eL | wc -l,再确认是不是宿主机整体 PID 耗尽,而非容器内部限制

超过 pid_max 后的行为:不是立即失败,而是有重试窗口

当系统 PID 分配器用完所有可用编号(从 1 到 pid_max),内核不会马上返回 EAGAIN。它会先尝试回收已退出但尚未被 wait() 的僵尸进程 PID,再 scan 一遍空闲槽位——这个过程最多重试 10 次,每次 sleep 微秒级。所以你会看到 fork() 延迟突增,而不是立刻报错。这也是为什么压测时偶尔出现 “fork 失败” 但 ps 显示进程数远低于 pid_max

  • 监控真实压力:用 cat /proc/sys/kernel/pid_maxcat /proc/sys/kernel/pid_allocated 对比(后者 5.11+ 内核才支持)
  • 旧内核无 pid_allocated?用 ps -eo pid= | wc -l 估算,但注意包含线程(LWP),更准的是 ls /proc/[0-9]* 2>/dev/null | wc -l
  • pid_max 不是“并发进程数”,而是“同时存活的 PID 总数”,包括僵尸进程 —— 忘记 wait() 的父进程会让 PID 泄漏,比调大 pid_max 更值得优先排查

事情说清了就结束

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
c语言中null和NULL的区别
c语言中null和NULL的区别

c语言中null和NULL的区别是:null是C语言中的一个宏定义,通常用来表示一个空指针,可以用于初始化指针变量,或者在条件语句中判断指针是否为空;NULL是C语言中的一个预定义常量,通常用来表示一个空值,用于表示一个空的指针、空的指针数组或者空的结构体指针。

246

2023.09.22

java中null的用法
java中null的用法

在Java中,null表示一个引用类型的变量不指向任何对象。可以将null赋值给任何引用类型的变量,包括类、接口、数组、字符串等。想了解更多null的相关内容,可以阅读本专题下面的文章。

846

2024.03.01

resource是什么文件
resource是什么文件

Resource文件是一种特殊类型的文件,它通常用于存储应用程序或操作系统中的各种资源信息。它们在应用程序开发中起着关键作用,并在跨平台开发和国际化方面提供支持。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

170

2023.12.20

线程和进程的区别
线程和进程的区别

线程和进程的区别:线程是进程的一部分,用于实现并发和并行操作,而线程共享进程的资源,通信更方便快捷,切换开销较小。本专题为大家提供线程和进程区别相关的各种文章、以及下载和课程。

717

2023.08.10

k8s和docker区别
k8s和docker区别

k8s和docker区别有抽象层次不同、管理范围不同、功能不同、应用程序生命周期管理不同、缩放能力不同、高可用性等等区别。本专题为大家提供k8s和docker区别相关的各种文章、以及下载和课程。

265

2023.07.24

docker进入容器的方法有哪些
docker进入容器的方法有哪些

docker进入容器的方法:1. Docker exec;2. Docker attach;3. Docker run --interactive --tty;4. Docker ps -a;5. 使用 Docker Compose。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

513

2024.04.08

docker容器无法访问外部网络怎么办
docker容器无法访问外部网络怎么办

docker 容器无法访问外部网络的原因和解决方法:配置 nat 端口映射以将容器端口映射到主机端口。根据主机兼容性选择正确的网络驱动(如 host 或 overlay)。允许容器端口通过主机的防火墙。配置容器的正确 dns 服务器。选择正确的容器网络模式。排除主机网络问题,如防火墙或连接问题。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

412

2024.04.08

docker镜像有什么用
docker镜像有什么用

docker 镜像是预构建的软件组件,用途广泛,包括:应用程序部署:简化部署,提高移植性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

447

2024.04.08

pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

1127

2026.02.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 9.6万人学习

Git 教程
Git 教程

共21课时 | 3.8万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号