可以使用Ansible的EC2 dynamic inventory和EC2模块来解决这个问题。下面是一个示例的解决方法:
pip install ansible boto
ec2_inventory.ini
的文件,用于配置动态主机清单。文件内容如下:#!/bin/bash
# 引入必要的库
import boto
import boto.ec2
import json
# 创建EC2连接
conn = boto.ec2.connect_to_region('your_region', aws_access_key_id='your_access_key', aws_secret_access_key='your_secret_key')
# 获取所有运行中的实例
reservations = conn.get_all_reservations(filters={'instance-state-name':'running'})
instances = [i for r in reservations for i in r.instances]
# 创建主机清单
inventory = {}
inventory['_meta'] = {'hostvars': {}}
for i in instances:
inventory[i.id] = {'ansible_ssh_host': i.ip_address, 'ansible_ssh_user': 'your_ssh_user', 'ansible_ssh_private_key_file': 'your_ssh_private_key_file'}
inventory['_meta']['hostvars'][i.id] = {'ec2_tags': i.tags}
# 输出清单
print(json.dumps(inventory))
确保替换your_region
,your_access_key
,your_secret_key
,your_ssh_user
和your_ssh_private_key_file
为你自己的值。
ec2_command.yml
的Ansible playbook文件,用于在EC2实例上执行命令。文件内容如下:---
- name: Run command on EC2 instances
hosts: tag_Name_your_instance_name
gather_facts: false
tasks:
- name: Execute command
command: your_command
确保替换tag_Name_your_instance_name
为你想要在其上执行命令的EC2实例的标签名称,并将your_command
替换为你要执行的实际命令。
ansible-playbook -i ec2_inventory.ini ec2_command.yml
这将使用动态主机清单ec2_inventory.ini
和playbook文件ec2_command.yml
来在新创建的EC2实例上执行命令。
请注意,你需要在Ansible主机上配置好适当的AWS凭据,并且EC2实例需要具有与Ansible主机的SSH密钥对相匹配的密钥对。