0

0

Linux /proc/sys/fs/file-max 与 /proc/sys/fs/nr_open 的文件描述符上限调优

舞姬之光

舞姬之光

发布时间:2026-02-26 16:35:02

|

386人浏览过

|

来源于php中文网

原创

file-max 是系统级文件描述符总数上限,不直接限制单进程;单进程上限由 nr_open 和 ulimit -n 共同决定,且 ulimit 受 nr_open 硬性约束。

linux /proc/sys/fs/file-max 与 /proc/sys/fs/nr_open 的文件描述符上限调优

file-max 是系统级硬上限,但不直接限制单进程

很多运维同学看到 cat /proc/sys/fs/file-max 返回 8388608 就以为“系统最多开 800 万文件”,结果单个进程 open() 到 1024 就报 Too many open files——这说明搞混了层级。file-max 是内核允许分配的**所有文件描述符总数**,类似内存总量;而单进程能用多少,由 nr_open 和用户级 ulimit -n 共同掐着。

实操建议:

  • file-max 应设为预期峰值总连接数 × 1.2~1.5(比如 Nginx + Redis + Java 应用合计可能开 50 万 fd,则设为 60 万~75 万)
  • 改完需执行 sysctl -p 生效,否则重启才生效
  • 注意:该值不能高于 nr_open,否则内核启动时会自动截断到 nr_open

nr_open 决定 ulimit -n 的理论天花板

nr_open 是内核编译期或运行时设定的**单进程可申请 fd 数的绝对上限**。它不像 file-max 那样可随意调高——超过它,连 ulimit -n 1048576 都会被拒绝,提示 Operation not permitted

常见错误现象:

  • 执行 ulimit -n 1048576 后查仍是 1024 或 65536
  • Java 进程 -XX:+UseG1GC 下大量 socket 超时,日志里反复出现 java.io.IOException: Too many open files

实操建议:

  • 先看当前值:cat /proc/sys/fs/nr_open(常见默认值是 1048576)
  • 若要支持单进程百万级 fd,需先调高 nr_open(如设为 2097152),再调 ulimit -n
  • 修改方式:写入 /proc/sys/fs/nr_open(临时)或在 /etc/sysctl.conffs.nr_open = 2097152(永久)
  • ⚠️ 注意:该值一旦写死,普通用户无法通过 ulimit 超过它;root 也不行——这是内核硬边界

ulimit -n 的实际生效受三重约束

你以为 ulimit -n 1048576 就万事大吉?不一定。它必须同时满足:nr_open ≥ 设置值 ≥ 当前 soft limit,且 shell 启动时未被父进程继承更低限制。

Runway
Runway

Runway是一个AI创意工具平台,它提供了一系列强大的功能,旨在帮助用户在视觉内容创作、设计和开发过程中提高效率和创新能力。

下载

使用场景:

  • systemd 服务中 fd 不足,LimitNOFILE 设再高也无效——因为 systemd 自己的 ulimitnr_open 限制
  • 容器内 ulimit -n 失效,本质是容器 runtime(如 runc)启动时从宿主机继承了受限的 limits

实操建议:

  • 检查当前生效值:ulimit -n(soft)、ulimit -Hn(hard)
  • 临时提限:先 ulimit -Hn 1048576,再 ulimit -Sn 1048576
  • 长期生效:在 /etc/security/limits.conf* soft nofile 1048576* hard nofile 1048576,并确认 PAM 模块已启用 pam_limits.so
  • systemd 用户服务需额外设置 DefaultLimitNOFILE=1048576 并重启 systemd --user

调完不验证等于没调

改完 file-maxnr_openulimit,很多人就去盯业务日志,结果几天后又爆 Too many open files——大概率是某个环节漏了验证,或者进程根本没加载新限制。

关键验证点:

  • 确认进程实际 limit:cat /proc/<pid>/limits | grep "Max open files"</pid>,看 Soft LimitHard Limit 是否符合预期
  • 确认 file-max 已生效:sysctl fs.file-max,别只信 cat /proc/sys/fs/file-max(可能缓存)
  • 检查是否被 cgroup 限制:容器或 systemd service 下,cat /proc/<pid>/cgroup</pid> 若含 memorypids controller,还需查对应 cgroup 的 tasksfd 目录
  • 注意:某些 Go 程序(尤其旧版)会绕过 ulimit 自行调 setrlimit(RLIMIT_NOFILE),此时得看代码里是否硬编码了 65536

最常被忽略的是:改完 nr_open 后没重启相关服务,老进程仍卡在旧限制里。不是所有服务都支持热 reload fd 限制。

相关文章

相关标签:

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
nginx 重启
nginx 重启

nginx重启对于网站的运维来说是非常重要的,根据不同的需求,可以选择简单重启、平滑重启或定时重启等方式。本专题为大家提供nginx重启的相关的文章、下载、课程内容,供大家免费下载体验。

240

2023.07.27

nginx 配置详解
nginx 配置详解

Nginx的配置是指设置和调整Nginx服务器的行为和功能的过程。通过配置文件,可以定义虚拟主机、HTTP请求处理、反向代理、缓存和负载均衡等功能。Nginx的配置语法简洁而强大,允许管理员根据自己的需要进行灵活的调整。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

519

2023.08.04

nginx配置详解
nginx配置详解

NGINX与其他服务类似,因为它具有以特定格式编写的基于文本的配置文件。本专题为大家提供nginx配置相关的文章,大家可以免费学习。

587

2023.08.04

tomcat和nginx有哪些区别
tomcat和nginx有哪些区别

tomcat和nginx的区别:1、应用领域;2、性能;3、功能;4、配置;5、安全性;6、扩展性;7、部署复杂性;8、社区支持;9、成本;10、日志管理。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

243

2024.02.23

nginx报404怎么解决
nginx报404怎么解决

当访问 nginx 网页服务器时遇到 404 错误,表明服务器无法找到请求资源,可以通过以下步骤解决:1. 检查文件是否存在且路径正确;2. 检查文件权限并更改为 644 或 755;3. 检查 nginx 配置,确保根目录设置正确、没有冲突配置等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

585

2024.07.09

Nginx报404错误解决方法
Nginx报404错误解决方法

解决方法:只需要加上这段配置:try_files $uri $uri/ /index.html;即可。想了解更多Nginx的相关内容,可以阅读本专题下面的文章。

3606

2024.08.07

nginx部署php项目教程汇总
nginx部署php项目教程汇总

本专题整合了nginx部署php项目教程汇总,阅读专题下面的文章了解更多详细内容。

53

2026.01.13

nginx配置文件详细教程
nginx配置文件详细教程

本专题整合了nginx配置文件相关教程详细汇总,阅读专题下面的文章了解更多详细内容。

67

2026.01.13

Golang 实际项目案例:从需求到上线
Golang 实际项目案例:从需求到上线

《Golang 实际项目案例:从需求到上线》以真实业务场景为主线,完整覆盖需求分析、架构设计、模块拆分、编码实现、性能优化与部署上线全过程,强调工程规范与实践决策,帮助开发者打通从技术实现到系统交付的关键路径,提升独立完成 Go 项目的综合能力。

1

2026.02.26

热门下载

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

精品课程

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

共48课时 | 9.8万人学习

Git 教程
Git 教程

共21课时 | 3.9万人学习

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

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