准确--CentOS 7 配置用户资源限制(nofile / nproc)


CentOS 7 配置用户资源限制(nofile / nproc)

目标:

  • 提升文件句柄数(nofile)
  • 提升进程数(nproc)
  • 避免启用 UsePAM 后"密码正确却登录失败"的坑

一、临时生效(立即生效,无需重启服务)

使用 prlimit 强制修改当前 Shell

适合:

  • 立即排障
  • 临时调优
  • 不想重启服务
bash 复制代码
prlimit --pid $$ --nofile=65535:65535 --nproc=65535:65535

参数说明

  • --pid $$:当前 Shell 进程
  • nofile:最大文件句柄数
  • nproc:最大进程数

验证

bash 复制代码
ulimit -n

输出应为:

text 复制代码
65535

⚠️ 注意

该方式 仅对当前 Shell 有效,重新登录即失效。


二、永久生效(推荐生产环境使用)

1️⃣ 修改 limits.conf

bash 复制代码
vim /etc/security/limits.conf

追加:

ini 复制代码
* soft nproc 65535
* hard nproc 65535
* soft nofile 65535
* hard nofile 65535

2️⃣ 启用 PAM(关键步骤)

编辑 SSH 配置:

bash 复制代码
vim /etc/ssh/sshd_config

确保存在并且未注释

ini 复制代码
UsePAM yes
PasswordAuthentication yes

修改后重启 SSH:

bash 复制代码
systemctl restart sshd

三、【非常关键】否则会出现"密码正确但登录失败"

很多人卡在这里

👉 只开了 UsePAM yes,但 PAM 认证链不完整

必须正确配置 /etc/pam.d/sshd

直接覆盖(最稳妥方式):

bash 复制代码
cat > /etc/pam.d/sshd <<'EOF'
#%PAM-1.0
auth       required     pam_sepermit.so
auth       include      password-auth

account    required     pam_nologin.so
account    include      password-auth

password   include      password-auth

# pam_selinux.so close should be the first session rule
session    required     pam_selinux.so close
session    required     pam_loginuid.so
# pam_selinux.so open should only be followed by sessions to be executed in the user context
session    required     pam_selinux.so open env_params
session    required     pam_namespace.so
session    optional     pam_keyinit.so force revoke
session    include      password-auth
session    include      postlogin

# ★ 关键:资源限制生效必须有它
session    required     pam_limits.so
EOF

⭐ 核心点说明

  • pam_limits.so
    👉 没有这一行,limits.conf 完全不生效
  • password-auth
    👉 决定"密码是否正确"的真正模块
  • 缺失或顺序错误
    👉 100% 导致密码登录失败

四、验证是否真正生效(一定要重新登录)

⚠️ 重要

已登录的 SSH 会话 不会继承新 limits

新开一个 SSH 会话后执行:

bash 复制代码
ulimit -n
ulimit -u

期望输出:

text 复制代码
65535

五、常见故障自检(备用)

1️⃣ 检查 sshd 实际配置

bash 复制代码
sshd -T | egrep 'usepam|passwordauthentication'

2️⃣ 查看认证失败原因

bash 复制代码
tail -n 50 /var/log/secure

3️⃣ 用户是否被 PAM 锁定

bash 复制代码
pam_tally2 --user 用户名

解锁:

bash 复制代码
pam_tally2 --user 用户名 --reset

六、一句话总结(给以后自己看的)

  • 临时调试prlimit
  • 永久生效limits.conf + pam_limits.so
  • UsePAM yes 必须配合完整 PAM 文件
  • 否则就是"密码正确但登录失败"

相关推荐
可可嘻嘻大老虎18 小时前
nginx无法访问后端服务问题
运维·nginx
JiMoKuangXiangQu19 小时前
ARM64 进程虚拟地址空间布局
linux·arm64 虚拟地址布局
阳光九叶草LXGZXJ19 小时前
达梦数据库-学习-47-DmDrs控制台命令(LSN、启停、装载)
linux·运维·数据库·sql·学习
无忧智库19 小时前
某市“十五五“地下综合管廊智能化运维管理平台建设全案解析:从数字孪生到信创适配的深度实践(WORD)
运维·智慧城市
春日见19 小时前
如何避免代码冲突,拉取分支
linux·人工智能·算法·机器学习·自动驾驶
珠海西格20 小时前
“主动预防” vs “事后补救”:分布式光伏防逆流技术的代际革命,西格电力给出标准答案
大数据·运维·服务器·分布式·云计算·能源
无垠的广袤20 小时前
【VisionFive 2 Lite 单板计算机】边缘AI视觉应用部署:缺陷检测
linux·人工智能·python·opencv·开发板
阿波罗尼亚20 小时前
Kubectl 命令记录
linux·运维·服务器
Fᴏʀ ʏ꯭ᴏ꯭ᴜ꯭.20 小时前
Keepalived单播模式配置与实战指南
linux·服务器·负载均衡
IDC02_FEIYA20 小时前
Linux文件搜索命令有哪些?Linux常用命令之文件搜索命令find详解
linux·运维·服务器