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

15次阅读

根本原因是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-sessiondebian/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 已改,其启动的服务也不会继承。

  • 对用户级服务(--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),再看目标进程是否真从预期上下文启动 —— 很多问题其实出在“你以为它读了配置,其实根本没走那条链路”。

text=ZqhQzanResources