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
相关推荐
unfeeling_2 小时前
Nginx实验
运维·nginx
悠闲蜗牛�2 小时前
边缘AI推理实战:从服务器到嵌入式设备的模型部署与优化
运维·服务器·人工智能
shawnyz2 小时前
Nginx的源码编译
运维·nginx
The️3 小时前
Linux驱动开发之Read_Write函数
linux·运维·服务器·驱动开发·ubuntu·交互
fengtangjiang3 小时前
国产操作系统安装tomcat
linux·运维·tomcat
牛奶咖啡134 小时前
DevOps自动化运维实践_使用再生龙对Linux系统进行备份还原
运维·自动化·devops·linux系统的备份还原·linux系统克隆备份·再生龙
Starry_hello world4 小时前
Linux 信号量
linux·运维
njsgcs4 小时前
最小化终端 到托盘 minimizeToNotificationArea
运维
2401_849339174 小时前
nginx
运维·nginx