NetworkLoadBalancedTaskImageProps
- class aws_cdk.aws_ecs_patterns.NetworkLoadBalancedTaskImageProps(*, image, container_name=None, container_ports=None, docker_labels=None, enable_logging=None, environment=None, execution_role=None, family=None, log_driver=None, secrets=None, task_role=None)
Bases:
object
Options for configuring a new container.
- Parameters:
image (
ContainerImage
) – The image used to start a container. Image or taskDefinition must be specified, but not both. Default: - nonecontainer_name (
Optional
[str
]) – The container name value to be specified in the task definition. Default: - nonecontainer_ports (
Optional
[Sequence
[Union
[int
,float
]]]) – A list of port numbers on the container that is bound to the user-specified or automatically assigned host port. If you are using containers in a task with the awsvpc or host network mode, exposed ports should be specified using containerPort. If you are using containers in a task with the bridge network mode and you specify a container port and not a host port, your container automatically receives a host port in the ephemeral port range. Port mappings that are automatically assigned in this way do not count toward the 100 reserved ports limit of a container instance. For more information, see hostPort. Default: - [80]docker_labels (
Optional
[Mapping
[str
,str
]]) – A key/value map of labels to add to the container. Default: - No labels.enable_logging (
Optional
[bool
]) – Flag to indicate whether to enable logging. Default: trueenvironment (
Optional
[Mapping
[str
,str
]]) – The environment variables to pass to the container. Default: - No environment variables.execution_role (
Optional
[IRole
]) – The name of the task execution IAM role that grants the Amazon ECS container agent permission to call AWS APIs on your behalf. Default: - No valuefamily (
Optional
[str
]) – The name of a family that this task definition is registered to. A family groups multiple versions of a task definition. Default: - Automatically generated name.log_driver (
Optional
[LogDriver
]) – The log driver to use. Default: - AwsLogDriver if enableLogging is truesecrets (
Optional
[Mapping
[str
,Secret
]]) – The secrets to expose to the container as an environment variable. Default: - No secret environment variables.task_role (
Optional
[IRole
]) – The name of the task IAM role that grants containers in the task permission to call AWS APIs on your behalf. Default: - A task role is automatically created for you.
- ExampleMetadata:
infused
Example:
# Two network load balancers, each with their own listener and target group. # cluster: ecs.Cluster load_balanced_ec2_service = ecs_patterns.NetworkMultipleTargetGroupsEc2Service(self, "Service", cluster=cluster, memory_limit_mi_b=256, task_image_options=ecsPatterns.NetworkLoadBalancedTaskImageProps( image=ecs.ContainerImage.from_registry("amazon/amazon-ecs-sample") ), load_balancers=[ecsPatterns.NetworkLoadBalancerProps( name="lb1", listeners=[ecsPatterns.NetworkListenerProps( name="listener1" ) ] ), ecsPatterns.NetworkLoadBalancerProps( name="lb2", listeners=[ecsPatterns.NetworkListenerProps( name="listener2" ) ] ) ], target_groups=[ecsPatterns.NetworkTargetProps( container_port=80, listener="listener1" ), ecsPatterns.NetworkTargetProps( container_port=90, listener="listener2" ) ] )
Attributes
- container_name
The container name value to be specified in the task definition.
- Default:
none
- container_ports
A list of port numbers on the container that is bound to the user-specified or automatically assigned host port.
If you are using containers in a task with the awsvpc or host network mode, exposed ports should be specified using containerPort. If you are using containers in a task with the bridge network mode and you specify a container port and not a host port, your container automatically receives a host port in the ephemeral port range.
Port mappings that are automatically assigned in this way do not count toward the 100 reserved ports limit of a container instance.
For more information, see hostPort.
- Default:
[80]
- docker_labels
A key/value map of labels to add to the container.
- Default:
No labels.
- enable_logging
Flag to indicate whether to enable logging.
- Default:
true
- environment
The environment variables to pass to the container.
- Default:
No environment variables.
- execution_role
The name of the task execution IAM role that grants the Amazon ECS container agent permission to call AWS APIs on your behalf.
- Default:
No value
- family
The name of a family that this task definition is registered to.
A family groups multiple versions of a task definition.
- Default:
Automatically generated name.
- image
The image used to start a container.
Image or taskDefinition must be specified, but not both.
- Default:
none
- log_driver
The log driver to use.
- Default:
AwsLogDriver if enableLogging is true
- secrets
The secrets to expose to the container as an environment variable.
- Default:
No secret environment variables.
- task_role
The name of the task IAM role that grants containers in the task permission to call AWS APIs on your behalf.
- Default:
A task role is automatically created for you.