如何修改Linux服务器密码?详细操作步骤是怎样的?

修改Linux服务器密码是系统管理和安全维护的基础操作,根据登录方式(本地/远程)、用户权限(普通用户/root)以及是否忘记密码等不同场景,操作方法有所差异,以下是详细的操作步骤、注意事项及常见问题处理,帮助管理员安全高效地完成密码修改

如何修改linux服务器密码

本地登录修改当前用户密码

当已通过控制台或本地终端登录Linux服务器时,修改当前用户的密码需使用passwd命令,操作流程如下:

  1. 执行passwd命令
    在终端输入passwd,按回车执行,如果是普通用户,系统会要求先输入当前密码进行验证;如果是root用户,可直接跳过验证。

    passwd
  2. 输入新密码
    根据提示输入两次新密码(第二次输入为确认,终端不会显示字符),密码需符合系统策略(如长度、字符类型),若不符合要求会提示重新输入。

  3. 确认修改成功
    密码修改成功后,终端会显示passwd: password updated successfully(密码更新成功),新密码立即生效,后续登录需使用新密码。

本地登录修改其他用户密码(需root权限)

若需修改其他用户的密码(如修改普通用户test的密码),必须使用root权限操作,步骤如下:

  1. 切换至root用户
    普通用户可通过su -命令切换至root(需输入root密码),或直接使用sudo passwd username(需配置sudo权限)。

    su -  # 输入root密码后切换
  2. 执行passwd命令指定用户
    使用passwd + 用户名修改目标用户密码,例如修改test用户:

    passwd test
  3. 输入并确认新密码
    根据提示输入两次新密码(无需输入目标用户旧密码),root用户可直接为其他用户设置任意符合策略的密码。

远程SSH登录修改密码

通过SSH远程连接服务器时,修改密码的操作与本地登录一致,但需确保SSH服务正常运行且网络连通。

如何修改linux服务器密码

  1. 建立SSH连接
    使用ssh命令连接服务器,例如以test用户远程登录168.1.100

    ssh test@192.168.1.100
  2. 执行passwd命令
    登录成功后,与本地操作一致,输入passwd修改当前用户密码,或root用户通过passwd username修改其他用户密码。

  3. 测试新密码
    修改完成后,可退出当前会话(exit),重新使用SSH连接测试新密码是否生效。

忘记密码的应急处理

若忘记root密码或关键用户密码,需通过“单用户模式”或“恢复模式”绕过密码验证重置密码,具体操作因Linux发行版(如CentOS/RHEL、Ubuntu/Debian)而异。

(一)CentOS/RHEL系统(以CentOS 7为例)

  1. 重启服务器并进入GRUB菜单
    重启服务器时,长按Shift键(或根据BIOS/UEFI设置按Esc),进入GRUB引导菜单。

  2. 编辑内核启动参数
    选择默认内核版本,按e键进入编辑模式,找到以linux16linuxefi开头的行,在行尾添加rd.break(临时中断启动进入initramfs环境)。

  3. 切换至系统根目录并修改密码

    • Ctrl+X启动系统,进入紧急模式后,执行以下命令挂载系统根目录:
      mount -o remount,rw /sysroot
    • 切换至系统根环境:
      chroot /sysroot
    • 使用passwd命令重置root密码(步骤同前),完成后输入exit退出chroot环境。
  4. 重启并验证
    执行reboot重启服务器,新密码生效,若系统启用了SELinux,建议首次重启后执行touch /.autorelabel(触发文件标签重标记),避免权限异常。

(二)Ubuntu/Debian系统

  1. 重启进入GRUB菜单
    重启时长按Shift键,进入GRUB引导界面。

    如何修改linux服务器密码

  2. 选择恢复模式
    选择Advanced options,进入当前内核的Recovery模式,再选择“root Drop to root shell prompt”(进入root终端)。

  3. 挂载根目录并修改密码

    • 挂载根目录为可读写模式:
      mount -o rw,remount /
    • 使用passwd命令重置root密码,完成后输入reboot重启。

密码策略与注意事项

为提升系统安全性,密码修改需遵循以下策略,可通过表格对比关键要求:

策略项 建议要求
密码长度 至少8位,推荐12位以上
字符复杂度 包含大写字母(A-Z)、小写字母(a-z)、数字(0-9)、特殊字符(如!@#$%^&*)
定期更换 建议每90天更换一次,避免长期使用相同密码
密码历史记录 通过/etc/login.defs配置PASS_MAX_DAYS(密码有效期)和PASS_MIN_DAYS(修改间隔)

额外注意事项

  • 修改密码后,及时清理终端历史记录(history -c),避免密码泄露。
  • 若服务器使用密钥认证+密码双重验证,修改密码后需确保密钥认证仍有效。
  • 批量修改多台服务器密码时,建议使用Ansible、SaltStack等自动化工具,避免手动操作遗漏。

相关问答FAQs

Q1:修改密码后提示“Authentication token manipulation error”,如何解决?
A:该错误通常由磁盘空间不足、/etc/shadow文件权限异常或SELinux强制模式导致,可按以下步骤排查:

  1. 检查磁盘空间:df -h,若根目录()使用率超过90%,清理临时文件(如/tmp目录)。
  2. 修复/etc/shadow权限:chmod 600 /etc/shadow(确保仅root可读写)。
  3. 临时关闭SELinux(测试用):setenforce 0,若问题解决,则需检查SELinux策略或启用allowpassword布尔值(setsebool -P allowpasswordonkey on)。

Q2:如何通过脚本批量修改多台Linux服务器的密码?
A:可结合sshpassexpect工具实现非交互式批量修改,或使用Ansible Playbook(推荐),以下为Ansible示例:

  1. 安装Ansible:yum install ansible -y(CentOS)或apt install ansible -y(Ubuntu)。
  2. 创建主机清单文件hosts.ini,定义目标服务器:
    [servers]  
    server1 ansible_ssh_user=root ansible_ssh_host=192.168.1.101  
    server2 ansible_ssh_user=root ansible_ssh_host=192.168.1.102  
  3. 创建Playbookreset_password.yml
    ---  
    - name: Batch reset password  
      hosts: servers  
      tasks:  
        - name: Update root password  
          user:  
            name: root  
            password: "{{ 'NewPass123!' | password_hash('sha512') }}"  # 替换为自定义密码  
            update_password: always  
  4. 执行Playbook:ansible-playbook -i hosts.ini reset_password.yml,输入SSH密码或配置SSH免密后即可批量修改。

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

(0)
酷番叔酷番叔
上一篇 2025年10月1日 00:47
下一篇 2025年10月1日 01:04

相关推荐

  • Linux系统中如何解压tar文件?

    在Linux系统中,tar是一种常用的文件归档工具,它能够将多个文件或目录合并成一个单一的文件,常用于文件的备份、传输和压缩,tar本身只负责打包,不进行压缩,但可以结合gzip、bzip2、xz等压缩工具生成压缩的归档文件(如.tar.gz、.tar.bz2、.tar.xz等),解压tar文件时,需要根据不同……

    2025年8月30日
    3600
  • 如何往Linux虚拟机传文件?有哪些常用方法和步骤?

    在Linux虚拟机的日常使用中,向虚拟机内传输文件是常见需求,无论是配置文件、数据集还是开发工具,都需要高效、安全的方式完成传输,根据虚拟机与宿主机的连接方式、文件大小、安全需求等不同场景,可选择多种传输方法,本文将详细介绍几种主流的文件传输方式,包括原理、操作步骤及注意事项,帮助用户根据实际情况选择最适合的方……

    2025年8月24日
    3000
  • Linux不同格式安装包如何解压?

    常见安装包格式及解压工具格式工具安装命令(如未预装).tartar默认预装.gzgzip/tarsudo apt install gzip.bz2bzip2/tarsudo apt install bzip2.xzxz/tarsudo apt install xz-utils.zipunzipsudo apt……

    2025年6月17日
    6200
  • 在Linux系统中,sar性能监控工具的安装步骤和配置方法是什么?

    在Linux系统中,sar(System Activity Reporter)是sysstat工具包中的一个核心组件,用于收集、统计和报告系统的各项性能数据,如CPU使用率、内存占用、磁盘I/O、网络流量等,通过sar,管理员可以实时监控系统状态,或分析历史数据排查性能瓶颈,本文将详细介绍Linux环境下安装s……

    2025年10月2日
    1300
  • 如何正确修改Linux系统时区?详细操作步骤与方法有哪些?

    Linux系统中,时区的正确设置对日志记录、定时任务执行、应用程序运行等至关重要,若系统时区与实际地理位置不符,可能导致时间显示错误、任务调度异常等问题,本文将详细介绍Linux系统时区的修改方法,涵盖不同发行版和工具的使用,并附上注意事项与常见问题解答,Linux时区修改的常用方法Linux系统修改时区主要有……

    2025年10月7日
    1000

发表回复

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

联系我们

400-880-8834

在线咨询: QQ交谈

邮件:HI@E.KD.CN

关注微信