如何修改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

相关推荐

  • VC程序如何与Linux系统实现高效稳定的通信连接?

    在跨平台开发场景中,Visual C++(以下简称VC++)作为Windows环境下的主流开发工具,常需与Linux系统进行数据交互或功能协同,两者分别基于Windows和Linux内核,通信机制存在差异,需通过网络协议、本地IPC(进程间通信)或中间件实现数据交换,本文将系统梳理VC++与Linux通信的主流……

    2025年8月28日
    8500
  • Linux移植到ARM平台的完整流程

    前期准备硬件需求ARM开发板(如树莓派、BeagleBone)串口调试工具(USB-TTL模块)SD卡(≥8GB,Class 10)交叉编译环境(x86主机)软件工具链# 安装ARM交叉编译器(以gcc-arm-linux-gnueabihf为例)sudo apt-get install gcc-arm-lin……

    2025年7月6日
    10700
  • Linux系统如何查看历史操作记录?

    在Linux系统中,查看操作记录是系统管理、故障排查和安全审计的重要环节,操作记录可能包括用户执行的命令、登录日志、系统事件等,通过不同工具和方法可以全面追溯系统行为,以下是常用的查看操作记录的方式及具体操作方法,通过历史命令查看用户操作记录历史命令记录了用户在终端中执行过的指令,默认存储在用户主目录的.bas……

    2025年9月29日
    6400
  • linux如何关闭某个服务

    Linux中,关闭某个服务可以使用systemctl stop 服务名或`service 服务

    2025年8月19日
    7500
  • Linux打包R程序总失败?

    准备工作安装必要工具sudo apt-get install r-base-dev build-essential pandoc # Debian/Ubuntusudo yum install R-devel texlive # CentOS/RHEL确保安装最新版R(≥4.0.0)及开发工具,推荐安装devt……

    2025年7月25日
    8500

发表回复

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

联系我们

400-880-8834

在线咨询: QQ交谈

邮件:HI@E.KD.CN

关注微信