Support for EC2 dedicated tenancy option
This commit is contained in:
parent
d30881a461
commit
23668e41b0
1 changed files with 23 additions and 0 deletions
|
@ -61,6 +61,12 @@ options:
|
||||||
required: true
|
required: true
|
||||||
default: null
|
default: null
|
||||||
aliases: []
|
aliases: []
|
||||||
|
tenancy:
|
||||||
|
description:
|
||||||
|
- An instance with a tenancy of "dedicated" runs on single-tenant hardware and can only be launched into a VPC. Valid values are:"default" or "dedicated". NOTE: To use dedicated tenancy you MUST specify a vpc_subnet_id as well. Dedicated tenancy is not available for EC2 "micro" instances.
|
||||||
|
required: false
|
||||||
|
default: default
|
||||||
|
aliases: []
|
||||||
spot_price:
|
spot_price:
|
||||||
version_added: "1.5"
|
version_added: "1.5"
|
||||||
description:
|
description:
|
||||||
|
@ -299,6 +305,18 @@ EXAMPLES = '''
|
||||||
vpc_subnet_id: subnet-29e63245
|
vpc_subnet_id: subnet-29e63245
|
||||||
assign_public_ip: yes
|
assign_public_ip: yes
|
||||||
|
|
||||||
|
# Dedicated tenancy example
|
||||||
|
- local_action:
|
||||||
|
module: ec2
|
||||||
|
assign_public_ip: yes
|
||||||
|
group_id: sg-1dc53f72
|
||||||
|
key_name: mykey
|
||||||
|
image: ami-6e649707
|
||||||
|
instance_type: m1.small
|
||||||
|
tenancy: dedicated
|
||||||
|
vpc_subnet_id: subnet-29e63245
|
||||||
|
wait: yes
|
||||||
|
|
||||||
# Spot instance example
|
# Spot instance example
|
||||||
- ec2:
|
- ec2:
|
||||||
spot_price: 0.24
|
spot_price: 0.24
|
||||||
|
@ -725,6 +743,7 @@ def create_instances(module, ec2, override_count=None):
|
||||||
group_id = module.params.get('group_id')
|
group_id = module.params.get('group_id')
|
||||||
zone = module.params.get('zone')
|
zone = module.params.get('zone')
|
||||||
instance_type = module.params.get('instance_type')
|
instance_type = module.params.get('instance_type')
|
||||||
|
tenancy = module.params.get('tenancy')
|
||||||
spot_price = module.params.get('spot_price')
|
spot_price = module.params.get('spot_price')
|
||||||
image = module.params.get('image')
|
image = module.params.get('image')
|
||||||
if override_count:
|
if override_count:
|
||||||
|
@ -809,6 +828,9 @@ def create_instances(module, ec2, override_count=None):
|
||||||
if ebs_optimized:
|
if ebs_optimized:
|
||||||
params['ebs_optimized'] = ebs_optimized
|
params['ebs_optimized'] = ebs_optimized
|
||||||
|
|
||||||
|
if tenancy:
|
||||||
|
params['tenancy'] = tenancy
|
||||||
|
|
||||||
if boto_supports_profile_name_arg(ec2):
|
if boto_supports_profile_name_arg(ec2):
|
||||||
params['instance_profile_name'] = instance_profile_name
|
params['instance_profile_name'] = instance_profile_name
|
||||||
else:
|
else:
|
||||||
|
@ -1150,6 +1172,7 @@ def main():
|
||||||
count_tag = dict(),
|
count_tag = dict(),
|
||||||
volumes = dict(type='list'),
|
volumes = dict(type='list'),
|
||||||
ebs_optimized = dict(type='bool', default=False),
|
ebs_optimized = dict(type='bool', default=False),
|
||||||
|
tenancy = dict(default='default'),
|
||||||
)
|
)
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue