ansible普通用户批量修改密码

ansible批量修改密码

#日常运维为了安全会禁止root远程登陆,并且要求用户三个月改一次密码,这时当机器比较多时,一台一台操作就比较麻烦。可以考虑以下方案

#创建一个普通用户,并加入wheel组,默认情况下只有加入wheel组的用户才能使用sudo提权

bash 复制代码
useradd -m -s /bin/bash admin_user

# 2. 为该用户设置初始密码
passwd admin_user

# 3. 赋予 sudo 权限
# 方法 A (推荐): 将用户加入 wheel 组 (CentOS/RHEL) 或 sudo 组 (Ubuntu/Debian)
usermod -aG wheel admin_user   # CentOS/RHEL/Fedora



#创建ansible的hosts文件
#同密码机器作为一批机器组

[webservers]
10.0.0.11

[webservers:vars]
# 指定登录的普通用户
ansible_user=admin_user
ansible_password=xxxxxxx
# 如果使用了 SSH 密钥,指定私钥路径(如果没有配置 ssh-agent 或默认 ~/.ssh/id_rsa)
# ansible_ssh_private_key_file=~/.ssh/id_rsa

# 【关键】开启提权模式 (相当于 sudo)
ansible_become=yes
# 如果 sudo 需要密码,在这里配置用来提权的用户密码 (如果配置了 NOPASSWD 则不需要这行)
ansible_become_password=xxxxxxx
yaml 复制代码
- name: Batch Update Root Password on Hardened Servers
  hosts: webservers
  gather_facts: no  # 加快速度,不需要收集系统信息
  
  tasks:
    - name: Update root password using user module
      user:
        name: root
        # 这里使用加密后的密码字符串,避免明文
        # 可以使用 mkpasswd 命令生成: mkpasswd -m sha-512 "NewPassword123!",或者python3 -c 'import crypt; print(crypt.crypt("b0++1Y#4I~ZPAE1", crypt.mksalt(crypt.METHOD_SHA512)))'
        password: "$6$v08nweH6wdN9cgZl$e6iEgRzpy7RltRmVq3HFl4AuUOnzPLPSTpVG3YqpABkC3kOh74NxDLy6KqUXMGh69q8t8WVengryo0a7ql08J0"
        update_password: always
      become: yes  # 再次确认需要提权 (虽然 inventory 里已经全局设置了)
      become_method: sudo
bash 复制代码
ansible-playbook -i hosts change_root_pwd.yml

#如果没有在Hosts文件写密码,,或者没有生成密钥则可以添加询问模式
ansible-playbook -i hosts change_root_pwd.yml --ask-pass --ask-become-pass
相关推荐
测试修炼手册1 天前
[测试工具] 用 Codex 做测试实战:从需求分析到自动化用例落地
运维·自动化·需求分析
米高梅狮子1 天前
03.网络类服务实践
linux·运维·服务器·网络·kubernetes·centos·openstack
IpdataCloud1 天前
稳定的企业级IP数据接口怎么选?可用性指标+离线库高可用方案
运维·网络·tcp/ip
WebGIS开发1 天前
地信职业百科②:GIS运维
运维·gis·就业·转行
淘矿人1 天前
Claude辅助DevOps实践
java·大数据·运维·人工智能·算法·bug·devops
JiaWen技术圈1 天前
nginx 安全响应头 介绍
运维·nginx·安全
IMPYLH1 天前
Linux 的 unexpand 命令
linux·运维·服务器·bash
|_⊙1 天前
Linux 文件知识 补充
linux·运维·服务器
十六年开源服务商1 天前
2026服务器配置优化与WordPress运维实战指南
android·运维·服务器
LN花开富贵1 天前
Ubuntu aarch64 架构安装 NoMachine 远程控制 避坑与实战
linux·运维·笔记·学习·ubuntu·嵌入式