ansible 实现批量免密
时间: 2023-09-20 16:05:10 浏览: 171
可以通过 Ansible 的 SSH 连接配置来实现批量免密的功能。具体步骤如下:
1. 在 Ansible 的控制节点上生成 SSH 密钥对:
```
ssh-keygen -t rsa
```
2. 将公钥复制到需要免密登录的目标节点上:
```
ssh-copy-id <user>@<target-host>
```
3. 在 Ansible 的配置文件中添加 SSH 连接配置,指定使用 SSH 密钥登录:
```
[defaults]
private_key_file=/path/to/private_key
```
4. 在 Ansible 的 inventory 文件中指定目标节点的用户名和 SSH 端口号:
```
[target-group]
<target-host> ansible_user=<user> ansible_port=<port>
```
这样,在执行 Ansible playbook 或 ad-hoc 命令时,Ansible 将使用 SSH 密钥进行免密登录目标节点。
相关问题
Ansible 批量下载 免密
### 使用 Ansible 批量下载文件并配置免密登录
#### 安装 Ansible 和准备环境
为了实现批量操作,首先需要确保目标机器上已经安装了 Ansible。可以通过包管理器来完成这一工作:
```bash
sudo apt-get update && sudo apt-get install -y ansible
```
对于 RedHat/CentOS 类系统,则应使用 `yum`:
```bash
sudo yum install epel-release
sudo yum install ansible
```
#### 编写 Playbook 进行批量下载文件
Ansible 的强大之处在于其 playbook 文件,这些 YAML 格式的剧本定义了一系列的任务去执行特定的操作。
创建一个新的 playbook 来描述要执行的动作,比如名为 `batch_download.yml` :
```yaml
---
- hosts: all
become: yes
tasks:
- name: Download file from URL
get_url:
url: http://example.com/path/to/file.zip
dest: /tmp/file.zip
mode: '0755'
```
上述脚本会指示每台主机从指定URL地址下载压缩包到临时目录下,并设置权限为可读可执行[^1]。
#### 设置 SSH 密钥认证以支持无密码登录
为了让后续任务能够顺利运行而不需要人工干预输入密码,在此之前还需要先建立SSH公私钥对以及分发给各节点。
编写另一个playbook用于生成密钥对并将公钥复制至远程服务器,命名为 `setup_ssh_key.yml` :
```yaml
---
- hosts: localhost
gather_facts: no
tasks:
- name: Generate ssh key pair on local machine if not exist
user:
name: "{{ansible_user}}"
generate_ssh_key: yes
ssh_key_bits: 2048
ssh_key_file: ~/.ssh/id_rsa
when: lookup('file', '~/.ssh/id_rsa.pub') is failed
- hosts: all
become: true
tasks:
- name: Ensure .ssh directory exists with proper permissions
file:
path: /root/.ssh
state: directory
owner: root
group: root
mode: '0700'
- name: Copy public key to remote host's authorized_keys
authorized_key:
user: root
state: present
key: "{{lookup('file', '/home/{{ansible_user}}/.ssh/id_rsa.pub')}}"
```
这段代码首先会在本地计算机检查是否存在SSH密钥对,如果不存在则自动生成一对新的RSA密钥;接着向所有被管设备推送当前用户的公钥,使得之后可以无需密码验证即可通过SSH连接它们[^2]。
#### 合并两个Playbooks简化流程
考虑到实际应用场景可能更倾向于一次性完成全部准备工作,因此可以把上面提到的功能整合成单一的playbook以便于管理和调用。
以下是综合版本的 `prepare_environment.yml` :
```yaml
---
- hosts: localhost
connection: local
gather_facts: false
vars_prompt:
- name: target_hosts
prompt: Please enter the IP addresses or hostname of targets separated by commas.
private: no
tasks:
- name: Install required packages locally
package:
name: python3-pip,git
state: latest
- block:
- include_tasks: setup_ssh_key.yml
- add_host:
name: "{{ item }}"
loop: "{{target_hosts.split(',')}}"
- meta: flush_handlers
delegate_to: localhost
- hosts: all
any_errors_fatal: true
roles:
- role: common_role # 假设有一个通用的角色负责处理一些基础性的事务
post_tasks:
- import_playbook: batch_download.yml
```
这个完整的 playbooks 不仅实现了前面介绍过的功能,还加入了动态添加新主机的能力,允许用户交互式地提供待部署的目标列表。此外,它也引入了一个假设存在的角色 (`common_role`) ,这通常用来封装那些几乎每次都会涉及到的基础设定项,如更新软件源、关闭防火墙等[^3]。
ansible批量免密
以下是使用Ansible实现批量免密的步骤:
1. 在Ansible的master主控机上生成公私秘钥,执行命令:
```shell
ssh-keygen -t rsa
```
这将在当前用户的主目录下生成一个名为`.ssh`的目录,其中包含`id_rsa`和`id_rsa.pub`两个文件,分别是私钥和公钥。
2. 将公钥复制到所有需要免密登录的远程主机上,执行命令:
```shell
ssh-copy-id user@remote_host
```
其中`user`是远程主机的用户名,`remote_host`是远程主机的IP地址或域名。执行该命令后,会提示输入远程主机的密码,输入后即可将公钥复制到远程主机上。
3. 验证免密登录是否成功,执行命令:
```shell
ssh user@remote_host
```
如果成功登录远程主机而不需要输入密码,则说明免密登录已经成功实现。
阅读全文