mirror of
https://github.com/ansible-collections/community.general.git
synced 2025-04-26 20:31:27 -07:00
ec2_instance.py: Add CpuOptions to EC2 (#43799)
* ec2_instance.py: Add CpuOptions to EC2 * ec2_instance_facts.py: Add CpuOptions to EC2 facts * ec2_instance.py: LooseVersion and pylint indentation * Implement nested cpu_options dict * Fix botocore required version * ec2_instance: Split integration tests to add executions with old botocore versions * Ensure runme.sh is executable
This commit is contained in:
parent
401c45384e
commit
3921f34253
16 changed files with 197 additions and 7 deletions
|
@ -141,6 +141,23 @@ options:
|
|||
- For T2 series instances, choose whether to allow increased charges to buy CPU credits if the default pool is depleted.
|
||||
- Choose I(unlimited) to enable buying additional CPU credits.
|
||||
choices: [unlimited, standard]
|
||||
cpu_options:
|
||||
description:
|
||||
- Reduce the number of vCPU exposed to the instance.
|
||||
- Those parameters can only be set at instance launch. The two suboptions threads_per_core and core_count are mandatory.
|
||||
- See U(https://docs.aws.amazon.com/AWSEC2/latest/UserGuide/instance-optimize-cpu.html) for combinations available.
|
||||
- Requires botocore >= 1.10.16
|
||||
version_added: 2.7
|
||||
suboptions:
|
||||
threads_per_core:
|
||||
description:
|
||||
- Select the number of threads per core to enable. Disable or Enable Intel HT
|
||||
choices: [1, 2]
|
||||
required: true
|
||||
core_count:
|
||||
description:
|
||||
- Set the number of core to enable.
|
||||
required: true
|
||||
detailed_monitoring:
|
||||
description:
|
||||
- Whether to allow detailed cloudwatch metrics to be collected, enabling more detailed alerting.
|
||||
|
@ -901,6 +918,30 @@ def warn_if_public_ip_assignment_changed(instance):
|
|||
assign_public_ip, instance['InstanceId']))
|
||||
|
||||
|
||||
def warn_if_cpu_options_changed(instance):
|
||||
# This is a non-modifiable attribute.
|
||||
cpu_options = module.params.get('cpu_options')
|
||||
if cpu_options is None:
|
||||
return
|
||||
|
||||
# Check that the CpuOptions set are the same and warn if not
|
||||
core_count_curr = instance['CpuOptions'].get('CoreCount')
|
||||
core_count = cpu_options.get('core_count')
|
||||
threads_per_core_curr = instance['CpuOptions'].get('ThreadsPerCore')
|
||||
threads_per_core = cpu_options.get('threads_per_core')
|
||||
if core_count_curr != core_count:
|
||||
module.warn(
|
||||
"Unable to modify core_count from {0} to {1}. "
|
||||
"Assigning a number of core is determinted during instance creation".format(
|
||||
core_count_curr, core_count))
|
||||
|
||||
if threads_per_core_curr != threads_per_core:
|
||||
module.warn(
|
||||
"Unable to modify threads_per_core from {0} to {1}. "
|
||||
"Assigning a number of threads per core is determined during instance creation.".format(
|
||||
threads_per_core_curr, threads_per_core))
|
||||
|
||||
|
||||
def discover_security_groups(group, groups, parent_vpc_id=None, subnet_id=None, ec2=None):
|
||||
if ec2 is None:
|
||||
ec2 = module.client('ec2')
|
||||
|
@ -1019,6 +1060,10 @@ def build_top_level_options(params):
|
|||
spec['InstanceInitiatedShutdownBehavior'] = params.get('instance_initiated_shutdown_behavior')
|
||||
if params.get('termination_protection') is not None:
|
||||
spec['DisableApiTermination'] = params.get('termination_protection')
|
||||
if params.get('cpu_options') is not None:
|
||||
spec['CpuOptions'] = {}
|
||||
spec['CpuOptions']['ThreadsPerCore'] = params.get('cpu_options').get('threads_per_core')
|
||||
spec['CpuOptions']['CoreCount'] = params.get('cpu_options').get('core_count')
|
||||
return spec
|
||||
|
||||
|
||||
|
@ -1445,6 +1490,10 @@ def main():
|
|||
launch_template=dict(type='dict'),
|
||||
key_name=dict(type='str'),
|
||||
cpu_credit_specification=dict(type='str', choices=['standard', 'unlimited']),
|
||||
cpu_options=dict(type='dict', options=dict(
|
||||
core_count=dict(type='int', required=True),
|
||||
threads_per_core=dict(type='int', choices=[1, 2], required=True)
|
||||
)),
|
||||
tenancy=dict(type='str', choices=['dedicated', 'default']),
|
||||
instance_initiated_shutdown_behavior=dict(type='str', choices=['stop', 'terminate']),
|
||||
termination_protection=dict(type='bool'),
|
||||
|
@ -1515,12 +1564,16 @@ def main():
|
|||
|
||||
module.params['filters'] = filters
|
||||
|
||||
if module.params.get('cpu_options') and not module.botocore_at_least('1.10.16'):
|
||||
module.fail_json(msg="cpu_options is only supported with botocore >= 1.10.16")
|
||||
|
||||
existing_matches = find_instances(ec2, filters=module.params.get('filters'))
|
||||
changed = False
|
||||
|
||||
if state not in ('terminated', 'absent') and existing_matches:
|
||||
for match in existing_matches:
|
||||
warn_if_public_ip_assignment_changed(match)
|
||||
warn_if_cpu_options_changed(match)
|
||||
changed |= manage_tags(match, (module.params.get('tags') or {}), module.params.get('purge_tags', False), ec2)
|
||||
|
||||
if state in ('present', 'running', 'started'):
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue