ansible修改多台机器的密码
时间: 2023-08-31 19:28:44 浏览: 138
### 回答1:
Ansible 是一款用于管理和配置服务器的软件。如果你想用 Ansible 修改多台机器的密码,可以这样做:
1. 使用 Ansible 的 `user` 模块来创建或修改用户。
2. 使用 ansible 的 `shadow` 模块来修改用户的密码。
举个例子:
```
- hosts: all
tasks:
- name: create user
user:
name: myuser
password: "$6$rounds=656000$salt$hashedpassword"
update_password: on_create
- name: change password
shadow:
name: myuser
password: "$6$rounds=656000$salt$hashedpassword"
```
在这个例子中,我们使用了 `user` 模块来创建一个名为 `myuser` 的用户,并使用 `shadow` 模块修改该用户的密码。`hosts: all` 表示这个任务将会在所有主机上执行。
注意:这里假设密码已经使用哈希值的形式存储。
### 回答2:
使用Ansible修改多台机器的密码可以通过以下步骤进行:
1. 在Ansible主控机上创建一个用于批量修改密码的Playbook文件。
在Playbook文件中,定义一个变量用于存储新密码,例如:new_password: "新密码"。
2. 添加一个任务,使用Ansible的用户模块(user module)去修改用户的密码。
在任务中,指定远程主机的用户名和新密码,例如:name: "root"和password: "{{ new_password | password_hash('sha512') }}"。
3. 配置Ansible的主机清单文件(inventory file),将需要修改密码的主机添加到一个组中。
在清单文件中,指定远程主机的IP地址或主机名,并将其分配到之前创建的组中。
4. 运行Ansible的命令行工具,执行上述Playbook文件。
在命令行中,指定使用的清单文件,例如:ansible-playbook -i inventory.ini playbook.yml。
5. Ansible会自动连接到指定的远程主机,并执行相应的任务来修改密码。
在连接过程中,Ansible会使用SSH协议实现安全的远程通信,并自动处理认证和权限。
通过以上步骤,就可以使用Ansible来自动化修改多台机器的密码。Ansible的优势在于其简单易用的编排语言和自动化能力,可以快速高效地在多台机器上执行任务。
阅读全文