news 2026/4/19 16:19:12

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

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
准确--CentOS 7 配置用户资源限制(nofile / nproc)

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

目标:

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

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

使用prlimit强制修改当前 Shell

适合:

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

参数说明

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

验证

ulimit-n

输出应为:

65535

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


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

1️⃣ 修改 limits.conf

vim/etc/security/limits.conf

追加:

* soft nproc 65535 * hard nproc 65535 * soft nofile 65535 * hard nofile 65535

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

编辑 SSH 配置:

vim/etc/ssh/sshd_config

确保存在并且未注释

UsePAM yes PasswordAuthentication yes

修改后重启 SSH:

systemctl restart sshd

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

很多人卡在这里
👉 只开了UsePAM yes,但PAM 认证链不完整

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

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

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 会话后执行:

ulimit-nulimit-u

期望输出:

65535

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

1️⃣ 检查 sshd 实际配置

sshd -T|egrep'usepam|passwordauthentication'

2️⃣ 查看认证失败原因

tail-n50/var/log/secure

3️⃣ 用户是否被 PAM 锁定

pam_tally2 --user 用户名

解锁:

pam_tally2 --user 用户名 --reset

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

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

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/18 15:06:31

科技不应逾越人性底线:我们的立场声明

科技不应逾越人性底线&#xff1a;我们的立场声明 在某次深夜调试语音助手时&#xff0c;我听到一段由AI生成的“愤怒”语音——语速急促、音调尖锐&#xff0c;几乎与真人无异。那一刻&#xff0c;我没有感到技术突破的欣喜&#xff0c;反而心头一紧&#xff1a;如果这声音被用…

作者头像 李华
网站建设 2026/4/18 21:43:27

Lime开源编辑器深度体验:从Sublime Text用户到贡献者的完整解析

Lime开源编辑器深度体验&#xff1a;从Sublime Text用户到贡献者的完整解析 【免费下载链接】lime Open source API-compatible alternative to the text editor Sublime Text 项目地址: https://gitcode.com/gh_mirrors/li/lime 作为一名长期使用Sublime Text的开发者&…

作者头像 李华
网站建设 2026/4/18 15:54:26

ThingsBoard物联网平台Vue3前端开发实战指南

ThingsBoard物联网平台Vue3前端开发实战指南 【免费下载链接】thingsboard-ui-vue3 本项目为基于Vue3开发的 ThingsBoard 前台 ,AntDesginVue、VbenVueAdmin、AntV X6、规则链代码已全部开放、ThingsBoard3.x持续更新中 项目地址: https://gitcode.com/oliver225/thingsboard…

作者头像 李华
网站建设 2026/4/18 10:16:46

智能机器人云平台集成:从零到一的实战部署指南

智能机器人云平台集成&#xff1a;从零到一的实战部署指南 【免费下载链接】ZeroBot-Plugin 基于 ZeroBot 的 OneBot 插件 项目地址: https://gitcode.com/GitHub_Trending/ze/ZeroBot-Plugin 还在为多平台云服务管理而头疼吗&#xff1f;每天要在AWS、Azure、GCP之间反…

作者头像 李华
网站建设 2026/4/18 2:55:38

JupyterHub配置避坑指南:3步解决90%的部署难题

JupyterHub配置避坑指南&#xff1a;3步解决90%的部署难题 【免费下载链接】jupyterhub Multi-user server for Jupyter notebooks 项目地址: https://gitcode.com/gh_mirrors/ju/jupyterhub 为什么明明按照官方文档配置JupyterHub&#xff0c;却总是遭遇认证失败、端口…

作者头像 李华
网站建设 2026/4/18 19:37:35

BadDiffusion复现教程

BadDiffusion复现教程最近复现了经典的扩散模型攻击方法BadDiffusion&#xff0c;开个帖期末考之后来填坑。

作者头像 李华