Ansible EC2 Hosts 脚本缺少实例

Ansible EC2 Hosts 脚本缺少实例

由于某种原因,ansible 的 ec2 主机缺少实例。ec2-describe-instances 返回正确的实例,但 /etc/ansible/hosts 没有:

[root@or-manage ec2-user]# ec2-describe-instances | grep seed
TAG     instance        i-ff0b2f36      Name    cass-uat-seed
[root@or-manage ec2-user]# /etc/ansible/hosts | grep seed
[root@or-manage ec2-user]#

您可以看到 ec2-describe-instances 具有我正在寻找的标签的实例,但是 ansible hosts 没有。

为什么 /etc/ansible/hosts 中没有该实例?


注意:起初,我以为它/etc/ansible/hosts使用了错误的区域,但我打开了 boto 调试,它正确的区域:

send: 'POST / HTTP/1.1\r\nAccept-Encoding: identity\r\nContent-Length: 221\r\nContent-Type: application/x-www-form-urlencoded; charset=UTF-8\r\nHost: ec2.us-west-2.amazonaws.com


更新 1:

我注意到,没有公网 IP 的实例不会出现在 /etc/ansible/hosts 列表中。这是为什么呢?

答案1

我必须调整以下旋钮(在/etc/ansible/ec2.ini):

# This is the normal destination variable to use. If you are running Ansible
# from outside EC2, then 'public_dns_name' makes the most sense. If you are
# running Ansible from within EC2, then perhaps you want to use the internal
# address, and should set this to 'private_dns_name'. The key of an EC2 tag
# may optionally be used; however the boto instance variables hold precedence
# in the event of a collision.
destination_variable = private_dns_name

# For server inside a VPC, using DNS names may not make sense. When an instance
# has 'subnet_id' set, this variable is used. If the subnet is public, setting
# this to 'ip_address' will return the public IP address. For instances in a
# private subnet, this should be set to 'private_ip_address', and Ansible must
# be run from within EC2. The key of an EC2 tag may optionally be used; however
# the boto instance variables hold precedence in the event of a collision.
vpc_destination_variable = private_ip_address

相关内容