Linux下禁用su切换用户设置方法
时间:2026-06-01 13:08:52 187浏览 收藏
本文深入解析了在Linux系统中安全限制su命令切换用户的核心方法,强调修改/etc/pam.d/su文件是唯一可靠且防绕过的技术路径:既可通过注释全部auth行彻底禁用su(包括root自身),也可启用pam_wheel.so实现wheel组白名单控制,或借助pam_listfile.so精确指定允许/禁止的个别用户;同时提醒读者,禁用su绝非孤立操作——必须提前验证sudo、runuser等替代提权方式的有效性,避免因配置失误导致系统管理锁死,兼顾安全性与运维可用性。
最简可靠方式是修改 /etc/pam.d/su,注释所有 auth 行或启用 pam_wheel.so 限制 wheel 组,配合 SU_WHEEL_ONLY 或 pam_listfile.so 实现白名单控制,禁用 su 后须确保 sudo 等替代路径可用。

直接禁用 su 命令的最简方式
想彻底不让任何人用 su 切换用户?改 /etc/pam.d/su 是唯一可靠路径。其他方法(如删命令、改权限)容易被绕过,且可能破坏系统工具链。
操作就是注释掉该文件里所有以 auth 开头的有效行,例如:
auth [default=ignore] pam_deny.so
或者更常见的是直接注释原 auth 行:
# auth [success=ok default=bad] pam_wheel.so use_uid
这样即使输入正确的 root 密码,su 也会立即失败并记录到 /var/log/auth.log。注意:此操作后,root 也无法用 su - 切自己,必须依赖 sudo 或直接登录。
只允许 wheel 组用户使用 su
这是生产环境最常用的折中方案——既不限死权限,又守住最小授权原则。
- 把可信用户加进
wheel组:usermod -aG wheel username - 编辑
/etc/pam.d/su,取消注释这行:auth required pam_wheel.so use_uid - 可选加固:在
/etc/login.defs中追加SU_WHEEL_ONLY yes,让策略更明确
没加组的用户执行 su - 时,无论密码对错,都会提示 Permission denied,且不会暴露账户是否存在——这点比单纯靠密码验证更安全。
用 pam_listfile.so 精确控制白名单/黑名单
当 wheel 组太粗、而你只想放行 2–3 个特定账号时,pam_listfile.so 更精准。
例如只允许 admin1 和 backup 使用 su:
- 创建白名单文件:
echo -e "admin1\nbackup" > /etc/security/su.allow - 在
/etc/pam.d/su顶部添加一行:auth required pam_listfile.so onerr=fail item=user sense=allow file=/etc/security/su.allow
注意:sense=allow 表示“只允许列表里的”,sense=deny 才是拒绝;onerr=fail 确保文件出错时默认拒绝,避免配置失误导致开门。
禁用 su 后仍能提权的替代路径
禁了 su 不等于锁死所有提权能力,运维仍需留出合法通道,否则会把自己关在外面。
sudo -i或sudo su -(前提是已配好/etc/sudoers)runuser -l root -c 'command':不走 PAM,但要求调用者有对应 sudo 权限- SSH 直连:
ssh root@localhost(若未禁用 root SSH 登录)
真正危险的是同时禁掉 su 又没配好 sudo,结果连 root 都进不去。务必在修改前确认至少一种替代方式已测试通过——比如用另一个终端先 sudo -l 验证权限,再动 /etc/pam.d/su。
文中关于的知识介绍,希望对你的学习有所帮助!若是受益匪浅,那就动动鼠标收藏这篇《Linux下禁用su切换用户设置方法》文章吧,也可关注golang学习网公众号了解相关技术文章。
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
360 收藏
-
108 收藏
-
227 收藏
-
436 收藏
-
288 收藏
-
250 收藏
-
280 收藏
-
122 收藏
-
497 收藏
-
392 收藏
-
484 收藏
-
129 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 485次学习