Linux用户锁定方法及操作教程
时间:2026-03-03 16:54:54 467浏览 收藏
Linux中锁定用户登录并非简单执行一条命令就能彻底生效,usermod -L仅通过禁用密码字段实现有限防护,对SSH公钥免密等非密码认证方式完全无效;真正稳妥的做法是将用户shell改为/sbin/nologin,配合清理authorized_keys、移出特权组及终止残留进程,才能构建闭环安全机制——否则看似“已锁定”的账户仍可能成为系统入侵的跳板。

usermod -L 真的能禁止登录吗?
能,但只锁密码字段,不是万能禁用方案。它本质是往 /etc/shadow 中该用户的密码字段前加两个感叹号(!!),让系统在验证时直接拒绝——但前提是用户必须走密码认证流程。如果用户配置了 SSH 公钥免密登录,usermod -L 完全无效,照样能进来。
- 适用场景:仅依赖密码登录的普通账户,比如本地 console 或传统 SSH 密码登录
- 不适用场景:已配置
AuthorizedKeysFile的 SSH 用户、使用 PAM 认证模块绕过密码校验的服务、或启用了 root 登录且用户有 sudo 权限可提权的情况 - 验证是否生效:运行
passwd -S username,输出中看到LK(Locked)才表示成功;若显示PS(Password set),说明没锁住
更彻底的禁用方式:改 shell 为 /sbin/nologin
这是生产环境最常用、也最稳妥的做法。它不碰密码,而是让系统在用户认证通过后,直接拒绝启动 shell 进程,连交互式会话都不给开——哪怕公钥登录成功,也会立刻退出并显示 /etc/nologin.txt 里的提示信息。
- 执行命令:
sudo usermod -s /sbin/nologin username - 增强提示(可选):
echo "Account disabled for security review" | sudo tee /etc/nologin.txt - 注意:
/sbin/nologin和/bin/false效果类似,但前者支持自定义提示,后者静默退出,运维排查时不易定位原因 - 恢复登录只需还原 shell:
sudo usermod -s /bin/bash username
为什么别直接编辑 /etc/passwd?
手动用 sed 或 vi 改 /etc/passwd 看似快,实则风险高。usermod 是原子操作,会同步更新影子文件、PAM 缓存、甚至 SELinux 上下文(如启用);而手改容易漏掉关联项,比如忘记改 /etc/shadow 对应行,或破坏文件权限/格式导致整个用户系统异常。
- 典型翻车点:改完
/etc/passwd后,用户仍能登录(因为密码还在 shadow 里有效),或突然所有用户都登不上(文件格式损坏触发 PAM 拒绝) - usermod 自动处理
-d(家目录)、-s(shell)、-g(主组)等字段的联动,手改需逐个核对三四个配置文件 - 审计要求:usermod 操作会被记录在
journald或/var/log/secure,手改无迹可寻
锁定后还要注意什么?
禁用只是第一步,真正安全要看后续动作是否闭环。很多管理员锁完就以为万事大吉,结果用户残留的进程、定时任务、网络服务还在跑,甚至可能被用来反弹 shell。
- 检查活跃会话:
loginctl list-users或ps -u username,强制终止残留进程 - 停用定时任务:
sudo -u username crontab -e不可行,改用sudo systemctl --user stop cron(若启用 user session)或直接删/var/spool/cron/username - 清理 SSH 授权密钥:
sudo rm -f /home/username/.ssh/authorized_keys,否则公钥登录依然通 - 特别提醒:如果用户属于
docker、adm、systemd-journal等特权组,光锁账户不够,得从组里移出——用sudo gpasswd -d username groupname
终于介绍完啦!小伙伴们,这篇关于《Linux用户锁定方法及操作教程》的介绍应该让你收获多多了吧!欢迎大家收藏或分享给更多需要学习的朋友吧~golang学习网公众号也会发布文章相关知识,快来关注吧!
相关阅读
更多>
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
最新阅读
更多>
-
350 收藏
-
472 收藏
-
147 收藏
-
203 收藏
-
380 收藏
-
459 收藏
-
293 收藏
-
102 收藏
-
376 收藏
-
157 收藏
-
346 收藏
-
460 收藏
课程推荐
更多>
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 485次学习