0

0

ulimit -n 软硬限制不一致的 /etc/security/limits.conf vs pam_limits

冷漠man

冷漠man

发布时间:2026-01-28 19:01:02

|

425人浏览过

|

来源于php中文网

原创

根本原因是pam_limits.so未被正确加载或顺序错误,导致limits.conf配置不生效;需检查PAM配置文件是否包含session required pam_limits.so,并确保SSH、su等登录方式均触发该模块。

ulimit -n 软硬限制不一致的 /etc/security/limits.conf vs pam_limits

为什么 ulimit -n 显示的软限制没生效?

根本原因通常是 pam_limits.so 没被正确加载,或加载顺序不对 —— 即使 /etc/security/limits.conf 写对了,PAM 层不读它,配置就完全无效。

常见现象:ulimit -n 输出是 1024(默认值),但 limits.conf 里已写 * soft nofile 65536;用 su -l 切换用户后仍不变;systemd --user 服务也继承不到。

  • limits.conf 只是数据文件,不自动生效 —— 它必须由 PAM 模块在登录会话初始化时解析并设置
  • 关键检查点:/etc/pam.d/common-session(Debian/Ubuntu)或 /etc/pam.d/login(RHEL/CentOS)是否包含这行:session required pam_limits.so
  • 如果用了 session [default=1] pam_succeed_if.so user ingroup nopamlimit 这类跳过逻辑,可能绕过 pam_limits
  • SSH 登录需确认 /etc/pam.d/sshd 同样加载了 pam_limits.so,否则 ssh 会话不读 limits.conf

limits.conf 的通配符和优先级怎么算?

匹配不是“第一个命中就停”,而是按规则逐条扫描、叠加应用,且用户组规则优先于用户名规则,硬限制可被更早的同类型硬限制覆盖。

  • * soft nofile 1024myuser hard nofile 65536 同时存在 → myuser 的软限制仍是 1024(未显式设软限),硬限制为 65536
  • @staff soft nofile 4096 + alice - nofile 8192alice 属于 staff 组,则最终软限取较大者(8192),硬限同理
  • - 表示同时设置软硬限制,比分开写 soft/hard 更安全,避免软限 > 硬限导致设置失败
  • 注释行必须以 # 开头且独占一行;空行会被忽略;路径中不能有空格(如 /path/to/file 不行,得写成 /path/to/file

systemd 服务绕过 limits.conf 怎么办?

systemd 忽略 PAM limits,默认使用内核默认值(通常 1024),即使用户登录 shell 的 ulimit -n 已改,其启动的服务也不会继承。

Voicenotes
Voicenotes

Voicenotes是一款简单直观的多功能AI语音笔记工具

下载
  • 对用户级服务(--user),在 ~/.config/systemd/user.conf/etc/systemd/user.conf 中设:DefaultLimitNOFILE=65536
  • 对系统级服务,在 unit 文件里加:[Service] 段下写 LimitNOFILE=65536(支持软硬分离:LimitNOFILE=4096:65536
  • 修改后必须运行:systemctl daemon-reload(用户服务还需 systemctl --user daemon-reload
  • 验证方式不是 ulimit -n,而是查进程:cat /proc//limits | grep "Max open files"

为什么 ulimit -n 软限制能调高但硬限制卡死?

硬限制只能由 root 提升,普通用户最多把软限制调到当前硬限制值;若 limits.conf 中硬限制没写或写得太低,后续任何 ulimit -Hn 都无法突破。

  • 检查当前硬限:ulimit -Hn;若输出是 4096,但你想设 65536,就必须先让 root 在 limits.conf 中提升硬限
  • root 用户自身也受 limits.conf 约束 —— 所以 sudo ulimit -Hn 65536 无效,必须改配置再重新登录
  • 某些容器环境(如 Docker)默认禁用 RLIMIT_NOFILE 提权,即使宿主机设了 high limit,容器内仍受限,需启动时加 --ulimit nofile=65536:65536
  • 内核参数 fs.nr_open 是全局上限,若它小于你设的硬限,pam_limits 会静默截断 —— 查看:cat /proc/sys/fs/nr_open,必要时用 sysctl -w fs.nr_open=2000000 提升

改完配置别急着测,先确认登录方式是否触发 PAM(比如直接 su 可能不读 common-session),再看目标进程是否真从预期上下文启动 —— 很多问题其实出在“你以为它读了配置,其实根本没走那条链路”。

热门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、使用会话管理中间件。

749

2023.10.18

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

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

92

2025.08.19

default gateway怎么配置
default gateway怎么配置

配置default gateway的步骤:1、了解网络环境;2、获取路由器IP地址;3、登录路由器管理界面;4、找到并配置WAN口设置;5、配置默认网关;6、保存设置并退出;7、检查网络连接是否正常。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

223

2023.12.07

k8s和docker区别
k8s和docker区别

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

257

2023.07.24

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

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

499

2024.04.08

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

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

401

2024.04.08

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

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

438

2024.04.08

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

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

158

2026.01.28

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
光速学会docker容器
光速学会docker容器

共33课时 | 1.9万人学习

Docker 17 中文开发手册
Docker 17 中文开发手册

共0课时 | 0人学习

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

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