如何修改Linux系统中的用户密码?

Linux系统中,用户密码管理是系统安全的核心环节之一,无论是日常使用还是管理员维护,掌握正确的密码修改方法都至关重要,本文将详细介绍不同场景下Linux用户密码修改方式,包括普通用户自主修改、管理员修改他人密码、紧急情况下的密码重置以及批量密码处理等,帮助用户全面掌握密码管理技能。

如何改变linux用户密码

普通用户修改自己的密码

普通用户通常需要修改自己的登录密码,这一过程需要当前密码验证,确保只有账户本人能更改密码,操作步骤如下:

  1. 登录系统:首先使用当前用户名和密码登录Linux系统,可通过终端(命令行界面)或图形界面登录(图形界面下打开终端即可)。
  2. 执行passwd命令:在终端输入passwd命令,按回车键执行,系统会提示输入当前密码(输入时字符不会显示,这是Linux的安全设计)。
  3. 设置新密码:当前密码验证通过后,系统要求输入新密码,再次输入新密码进行确认。
  4. 密码复杂度检查:Linux系统默认会对新密码的复杂度进行检查(如长度、字符类型等),若密码不符合策略(如过于简单、与用户名相同等),会提示重新输入。

示例操作

$ passwd  # 执行passwd命令
Changing password for user testuser.  # 系统提示修改testuser的密码
Current password:  # 输入当前密码(不显示字符)  
New password:      # 输入新密码(不显示字符)  
Retype new password:  # 再次输入新密码  
passwd: password updated successfully  # 提示密码修改成功  

注意事项

  • 密码长度建议至少8位,包含大小写字母、数字和特殊字符(如!@#$%),以提高安全性。
  • 若需修改密码复杂度策略,可编辑/etc/login.defs/etc/pam.d/passwd文件(需root权限)。

管理员(root用户)修改其他用户密码

管理员(root用户或具有sudo权限的用户)可以修改任何用户的密码,无需知道原密码,这一功能常用于用户忘记密码或管理员重置用户场景。

使用root用户直接修改

若当前登录用户为root,可直接使用passwd 用户名命令,无需额外验证。

示例操作

[root@localhost ~]# passwd testuser  # 修改testuser的密码  
New password:  # 输入新密码(root用户设置密码时无复杂度检查)  
Retype new password:  # 确认新密码  
passwd: password updated successfully  

使用sudo权限修改

若当前用户不是root但具有sudo权限(如在Ubuntu系统中),可在passwd命令前加sudo,输入当前用户密码后即可修改目标用户密码。

如何改变linux用户密码

示例操作

$ sudo passwd testuser  # 使用sudo修改testuser密码  
[sudo] password for adminuser:  # 输入当前用户(adminuser)的密码  
New password:  # 输入testuser的新密码  
Retype new password:  
passwd: password updated successfully  

特殊场景下的密码重置

用户忘记密码且无法登录(需物理访问或远程 rescue 模式)

若用户忘记密码且无法通过常规方式登录(如SSH被锁定),可通过进入单用户模式或救援模式重置密码,不同发行版操作略有差异,以CentOS 7和Ubuntu 20.04为例:

CentOS 7(单用户模式)

  • 重启系统,在GRUB启动菜单中选择“CentOS Linux (x86_64) with advanced options”,按e键进入编辑模式。
  • 找到linux16linuxefi开头的行,在行尾添加rd.break,按Ctrl+X启动。
  • 系统进入紧急模式,执行以下命令:
    mount -o remount,rw /sysroot  # 重新挂载根目录为可读写  
    chroot /sysroot  # 切换到根环境  
    passwd testuser  # 重置testuser密码  
    touch /.autorelabel  # 可选:若SELinux启用,需创建此文件以重新标记文件系统  
    exit  # 退出chroot  
    reboot  # 重启系统  

Ubuntu 20.04(recovery模式)

  • 重启系统,在GRUB菜单中选择“Advanced options for Ubuntu”,进入“recovery mode”。
  • 选择“root Drop to root shell prompt”,按回车进入root终端。
  • 执行mount -o remount,rw /重新挂载根目录,然后使用passwd testuser修改密码,最后执行reboot重启。

批量修改用户密码

管理员可通过chpasswd命令批量修改用户密码,适用于大量用户场景(如服务器初始化配置),操作步骤如下:

  1. 创建密码文件:创建一个文本文件,格式为“用户名:密码”,每行一个用户,
    echo -e "user1:Passw0rd1!nuser2:Passw0rd2!nuser3:Passw0rd3!" > userpass.txt  
  2. 使用chpasswd批量修改:通过chpasswd命令读取文件并设置密码,需root权限:
    chpasswd < userpass.txt  
  3. 安全处理密码文件:密码文件包含明文密码,修改后应立即删除或加密存储:
    shred -u userpass.txt  # 安全删除文件  

注意事项:批量修改密码时,确保密码文件来源可靠,避免泄露。

Linux用户密码修改方法对比

为方便用户快速选择合适的方法,以下通过表格总结不同场景下的操作要点:

如何改变linux用户密码

方法 适用场景 命令格式 注意事项
普通用户passwd 用户自主修改自身密码 passwd 需验证当前密码,符合密码复杂度策略
root用户passwd root修改任意用户密码 passwd 用户名 无需原密码,无复杂度检查
sudo passwd 非root管理员修改他人密码 sudo passwd 用户名 需当前用户有sudo权限,输入当前用户密码
单用户/救援模式重置 用户忘记密码且无法登录 需进入系统维护模式 需物理访问或远程 rescue 权限
chpasswd批量修改 管理员批量修改多个用户密码 chpasswd < 密码文件 密码文件需明文,操作后需安全删除

相关问答FAQs

Q1:修改密码时提示“Authentication token manipulation error”,如何解决?
A:该错误通常是由于密码文件(/etc/shadow)权限异常或磁盘空间不足导致,可尝试以下步骤:

  1. 检查/etc/shadow权限,确保root用户可读写:ls -l /etc/shadow(应为-rw-r--r-- 1 root root)。
  2. 若权限异常,执行chmod 644 /etc/shadow修复(需root权限)。
  3. 检查磁盘空间:df -h,若根目录空间不足(如剩余空间小于1%),清理临时文件后重试。
  4. 若仍报错,尝试强制更新密码文件:pwconv(确保shadow文件与passwd文件同步)。

Q2:如何查看用户上次修改密码的时间及密码过期策略?
A:Linux系统通过/etc/shadow文件记录用户密码信息,可通过chage命令查看和修改:

  1. 查看用户密码信息
    chage -l testuser  # 查看testuser的密码策略和修改时间  

    输出示例:

    Last password change                                    : Oct 20, 2023  
    Password expires                                        : Jan 18, 2024  
    Password inactive                                       : never  
    Account expires                                         : never  
    Minimum number of days between password change          : 7  
    Maximum number of days between password change          : 90  
    Number of days of warning before password expires       : 7  
  2. 修改密码过期策略(如设置密码90天后过期):
    sudo chage -M 90 testuser  # -M设置最大有效期(天)  
  3. 强制用户下次登录修改密码
    sudo chage -d 0 testuser  # -d将上次修改时间设为0,用户登录后需立即改密  

通过以上方法,用户可灵活应对不同场景下的Linux密码管理需求,确保系统安全性和用户权限的合理控制。

原创文章,发布者:酷番叔,转转请注明出处:https://cloud.kd.cn/ask/26529.html

(0)
酷番叔酷番叔
上一篇 2025年9月20日 02:25
下一篇 2025年9月20日 02:39

相关推荐

  • linux如何停止后台脚本

    Linux 中,可以使用 kill 命令停止后台脚本,例如先

    2025年8月13日
    12400
  • Linux中goto语句如何使用?

    在Linux环境下,goto语句是C/C++等编程语言提供的控制流语句,用于无条件跳转到代码中定义的标签处,它常用于简化错误处理或退出多层嵌套,但需谨慎使用以避免代码结构混乱。

    2025年7月16日
    14900
  • Systemd启动为何变慢?

    理解 Linux 中的”刷新”在 Linux 中,“刷新”并非单一操作,而是根据场景分为四类:图形界面刷新:重载桌面或应用视图系统级刷新:同步数据、清理缓存或重载配置网络配置刷新:更新网络设置终端显示刷新:重置命令行显示图形界面刷新(桌面环境)适用于 GNOME、KDE 等桌面用户:快捷键刷新按 F5 或 Ct……

    2025年7月12日
    12100
  • 如何构造linux panic

    Linux系统中,通过执行非法操作或引发内核错误(如除以零、访问无效内存)可导致系统panic。

    2025年8月16日
    12100
  • Linux系统如何正确退出登陆?

    在Linux系统中,退出登录是日常操作中不可或缺的一环,它不仅关系到用户会话的正常终止,还涉及系统资源的释放、安全性的保障以及后续用户的使用体验,不同的登录场景(如命令行登录、远程SSH登录、图形界面登录)对应着不同的退出方式,理解这些方法的原理和适用场景,能够帮助用户更高效、安全地管理系统会话,本文将详细解析……

    2025年10月3日
    10200

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

联系我们

400-880-8834

在线咨询: QQ交谈

邮件:HI@E.KD.CN

关注微信