连接方法和细节

本节介绍如何扩展和细化 Ansible 用于您的清单的连接方法。

ControlPersist 和 paramiko

默认情况下,Ansible 使用原生 OpenSSH,因为它支持 ControlPersist(一项性能特性)、Kerberos 和 ~/.ssh/config 中的选项,例如跳跃主机设置。如果您的控制机使用不支持 ControlPersist 的旧版 OpenSSH,Ansible 将回退到 OpenSSH 的 Python 实现,称为“paramiko”。

设置远程用户

默认情况下,Ansible 使用您在控制节点上使用的用户名连接到所有远程设备。如果该用户名在远程设备上不存在,您可以为连接设置不同的用户名。如果您只需要以不同的用户身份执行一些任务,请查看 了解特权提升:become。您可以在剧本中设置连接用户

---
- name: update webservers
  hosts: webservers
  remote_user: admin

  tasks:
  - name: thing to do first in this playbook
  . . .

作为清单中的主机变量

other1.example.com     ansible_connection=ssh        ansible_user=myuser
other2.example.com     ansible_connection=ssh        ansible_user=myotheruser

或作为清单中的组变量

cloud:
  hosts:
    cloud1: my_backup.cloud.com
    cloud2: my_backup2.cloud.com
  vars:
    ansible_user: admin

另请参见

ssh_connection

关于 remote_user 关键字和 ansible_user 变量的详细信息。

控制 Ansible 的行为:优先级规则

关于 Ansible 优先级规则的详细信息。

设置 SSH 密钥

默认情况下,Ansible 假设您使用 SSH 密钥连接到远程机器。鼓励使用 SSH 密钥,但如果需要,您可以使用 --ask-pass 选项使用密码身份验证。如果您需要为 特权提升(sudo、pbrun 等)提供密码,请使用 --ask-become-pass

注意

Ansible 不会公开一个通道,允许用户和 ssh 进程之间的通信,以便在使用 ssh 连接插件(默认)时手动接受密码来解密 ssh 密钥。强烈建议使用 ssh-agent

要设置 SSH 代理以避免重新输入密码,您可以执行

$ ssh-agent bash
$ ssh-add ~/.ssh/id_rsa

根据您的设置,您可能希望使用 Ansible 的 --private-key 命令行选项来指定一个 pem 文件。您还可以添加私钥文件

$ ssh-agent bash
$ ssh-add ~/.ssh/keypair.pem

另一种无需使用 ssh-agent 即可添加私钥文件的方法是使用 ansible_ssh_private_key_file 在清单文件中,如这里所述:如何构建您的清单

针对 localhost 运行

您可以使用“localhost”或“127.0.0.1”作为服务器名称,针对控制节点运行命令

$ ansible localhost -m ping -e 'ansible_python_interpreter="/usr/bin/env python"'

您可以通过在您的清单文件中添加以下内容来明确指定 localhost

localhost ansible_connection=local ansible_python_interpreter="/usr/bin/env python"

管理主机密钥检查

Ansible 默认情况下启用主机密钥检查。检查主机密钥可以防止服务器欺骗和中间人攻击,但它确实需要一些维护。

如果主机被重新安装并且在“known_hosts”中具有不同的密钥,这将导致错误消息,直到更正为止。如果新主机不在“known_hosts”中,您的控制节点可能会提示您确认密钥,这会导致使用 Ansible 时出现交互式体验,例如来自 cron 的交互式体验。您可能不希望这样。

如果您了解其含义并希望禁用此行为,您可以通过编辑 /etc/ansible/ansible.cfg~/.ansible.cfg 来实现

[defaults]
host_key_checking = False

或者,这可以通过 ANSIBLE_HOST_KEY_CHECKING 环境变量设置

$ export ANSIBLE_HOST_KEY_CHECKING=False

还要注意,paramiko 模式下的主机密钥检查速度相当慢,因此在使用此功能时也建议切换到“ssh”。

其他连接方法

Ansible 可以使用除 SSH 之外的各种连接方法。您可以选择任何连接插件,包括在本地管理和管理 chroot、lxc 和 jail 容器。一种称为“ansible-pull”的模式还可以反转系统,让系统通过计划的 git 检出“主动联系”中央存储库,以从中央存储库拉取配置指令。