0

0

Linux如何锁定和解锁用户账户

P粉602998670

P粉602998670

发布时间:2025-09-07 11:45:01

|

229人浏览过

|

来源于php中文网

原创

锁定Linux用户账户的常见方法包括:1. 使用passwd -l或usermod -L禁用密码登录,仅阻止密码认证,不影响SSH密钥登录;2. 使用usermod -s /sbin/nologin或/bin/false修改登录Shell,彻底禁止所有交互式登录;3. 使用chage -E 0设置账户立即过期,通过账户过期机制阻止登录。三者中,passwd -l和usermod -L作用相似,仅针对密码认证;而修改Shell方式更彻底,可阻止所有Shell访问;chage则基于时间策略,适用于临时或生命周期管理场景。实际中可根据需求单独或组合使用,以实现灵活的账户控制。

linux如何锁定和解锁用户账户

Linux中锁定和解锁用户账户,本质上就是控制其登录权限。锁定通常意味着阻止用户通过密码或特定方式登录系统,而解锁则是恢复这些权限。这在系统安全管理中是相当基础且关键的操作,无论是临时禁用还是永久停用某个账户,都有其特定的场景和手法。

解决方案

在Linux系统中,锁定和解锁用户账户主要通过修改其密码状态或登录Shell来实现。最直接且常用的方法是利用

passwd
usermod
命令。

要锁定一个用户账户,最常见的做法是使用

passwd -l
命令。这个命令的原理是在
/etc/shadow
文件中,用户密码的哈希值前面加上一个感叹号(
!
)。这样,系统在验证密码时就无法匹配,从而阻止用户通过密码登录。

sudo passwd -l 

例如,要锁定名为

testuser
的用户:

sudo passwd -l testuser

执行后,你可能会看到类似“Locking password for user testuser.”的提示。

另一种锁定方法是使用

usermod -L
命令。它和
passwd -l
的效果类似,也是在
/etc/shadow
中用户密码哈希前加
!

sudo usermod -L 

例如:

sudo usermod -L testuser

解锁账户则使用相应的

-u
-u
参数:

sudo passwd -u 

或者

sudo usermod -U 

这些命令会移除密码哈希前的感叹号,使密码验证恢复正常。

锁定Linux用户账户的常见方法有哪些,它们有何不同?

在Linux系统里,锁定用户账户可不是只有一种“标准”做法,它更像是一个工具箱,里面有几把不同的扳手,每把都有其特定的用途和影响。我个人在实际操作中,会根据需要禁用的登录方式和安全级别来选择。

1. 禁用密码登录(

passwd -l
usermod -L
这是最常见也是最直接的方法。如前所述,它通过在
/etc/shadow
文件中用户密码哈希前加一个
!
来实现。

  • 影响: 用户将无法通过密码进行身份验证。这意味着他们不能通过SSH(如果启用了密码认证)、本地控制台或任何需要密码的服务登录。
  • 何时使用: 当你希望暂时禁用某个用户的密码登录能力,但又不想完全阻止其通过其他方式(如SSH密钥)登录时,这会是一个不错的选择。比如,一个员工暂时离职,但其SSH密钥可能还在使用,而你只想禁用其密码登录。

2. 更改Shell为

/sbin/nologin
/bin/false
这是通过修改用户在
/etc/passwd
文件中的默认Shell来实现的。当用户的Shell被设置为
/sbin/nologin
/bin/false
时,系统会阻止他们登录,并在尝试登录时显示一条消息(
/sbin/nologin
通常会显示更友好的消息)。

  • 命令:
    sudo usermod -s /sbin/nologin 

    或者

    sudo usermod -s /bin/false 
  • 影响: 用户将无法通过任何交互式Shell登录,无论是密码认证还是SSH密钥认证。对于SSH密钥登录,他们可能会成功认证,但会立即断开连接,因为没有可用的Shell。
  • 何时使用: 当你需要彻底阻止用户登录系统,无论他们使用何种认证方式时,这非常有效。例如,系统中的服务账户,它们通常不需要交互式登录,或者某个用户账户被永久停用。

3. 设置账户过期日期(

chage -E 0
这个方法是利用
chage
命令来设置账户的过期日期。将其设置为“0”或一个过去的日期,账户就会立即过期。

  • 命令:
    sudo chage -E 0 
  • 影响: 账户被标记为过期,用户将无法登录。
  • 何时使用: 适用于那些有明确生命周期的账户,或者需要临时禁用但又不想修改密码状态的场景。

总结差异:

  • passwd -l
    /
    usermod -L
    :主要针对密码认证。用户可能仍能通过SSH密钥等非密码方式登录。
  • usermod -s /sbin/nologin
    :彻底禁用所有交互式登录,无论认证方式。
  • chage -E 0
    :通过账户过期机制禁用登录。

在我看来,最彻底的锁定通常是结合使用

usermod -L
usermod -s /sbin/nologin
。这样既禁用了密码,又阻止了任何形式的交互式Shell登录。

EasySub – AI字幕生成翻译工具
EasySub – AI字幕生成翻译工具

EasySub 是一款在线 AI 字幕生成器。 它提供AI语音识别、AI字幕生成、AI字幕翻译,本来就很简单的视频剪辑。

下载

解锁Linux用户账户的具体操作步骤与注意事项

解锁Linux用户账户,听起来只是把锁上的门打开,但实际上,我们得回溯一下之前可能采取的锁定措施,确保每一环都恢复正常。不然,你可能会遇到“我明明解锁了,为什么用户还是登不进去?”的尴尬局面。

1. 解锁密码状态 如果之前使用了

passwd -l
usermod -L
来锁定账户,那么解锁的第一步就是恢复其密码认证能力。

  • 命令:
    sudo passwd -u 

    或者

    sudo usermod -U 
  • 注意事项: 这个操作只会移除
    /etc/shadow
    文件中密码哈希前的
    !
    。如果用户忘记了密码,或者密码已经过期,即使解锁了密码状态,他们仍然无法登录。在这种情况下,你可能还需要重置他们的密码:
    sudo passwd 

    然后输入两次新密码。

2. 恢复默认Shell 如果之前为了彻底禁用登录,将用户的Shell修改为

/sbin/nologin
/bin/false
,那么解锁时必须将其改回一个合法的Shell,比如
/bin/bash
/bin/zsh

  • 命令:
    sudo usermod -s /bin/bash 

    (将

    /bin/bash
    替换为用户原有的或你希望提供的合法Shell)

  • 注意事项: 忘记恢复Shell是用户解锁后依然无法登录的常见原因之一。务必检查
    /etc/passwd
    文件中用户的Shell设置。

3. 检查并重置账户过期日期 如果账户是通过

chage -E 0
设置了过期日期而锁定的,那么解锁需要移除或修改这个过期日期。

  • 命令:
    sudo chage -E -1  # 移除过期日期

    或者

    sudo chage -E YYYY-MM-DD  # 设置一个新的未来过期日期
  • 注意事项:
    chage -E -1
    会将账户设置为永不过期。

4. 综合考量与验证 解锁操作完成后,我通常会建议立即进行验证。让用户尝试登录,或者作为管理员,使用

su - 
命令切换到该用户,看看是否能正常获取Shell。

  • 安全考量: 在解锁一个账户之前,最好弄清楚为什么它会被锁定。如果是安全事件导致,解锁前需要确保安全隐患已经排除。解锁后,也应该通知用户,并建议他们更改密码,尤其是在密码被重置过的情况下。
  • 审计: 所有的锁定和解锁操作都应该被记录下来,以便日后审计。

解锁并非简单地执行一个命令,它需要你对账户之前的状态有一个清晰的了解,并采取相应的恢复措施。

如何检查Linux用户账户的锁定状态及常见问题排查

在Linux系统管理中,我们不仅要会操作,更要会“看”,即如何确认一个账户当前处于何种状态,以及当用户报告无法登录时,我们该如何快速排查问题。这就像医生看病,不能只知道开药,还得会诊断。

1. 检查密码锁定状态(

/etc/shadow
文件) 这是最直接的方式。
passwd -S
命令可以显示用户的密码状态。

  • 命令:
    sudo passwd -S 
  • 输出示例:
    testuser L 2023-01-01 0 99999 7 -1

    这里的

    L
    表示账户已锁定(Locked)。如果是
    PS
    ,表示有密码且可用(Password Set)。
    NP
    表示没有密码(No Password)。

  • 手动检查: 你也可以直接查看
    /etc/shadow
    文件。
    sudo grep '^:' /etc/shadow

    如果密码哈希前有

    !
    ,例如
    testuser:!$6$...
    ,则表示密码已锁定。

2. 检查Shell设置(

/etc/passwd
文件) 用户的默认Shell是决定他们能否获取交互式会话的关键。

  • 命令:
    grep '^:' /etc/passwd
  • 输出示例:
    testuser:x:1001:1001::/home/testuser:/sbin/nologin

    如果最后一项是

    /sbin/nologin
    /bin/false
    ,那么用户将无法登录。合法的Shell通常是
    /bin/bash
    /bin/zsh
    等。

3. 检查账户过期日期(

chage -l
如果账户设置了过期日期,即使密码和Shell都正常,也可能无法登录。

  • 命令:
    sudo chage -l 
  • 输出示例:
    Last password change                                : Jan 01, 2023
    Password expires                                    : never
    Password inactive                                   : never
    Account expires                                     : Jan 01, 2023  # 这一行是关键
    Minimum number of days between password change      : 0
    Maximum number of days between password change      : 99999
    Number of days of warning before password expires   : 7

    如果

    Account expires
    显示的是一个过去的日期,或者
    Jan 01, 2023
    这种,那么账户就是过期的。

常见问题排查:

  • 用户报告“密码错误”:
    • 首先检查
      passwd -S
      是否为
      L
      。如果是,用
      passwd -u
      解锁。
    • 如果不是
      L
      ,可能是用户真的记错了密码,或者密码已过期(
      Password expires
      显示过去的日期)。考虑重置密码。
  • 用户报告“登录成功但立即断开”或“没有Shell”:
    • 检查
      /etc/passwd
      中用户的Shell是否为
      /sbin/nologin
      /bin/false
      。如果是,用
      usermod -s /bin/bash
      等命令恢复。
    • 检查用户主目录是否存在且权限正确。
  • 用户报告“账户过期”:
    • 检查
      chage -l
      Account expires
      字段。如果是,用
      chage -E -1
      或设置未来日期。
  • 用户通过SSH密钥登录失败,但密码认证也禁用:
    • 这通常意味着SSH服务配置了不允许密码认证,而用户的SSH密钥可能没有正确配置,或者
      authorized_keys
      文件权限不正确。这不是账户锁定问题,而是SSH配置或密钥问题。

在排查问题时,我通常会遵循一个优先级:先检查密码状态,再检查Shell,最后是账户过期。这样可以系统性地缩小问题范围,提高排查效率。记住,任何系统操作都可能引入新的问题,所以验证和回溯是不可或缺的。

相关专题

更多
磁盘配额是什么
磁盘配额是什么

磁盘配额是计算机中指定磁盘的储存限制,就是管理员可以为用户所能使用的磁盘空间进行配额限制,每一用户只能使用最大配额范围内的磁盘空间。php中文网为大家提供各种磁盘配额相关的内容,教程,供大家免费下载安装。

1349

2023.06.21

如何安装LINUX
如何安装LINUX

本站专题提供如何安装LINUX的相关教程文章,还有相关的下载、课程,大家可以免费体验。

702

2023.06.29

linux find
linux find

find是linux命令,它将档案系统内符合 expression 的档案列出来。可以指要档案的名称、类别、时间、大小、权限等不同资讯的组合,只有完全相符的才会被列出来。find根据下列规则判断 path 和 expression,在命令列上第一个 - ( ) , ! 之前的部分为 path,之后的是 expression。还有指DOS 命令 find,Excel 函数 find等。本站专题提供linux find相关教程文章,还有相关

294

2023.06.30

linux修改文件名
linux修改文件名

本专题为大家提供linux修改文件名相关的文章,这些文章可以帮助用户快速轻松地完成文件名的修改工作,大家可以免费体验。

776

2023.07.05

linux系统安装教程
linux系统安装教程

linux系统是一种可以免费使用,自由传播,多用户、多任务、多线程、多CPU的操作系统。本专题提供linux系统安装教程相关的文章,大家可以免费体验。

572

2023.07.06

linux查看文件夹大小
linux查看文件夹大小

Linux是一种自由和开放源码的类Unix操作系统,存在着许多不同的Linux版本,但它们都使用了Linux内核。Linux可安装在各种计算机硬件设备中,比如手机、平板电脑、路由器、视频游戏控制台、台式计算机、大型机和超级计算机。linux怎么查看文件夹大小呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

545

2023.07.20

linux查看ip命令
linux查看ip命令

本专题为大家提供linux查看ip命令相关文章内容,感兴趣的朋友可以免费下载体验试试。

297

2023.07.20

linux查看cpu使用率
linux查看cpu使用率

在linux的系统维护中,可能需要经常查看cpu使用率,分析系统整体的运行情况。本专题为大家带来了linux查看cpu使用率的相关文章,感兴趣的朋友千万不要错过了。

380

2023.07.25

高德地图升级方法汇总
高德地图升级方法汇总

本专题整合了高德地图升级相关教程,阅读专题下面的文章了解更多详细内容。

43

2026.01.16

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 7.3万人学习

Git 教程
Git 教程

共21课时 | 2.8万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号