InitConfig
- class aws_cdk.aws_ec2.InitConfig(elements)
Bases:
object
A collection of configuration elements.
- ExampleMetadata:
infused
Example:
# vpc: ec2.Vpc # instance_type: ec2.InstanceType # machine_image: ec2.IMachineImage ec2.Instance(self, "Instance", vpc=vpc, instance_type=instance_type, machine_image=machine_image, # Showing the most complex setup, if you have simpler requirements # you can use `CloudFormationInit.fromElements()`. init=ec2.CloudFormationInit.from_config_sets( config_sets={ # Applies the configs below in this order "default": ["yumPreinstall", "config"] }, configs={ "yum_preinstall": ec2.InitConfig([ # Install an Amazon Linux package using yum ec2.InitPackage.yum("git") ]), "config": ec2.InitConfig([ # Create a JSON file from tokens (can also create other files) ec2.InitFile.from_object("/etc/stack.json", { "stack_id": Stack.of(self).stack_id, "stack_name": Stack.of(self).stack_name, "region": Stack.of(self).region }), # Create a group and user ec2.InitGroup.from_name("my-group"), ec2.InitUser.from_name("my-user"), # Install an RPM from the internet ec2.InitPackage.rpm("http://mirrors.ukfast.co.uk/sites/dl.fedoraproject.org/pub/epel/8/Everything/x86_64/Packages/r/rubygem-git-1.5.0-2.el8.noarch.rpm") ]) } ), init_options=ec2.ApplyCloudFormationInitOptions( # Optional, which configsets to activate (['default'] by default) config_sets=["default"], # Optional, how long the installation is expected to take (5 minutes by default) timeout=Duration.minutes(30), # Optional, whether to include the --url argument when running cfn-init and cfn-signal commands (false by default) include_url=True, # Optional, whether to include the --role argument when running cfn-init and cfn-signal commands (false by default) include_role=True ) )
- Parameters:
elements (
Sequence
[InitElement
])
Methods
- add(*elements)
Add one or more elements to the config.
- Parameters:
elements (
InitElement
)- Return type:
None
- is_empty()
Whether this configset has elements or not.
- Return type:
bool