@Generated(value="software.amazon.awssdk:codegen") public final class ContainerProperties extends Object implements SdkPojo, Serializable, ToCopyableBuilder<ContainerProperties.Builder,ContainerProperties>
Container properties are used for Amazon ECS based job definitions. These properties to describe the container that's launched as part of a job.
| Modifier and Type | Class and Description |
|---|---|
static interface |
ContainerProperties.Builder |
| Modifier and Type | Method and Description |
|---|---|
static ContainerProperties.Builder |
builder() |
List<String> |
command()
The command that's passed to the container.
|
List<KeyValuePair> |
environment()
The environment variables to pass to a container.
|
EphemeralStorage |
ephemeralStorage()
The amount of ephemeral storage to allocate for the task.
|
boolean |
equals(Object obj) |
boolean |
equalsBySdkFields(Object obj) |
String |
executionRoleArn()
The Amazon Resource Name (ARN) of the execution role that Batch can assume.
|
FargatePlatformConfiguration |
fargatePlatformConfiguration()
The platform configuration for jobs that are running on Fargate resources.
|
<T> Optional<T> |
getValueForField(String fieldName,
Class<T> clazz) |
boolean |
hasCommand()
For responses, this returns true if the service returned a value for the Command property.
|
boolean |
hasEnvironment()
For responses, this returns true if the service returned a value for the Environment property.
|
int |
hashCode() |
boolean |
hasMountPoints()
For responses, this returns true if the service returned a value for the MountPoints property.
|
boolean |
hasResourceRequirements()
For responses, this returns true if the service returned a value for the ResourceRequirements property.
|
boolean |
hasSecrets()
For responses, this returns true if the service returned a value for the Secrets property.
|
boolean |
hasUlimits()
For responses, this returns true if the service returned a value for the Ulimits property.
|
boolean |
hasVolumes()
For responses, this returns true if the service returned a value for the Volumes property.
|
String |
image()
The image used to start a container.
|
String |
instanceType()
The instance type to use for a multi-node parallel job.
|
String |
jobRoleArn()
The Amazon Resource Name (ARN) of the IAM role that the container can assume for Amazon Web Services permissions.
|
LinuxParameters |
linuxParameters()
Linux-specific modifications that are applied to the container, such as details for device mappings.
|
LogConfiguration |
logConfiguration()
The log configuration specification for the container.
|
Integer |
memory()
Deprecated.
This field is deprecated, use resourceRequirements instead.
|
List<MountPoint> |
mountPoints()
The mount points for data volumes in your container.
|
NetworkConfiguration |
networkConfiguration()
The network configuration for jobs that are running on Fargate resources.
|
Boolean |
privileged()
When this parameter is true, the container is given elevated permissions on the host container instance (similar
to the
root user). |
Boolean |
readonlyRootFilesystem()
When this parameter is true, the container is given read-only access to its root file system.
|
List<ResourceRequirement> |
resourceRequirements()
The type and amount of resources to assign to a container.
|
RuntimePlatform |
runtimePlatform()
Returns the value of the RuntimePlatform property for this object.
|
List<SdkField<?>> |
sdkFields() |
List<Secret> |
secrets()
The secrets for the container.
|
static Class<? extends ContainerProperties.Builder> |
serializableBuilderClass() |
ContainerProperties.Builder |
toBuilder() |
String |
toString()
Returns a string representation of this object.
|
List<Ulimit> |
ulimits()
A list of
ulimits to set in the container. |
String |
user()
The user name to use inside the container.
|
Integer |
vcpus()
Deprecated.
This field is deprecated, use resourceRequirements instead.
|
List<Volume> |
volumes()
A list of data volumes used in a job.
|
clone, finalize, getClass, notify, notifyAll, wait, wait, waitcopypublic final String image()
The image used to start a container. This string is passed directly to the Docker daemon. Images in the Docker
Hub registry are available by default. Other repositories are specified with
repository-url/image:tag . It can be 255 characters long. It can contain
uppercase and lowercase letters, numbers, hyphens (-), underscores (_), colons (:), periods (.), forward slashes
(/), and number signs (#). This parameter maps to Image in the Create a container section of the Docker Remote API and the IMAGE parameter of docker run.
Docker image architecture must match the processor architecture of the compute resources that they're scheduled on. For example, ARM-based Docker images can only run on ARM-based compute resources.
Images in Amazon ECR Public repositories use the full registry/repository[:tag] or
registry/repository[@digest] naming conventions. For example,
public.ecr.aws/registry_alias/my-web-app:latest .
Images in Amazon ECR repositories use the full registry and repository URI (for example,
123456789012.dkr.ecr.<region-name>.amazonaws.com/<repository-name>).
Images in official repositories on Docker Hub use a single name (for example, ubuntu or
mongo).
Images in other repositories on Docker Hub are qualified with an organization name (for example,
amazon/amazon-ecs-agent).
Images in other online repositories are qualified further by a domain name (for example,
quay.io/assemblyline/ubuntu).
repository-url/image:tag . It can be 255 characters long. It can
contain uppercase and lowercase letters, numbers, hyphens (-), underscores (_), colons (:), periods (.),
forward slashes (/), and number signs (#). This parameter maps to Image in the Create a container section of the
Docker Remote API and the IMAGE
parameter of docker run. Docker image architecture must match the processor architecture of the compute resources that they're scheduled on. For example, ARM-based Docker images can only run on ARM-based compute resources.
Images in Amazon ECR Public repositories use the full registry/repository[:tag] or
registry/repository[@digest] naming conventions. For example,
public.ecr.aws/registry_alias/my-web-app:latest .
Images in Amazon ECR repositories use the full registry and repository URI (for example,
123456789012.dkr.ecr.<region-name>.amazonaws.com/<repository-name>).
Images in official repositories on Docker Hub use a single name (for example, ubuntu or
mongo).
Images in other repositories on Docker Hub are qualified with an organization name (for example,
amazon/amazon-ecs-agent).
Images in other online repositories are qualified further by a domain name (for example,
quay.io/assemblyline/ubuntu).
@Deprecated public final Integer vcpus()
This parameter is deprecated, use resourceRequirements to specify the vCPU requirements for the job
definition. It's not supported for jobs running on Fargate resources. For jobs running on EC2 resources, it
specifies the number of vCPUs reserved for the job.
Each vCPU is equivalent to 1,024 CPU shares. This parameter maps to CpuShares in the Create a container section of the Docker Remote API and the --cpu-shares option
to docker run. The number of vCPUs must be specified
but can be specified in several places. You must specify it at least once for each node.
resourceRequirements to specify the vCPU requirements for
the job definition. It's not supported for jobs running on Fargate resources. For jobs running on EC2
resources, it specifies the number of vCPUs reserved for the job.
Each vCPU is equivalent to 1,024 CPU shares. This parameter maps to CpuShares in the Create a container section of the
Docker Remote API and the
--cpu-shares option to docker
run. The number of vCPUs must be specified but can be specified in several places. You must specify
it at least once for each node.
@Deprecated public final Integer memory()
This parameter is deprecated, use resourceRequirements to specify the memory requirements for the
job definition. It's not supported for jobs running on Fargate resources. For jobs that run on EC2 resources, it
specifies the memory hard limit (in MiB) for a container. If your container attempts to exceed the specified
number, it's terminated. You must specify at least 4 MiB of memory for a job using this parameter. The memory
hard limit can be specified in several places. It must be specified for each node at least once.
resourceRequirements to specify the memory requirements
for the job definition. It's not supported for jobs running on Fargate resources. For jobs that run on
EC2 resources, it specifies the memory hard limit (in MiB) for a container. If your container attempts to
exceed the specified number, it's terminated. You must specify at least 4 MiB of memory for a job using
this parameter. The memory hard limit can be specified in several places. It must be specified for each
node at least once.public final boolean hasCommand()
isEmpty() method on the property). This is
useful because the SDK will never return a null collection or map, but you may need to differentiate between the
service returning nothing (or null) and the service returning an empty collection or map. For requests, this
returns true if a value for the property was specified in the request builder, and false if a value was not
specified.public final List<String> command()
The command that's passed to the container. This parameter maps to Cmd in the Create a container section of the Docker Remote API and the COMMAND parameter to
docker run. For more information, see https://docs.docker.com/engine/reference/builder/#cmd.
Attempts to modify the collection returned by this method will result in an UnsupportedOperationException.
This method will never return null. If you would like to know whether the service returned this field (so that
you can differentiate between null and empty), you can use the hasCommand() method.
Cmd in the Create a container section of the
Docker Remote API and the COMMAND
parameter to docker run. For more
information, see https://docs.docker.com/engine
/reference/builder/#cmd.public final String jobRoleArn()
The Amazon Resource Name (ARN) of the IAM role that the container can assume for Amazon Web Services permissions. For more information, see IAM roles for tasks in the Amazon Elastic Container Service Developer Guide.
public final String executionRoleArn()
The Amazon Resource Name (ARN) of the execution role that Batch can assume. For jobs that run on Fargate resources, you must provide an execution role. For more information, see Batch execution IAM role in the Batch User Guide.
public final boolean hasVolumes()
isEmpty() method on the property). This is
useful because the SDK will never return a null collection or map, but you may need to differentiate between the
service returning nothing (or null) and the service returning an empty collection or map. For requests, this
returns true if a value for the property was specified in the request builder, and false if a value was not
specified.public final List<Volume> volumes()
A list of data volumes used in a job.
Attempts to modify the collection returned by this method will result in an UnsupportedOperationException.
This method will never return null. If you would like to know whether the service returned this field (so that
you can differentiate between null and empty), you can use the hasVolumes() method.
public final boolean hasEnvironment()
isEmpty() method on the property).
This is useful because the SDK will never return a null collection or map, but you may need to differentiate
between the service returning nothing (or null) and the service returning an empty collection or map. For
requests, this returns true if a value for the property was specified in the request builder, and false if a
value was not specified.public final List<KeyValuePair> environment()
The environment variables to pass to a container. This parameter maps to Env in the Create a container section of the Docker Remote API and the --env option to docker run.
We don't recommend using plaintext environment variables for sensitive information, such as credential data.
Environment variables cannot start with "AWS_BATCH". This naming convention is reserved for
variables that Batch sets.
Attempts to modify the collection returned by this method will result in an UnsupportedOperationException.
This method will never return null. If you would like to know whether the service returned this field (so that
you can differentiate between null and empty), you can use the hasEnvironment() method.
Env in the Create a container section of the
Docker Remote API and the --env
option to docker run. We don't recommend using plaintext environment variables for sensitive information, such as credential data.
Environment variables cannot start with "AWS_BATCH". This naming convention is reserved for
variables that Batch sets.
public final boolean hasMountPoints()
isEmpty() method on the property).
This is useful because the SDK will never return a null collection or map, but you may need to differentiate
between the service returning nothing (or null) and the service returning an empty collection or map. For
requests, this returns true if a value for the property was specified in the request builder, and false if a
value was not specified.public final List<MountPoint> mountPoints()
The mount points for data volumes in your container. This parameter maps to Volumes in the Create a container section of the Docker Remote API and the --volume option to docker run.
Attempts to modify the collection returned by this method will result in an UnsupportedOperationException.
This method will never return null. If you would like to know whether the service returned this field (so that
you can differentiate between null and empty), you can use the hasMountPoints() method.
Volumes in the
Create a container section of
the Docker Remote API and the
--volume option to docker run.public final Boolean readonlyRootFilesystem()
When this parameter is true, the container is given read-only access to its root file system. This parameter maps
to ReadonlyRootfs in the Create a container section of the Docker Remote API and the --read-only option to
docker run.
ReadonlyRootfs in the Create a container section of the
Docker Remote API and the
--read-only option to docker run.public final Boolean privileged()
When this parameter is true, the container is given elevated permissions on the host container instance (similar
to the root user). This parameter maps to Privileged in the Create a container section of the Docker Remote API and the --privileged option
to docker run. The default value is false.
This parameter isn't applicable to jobs that are running on Fargate resources and shouldn't be provided, or specified as false.
root user). This parameter maps to Privileged in the Create a container section of the
Docker Remote API and the
--privileged option to docker
run. The default value is false. This parameter isn't applicable to jobs that are running on Fargate resources and shouldn't be provided, or specified as false.
public final boolean hasUlimits()
isEmpty() method on the property). This is
useful because the SDK will never return a null collection or map, but you may need to differentiate between the
service returning nothing (or null) and the service returning an empty collection or map. For requests, this
returns true if a value for the property was specified in the request builder, and false if a value was not
specified.public final List<Ulimit> ulimits()
A list of ulimits to set in the container. This parameter maps to Ulimits in the Create a container section of the Docker Remote API and the --ulimit option to docker run.
This parameter isn't applicable to jobs that are running on Fargate resources and shouldn't be provided.
Attempts to modify the collection returned by this method will result in an UnsupportedOperationException.
This method will never return null. If you would like to know whether the service returned this field (so that
you can differentiate between null and empty), you can use the hasUlimits() method.
ulimits to set in the container. This parameter maps to Ulimits in
the Create a container section
of the Docker Remote API and the
--ulimit option to docker
run. This parameter isn't applicable to jobs that are running on Fargate resources and shouldn't be provided.
public final String user()
The user name to use inside the container. This parameter maps to User in the Create a container section of the Docker Remote API and the --user option to docker run.
User in the Create a container section of the
Docker Remote API and the --user
option to docker run.public final String instanceType()
The instance type to use for a multi-node parallel job. All node groups in a multi-node parallel job must use the same instance type.
This parameter isn't applicable to single-node container jobs or jobs that run on Fargate resources, and shouldn't be provided.
This parameter isn't applicable to single-node container jobs or jobs that run on Fargate resources, and shouldn't be provided.
public final boolean hasResourceRequirements()
isEmpty() method on the property).
This is useful because the SDK will never return a null collection or map, but you may need to differentiate
between the service returning nothing (or null) and the service returning an empty collection or map. For
requests, this returns true if a value for the property was specified in the request builder, and false if a
value was not specified.public final List<ResourceRequirement> resourceRequirements()
The type and amount of resources to assign to a container. The supported resources include GPU,
MEMORY, and VCPU.
Attempts to modify the collection returned by this method will result in an UnsupportedOperationException.
This method will never return null. If you would like to know whether the service returned this field (so that
you can differentiate between null and empty), you can use the hasResourceRequirements() method.
GPU, MEMORY, and VCPU.public final LinuxParameters linuxParameters()
Linux-specific modifications that are applied to the container, such as details for device mappings.
public final LogConfiguration logConfiguration()
The log configuration specification for the container.
This parameter maps to LogConfig in the Create a container section of the Docker Remote API and the --log-driver option
to docker run. By default, containers use the same
logging driver that the Docker daemon uses. However the container might use a different logging driver than the
Docker daemon by specifying a log driver with this parameter in the container definition. To use a different
logging driver for a container, the log system must be configured properly on the container instance (or on a
different log server for remote logging options). For more information on the options for different supported log
drivers, see Configure logging drivers in
the Docker documentation.
Batch currently supports a subset of the logging drivers available to the Docker daemon (shown in the LogConfiguration data type).
This parameter requires version 1.18 of the Docker Remote API or greater on your container instance. To check the
Docker Remote API version on your container instance, log in to your container instance and run the following
command: sudo docker version | grep "Server API version"
The Amazon ECS container agent running on a container instance must register the logging drivers available on
that instance with the ECS_AVAILABLE_LOGGING_DRIVERS environment variable before containers placed
on that instance can use these log configuration options. For more information, see Amazon ECS container
agent configuration in the Amazon Elastic Container Service Developer Guide.
This parameter maps to LogConfig in the Create a container section of the
Docker Remote API and the
--log-driver option to docker
run. By default, containers use the same logging driver that the Docker daemon uses. However the
container might use a different logging driver than the Docker daemon by specifying a log driver with
this parameter in the container definition. To use a different logging driver for a container, the log
system must be configured properly on the container instance (or on a different log server for remote
logging options). For more information on the options for different supported log drivers, see Configure logging drivers in the Docker
documentation.
Batch currently supports a subset of the logging drivers available to the Docker daemon (shown in the LogConfiguration data type).
This parameter requires version 1.18 of the Docker Remote API or greater on your container instance. To
check the Docker Remote API version on your container instance, log in to your container instance and run
the following command: sudo docker version | grep "Server API version"
The Amazon ECS container agent running on a container instance must register the logging drivers
available on that instance with the ECS_AVAILABLE_LOGGING_DRIVERS environment variable
before containers placed on that instance can use these log configuration options. For more information,
see Amazon
ECS container agent configuration in the Amazon Elastic Container Service Developer Guide.
public final boolean hasSecrets()
isEmpty() method on the property). This is
useful because the SDK will never return a null collection or map, but you may need to differentiate between the
service returning nothing (or null) and the service returning an empty collection or map. For requests, this
returns true if a value for the property was specified in the request builder, and false if a value was not
specified.public final List<Secret> secrets()
The secrets for the container. For more information, see Specifying sensitive data in the Batch User Guide.
Attempts to modify the collection returned by this method will result in an UnsupportedOperationException.
This method will never return null. If you would like to know whether the service returned this field (so that
you can differentiate between null and empty), you can use the hasSecrets() method.
public final NetworkConfiguration networkConfiguration()
The network configuration for jobs that are running on Fargate resources. Jobs that are running on EC2 resources must not specify this parameter.
public final FargatePlatformConfiguration fargatePlatformConfiguration()
The platform configuration for jobs that are running on Fargate resources. Jobs that are running on EC2 resources must not specify this parameter.
public final EphemeralStorage ephemeralStorage()
The amount of ephemeral storage to allocate for the task. This parameter is used to expand the total amount of ephemeral storage available, beyond the default amount, for tasks hosted on Fargate.
public final RuntimePlatform runtimePlatform()
public ContainerProperties.Builder toBuilder()
toBuilder in interface ToCopyableBuilder<ContainerProperties.Builder,ContainerProperties>public static ContainerProperties.Builder builder()
public static Class<? extends ContainerProperties.Builder> serializableBuilderClass()
public final boolean equalsBySdkFields(Object obj)
equalsBySdkFields in interface SdkPojopublic final String toString()
Copyright © 2023. All rights reserved.