如何修改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系统XAMPP环境下FTP连接的具体操作步骤是什么?

    在Linux系统中使用XAMPP搭建Web环境后,常需要通过FTP协议上传或管理网站文件,FTP(File Transfer Protocol)是一种用于在客户端和服务器之间传输文件的标准协议,结合XAMPP的目录结构(默认为/opt/lampp/htdocs),通过FTP可以高效管理网站资源,以下是详细的Li……

    2025年9月30日
    1500
  • Linux如何监控网络流量?实用方法与工具全解析指南?

    Linux作为服务器和开发环境的主流操作系统,网络流量监控是系统管理和性能优化的重要环节,通过监控网络流量,可以及时发现异常连接、带宽瓶颈、安全威胁(如DDoS攻击、数据泄露),并为网络扩容提供依据,本文将详细介绍Linux中常用的网络流量监控工具,包括其原理、使用方法及适用场景,帮助读者根据实际需求选择合适的……

    2025年9月18日
    3600
  • 安装前你准备好了吗?

    Java Development Kit(JDK)是开发和运行Java应用的核心工具包,在Linux系统中安装JDK是开发者的基础操作,本文将提供三种主流安装方法,涵盖OpenJDK和Oracle JDK,并详解环境变量配置与故障排查,确保您高效完成部署,检查现有JDK终端执行以下命令,若返回版本号则已安装:j……

    2025年7月24日
    4500
  • Linux如何设置锁屏时间与系统时间?

    在Linux系统中,系统时间与锁屏时间的设置是日常使用中常见的操作,前者关系到系统日志、任务调度等功能的准确性,后者则影响设备的安全性与使用便捷性,本文将详细讲解Linux系统时间设置与锁屏时间设置的具体方法,涵盖不同发行版和桌面环境的操作步骤,并提供实用注意事项,Linux系统时间设置Linux系统时间管理涉……

    2025年9月20日
    2600
  • Linux系统调优如何针对CPU、内存、磁盘、网络进行优化?

    Linux系统调优是提升服务器性能、稳定性和资源利用率的关键工作,需结合实际业务场景从CPU、内存、磁盘、网络、内核参数等多维度综合优化,以下是具体调优方向及操作方法:CPU调优CPU调优核心在于均衡负载、减少上下文切换和提升计算效率,首先通过top、htop、vmstat等工具监控CPU使用率,若user(用……

    2025年9月18日
    1900

发表回复

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

联系我们

400-880-8834

在线咨询: QQ交谈

邮件:HI@E.KD.CN

关注微信