我正在通过Terraform设置新服务器,并将Ansible用作本地系统上的设置者。
Terraform在EC2上配置了一个系统,然后运行Ansible剧本,提供新建系统的IP作为清单。
我想使用Ansible等待系统完成引导,并阻止尝试进一步的任务,直到可以建立连接为止。到目前为止,我一直在使用手动暂停功能,这种手动操作不方便且不精确。
Ansible似乎并没有按照文档所说的去做(除非我错了,这是一个非常可能的情况)。这是我的代码:
- name: waiting for server to be alive
wait_for:
state: started
port: 22
host: "{{ ansible_ssh_host | default(inventory_hostname) }}"
delay: 10
timeout: 300
connect_timeout: 300
search_regex: OpenSSH
delegate_to: localhost
在此步骤中发生的事情是连接等待建立连接的时间不超过10秒,并且连接失败。如果服务器已启动,并且我再次尝试了剧本,则它可以正常工作并按预期执行。
我也尝试过do_until
样式循环,但似乎永远无法正常工作。文档中给出的所有示例都使用shell输出,但我看不出它将对非shell模块起作用。
如果尝试注册结果并使用调试模块将其打印出,我似乎也看不到任何调试信息。
有人对我做错了什么建议吗?
当您使用delegate_to
或local_action
模块时,{{ ansible_ssh_host }}
解析为localhost
,因此您的任务始终使用以下参数运行:
host: localhost
它等待10秒钟,检查与本地主机的SSH连接并继续(因为它很可能已打开)。
如果您使用gather_facts: false
(相信您会这样做),则可以set_fact
在前面添加一个任务,以将目标主机名值存储在变量中:
- set_fact:
host_to_wait_for: "{{ ansible_ssh_host | default(inventory_hostname) }}"
并将行更改为:
host: "{{ host_to_wait_for }}"
您可以使用以下剧本对变量进行证明测试:
---
- hosts: all
gather_facts: false
tasks:
- set_fact:
host_to_wait_for: "{{ ansible_ssh_host | default(inventory_hostname) }}"
- debug: msg="ansible_ssh_host={{ ansible_ssh_host }}, inventory_hostname={{ inventory_hostname }}, host_to_wait_for={{ host_to_wait_for }}"
delegate_to: localhost
另外,您可以尝试找到一种方法来将EC2实例的IP地址提供给Ansible作为变量并将其用作host:
参数值。例如,您从CLI运行Ansible,然后将其传递${aws_instance.example.public_ip}
给--extra-vars
参数。
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句