如何修改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系统安装过程中,用户可能因操作失误、需求变更或硬件问题需要退出安装程序,不同安装界面(图形化/文本化)及不同发行版(Ubuntu/CentOS等)的退出方式存在差异,需根据具体场景选择合适操作,避免因强制退出导致系统文件损坏或引导异常,安装程序运行中的退出是最常见场景,对于图形化安装界面(如Ubun……

    2025年9月9日
    7200
  • Linux遍历目录有哪些实用方法?常用命令及具体操作步骤是什么?

    Linux遍历目录是日常运维和开发中的基础操作,无论是查找特定文件、批量处理数据还是分析目录结构,都需要掌握高效的遍历方法,本文将详细介绍几种主流的目录遍历方式,包括基础命令、高级工具及脚本化处理技巧,基础命令:ls递归遍历ls命令是Linux中最基础的文件列表工具,通过-R(递归)选项可实现简单目录遍历,ls……

    2025年8月28日
    8400
  • Linux系统下如何连接光纤磁盘阵列柜?

    在Linux系统下连接光纤磁盘阵列柜需经历硬件准备、物理连接、驱动安装、设备发现、多路径配置及文件系统挂载等流程,以下是详细步骤:硬件准备与物理连接光纤磁盘阵列柜通过光纤通道(FC)与服务器通信,需确保以下硬件组件就绪:组件类型/要求注意事项服务器端HBA卡PCIe接口光纤通道卡(如QLogic 2580、Em……

    2025年9月29日
    7500
  • Linux系统如何修改域控的配置信息?

    在Linux系统中,“域”可能涉及多个层面的配置,常见的包括DNS搜索域(影响域名解析)、Active Directory域(域成员身份)、主机名中的域名部分(如host.example.com)以及特定服务(如Samba)的域配置,不同场景下的修改方法差异较大,本文将分场景详细介绍Linux系统中修改域的具体……

    2025年8月28日
    7200
  • Linux如何访问光盘内容?

    检查光盘是否被识别插入光盘:将光盘放入光驱(物理服务器/虚拟机均可),查看设备节点:ls /dev/sr*输出示例:/dev/sr0(常见设备名,可能为/dev/cdrom),若未显示设备,尝试重启光驱服务:sudo systemctl restart udisks2挂载光盘到目录创建挂载点(目录):sudo……

    2025年7月9日
    9600

发表回复

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

联系我们

400-880-8834

在线咨询: QQ交谈

邮件:HI@E.KD.CN

关注微信