0

0

ulimit -n 1024 但实际打开文件远超的 pam_limits 配置坑

冷炫風刃

冷炫風刃

发布时间:2026-01-28 16:22:02

|

920人浏览过

|

来源于php中文网

原创

ulimit -n 只影响当前 shell 及其子进程,systemd 等服务不经过 shell 初始化,故忽略该设置;真正生效需依赖 pam_limits 或 systemd 的 LimitNOFILE 配置。

ulimit -n 1024 但实际打开文件远超的 pam_limits 配置坑

执行 ulimit -n 1024 后,lsof -p $PID | wc -l 却显示进程打开了 3000+ 文件描述符——这不是 ulimit 失效,而是 pam_limits 没生效或被绕过了。

为什么 ulimit -n 设置后进程仍能打开远超限制的文件?

根本原因:当前 shell 的 ulimit -n 只影响该 shell 及其**后续 fork 出的子进程**;但很多服务(如 systemd 服务、supervisord 管理的进程、SSH 登录后直接 exec 的守护进程)**不经过 shell 初始化流程**,因此完全忽略你手动设置的 ulimit,而是依赖系统级限制策略(即 pam_limits)。

更隐蔽的情况是:即使你配置了 /etc/security/limits.conf,若 PAM 配置未启用 pam_limits.so,或启用顺序错误、匹配用户类型不对(比如用了 @group 却没加 includedir),该配置就形同虚设。

检查 pam_limits 是否真正生效的三步验证法

  • 确认 PAM 配置加载了 limits 模块:grep -r "pam_limits" /etc/pam.d/,重点看 loginsshdsystem-auth(RHEL/CentOS)或 common-session(Debian/Ubuntu)中是否包含 session required pam_limits.so —— 缺少这行,limits.conf 就不会被读取
  • 确认用户登录类型匹配:SSH 登录走的是 sshd PAM 配置,GUI 登录可能走 gdmlightdm,而 systemd 服务默认**完全不走 pam_limits**(除非显式配置 PAMName=
  • 验证实际生效值:cat /proc/$PID/limits | grep "Max open files",不要信 ulimit -n 输出,它只反映当前 shell 的设置;必须查目标进程的 /proc 视图才真实

systemd 服务绕过 pam_limits 的典型表现与修复

这是最常踩的坑:你改好了 /etc/security/limits.conf,也确认 sshd 加载了 pam_limits.so,但用 systemctl start myapp 启动的服务依然无视限制。因为 systemd 默认使用自己的资源控制逻辑,不调用 PAM。

解决方式不是改 limits.conf,而是直接在 service unit 中声明:

PageGen
PageGen

AI页面生成器,支持通过文本、图像、文件和URL一键生成网页。

下载
[Service]
LimitNOFILE=1024
# 或更细粒度:
LimitNOFILESoft=1024
LimitNOFILEHard=1024

注意:LimitNOFILE 是 systemd 原生参数,优先级高于 pam_limits;且需确保 DefaultLimitNOFILE/etc/systemd/system.conf 中未被设为更高值覆盖。

limits.conf 中容易被忽略的语法陷阱

/etc/security/limits.conf 看似简单,但几处细节会导致整行配置静默失效:

  • 用户名/组名前后不能有空格:myuser soft nofile 1024 ✅,myuser soft nofile 1024 ❌(部分老版 pam_limits 对多余空格敏感)
  • 通配符 * 不匹配 root:* soft nofile 1024 对普通用户有效,但 root 需单独写 root soft nofile 1024
  • soft/hard 限制必须成对出现才可靠:只设 soft,某些场景下 hard 会回退到内核默认值(通常是 4096 或 65536),导致 soft 实际可被提升
  • 修改后必须**重新登录**或重启对应 session:已存在的登录会话、screen/tmux 会话、systemd user session 都不会自动重载 limits

真正决定进程能打开多少文件的,从来不是你在终端敲的那条 ulimit -n,而是该进程启动时所处的完整上下文——PAM 配置是否加载、systemd 是否接管、用户 session 是否重建,缺一不可。最容易漏掉的,就是以为改了 limits.conf 就万事大吉,却忘了验证目标进程的 /proc/$PID/limits

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
session失效的原因
session失效的原因

session失效的原因有会话超时、会话数量限制、会话完整性检查、服务器重启、浏览器或设备问题等等。详细介绍:1、会话超时:服务器为Session设置了一个默认的超时时间,当用户在一段时间内没有与服务器交互时,Session将自动失效;2、会话数量限制:服务器为每个用户的Session数量设置了一个限制,当用户创建的Session数量超过这个限制时,最新的会覆盖最早的等等。

315

2023.10.17

session失效解决方法
session失效解决方法

session失效通常是由于 session 的生存时间过期或者服务器关闭导致的。其解决办法:1、延长session的生存时间;2、使用持久化存储;3、使用cookie;4、异步更新session;5、使用会话管理中间件。

748

2023.10.18

cookie与session的区别
cookie与session的区别

本专题整合了cookie与session的区别和使用方法等相关内容,阅读专题下面的文章了解更详细的内容。

92

2025.08.19

磁盘配额是什么
磁盘配额是什么

磁盘配额是计算机中指定磁盘的储存限制,就是管理员可以为用户所能使用的磁盘空间进行配额限制,每一用户只能使用最大配额范围内的磁盘空间。php中文网为大家提供各种磁盘配额相关的内容,教程,供大家免费下载安装。

1394

2023.06.21

如何安装LINUX
如何安装LINUX

本站专题提供如何安装LINUX的相关教程文章,还有相关的下载、课程,大家可以免费体验。

706

2023.06.29

linux find
linux find

find是linux命令,它将档案系统内符合 expression 的档案列出来。可以指要档案的名称、类别、时间、大小、权限等不同资讯的组合,只有完全相符的才会被列出来。find根据下列规则判断 path 和 expression,在命令列上第一个 - ( ) , ! 之前的部分为 path,之后的是 expression。还有指DOS 命令 find,Excel 函数 find等。本站专题提供linux find相关教程文章,还有相关

295

2023.06.30

linux修改文件名
linux修改文件名

本专题为大家提供linux修改文件名相关的文章,这些文章可以帮助用户快速轻松地完成文件名的修改工作,大家可以免费体验。

779

2023.07.05

linux系统安装教程
linux系统安装教程

linux系统是一种可以免费使用,自由传播,多用户、多任务、多线程、多CPU的操作系统。本专题提供linux系统安装教程相关的文章,大家可以免费体验。

575

2023.07.06

俄罗斯Yandex引擎入口
俄罗斯Yandex引擎入口

2026年俄罗斯Yandex搜索引擎最新入口汇总,涵盖免登录、多语言支持、无广告视频播放及本地化服务等核心功能。阅读专题下面的文章了解更多详细内容。

84

2026.01.28

热门下载

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

精品课程

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

共578课时 | 52.4万人学习

国外Web开发全栈课程全集
国外Web开发全栈课程全集

共12课时 | 1.0万人学习

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

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