Note
This action is only used by the Amazon ECS agent, and it is not intended for use outside of the agent.
Registers an EC2 instance into the specified cluster. This instance becomes available to place containers on.
See also: AWS API Documentation
See ‘aws help’ for descriptions of global parameters.
  register-container-instance
[--cluster <value>]
[--instance-identity-document <value>]
[--instance-identity-document-signature <value>]
[--total-resources <value>]
[--version-info <value>]
[--container-instance-arn <value>]
[--attributes <value>]
[--platform-devices <value>]
[--tags <value>]
[--cli-input-json | --cli-input-yaml]
[--generate-cli-skeleton <value>]
--cluster (string)
The short name or full Amazon Resource Name (ARN) of the cluster with which to register your container instance. If you do not specify a cluster, the default cluster is assumed.
--instance-identity-document (string)
The instance identity document for the EC2 instance to register. This document can be found by running the following command from the instance:
curl http://169.254.169.254/latest/dynamic/instance-identity/document/
--instance-identity-document-signature (string)
The instance identity document signature for the EC2 instance to register. This signature can be found by running the following command from the instance:
curl http://169.254.169.254/latest/dynamic/instance-identity/signature/
--total-resources (list)
The resources available on the instance.
(structure)
Describes the resources available for a container instance.
name -> (string)
The name of the resource, such as
CPU,MEMORY,PORTS,PORTS_UDP, or a user-defined resource.type -> (string)
The type of the resource, such as
INTEGER,DOUBLE,LONG, orSTRINGSET.doubleValue -> (double)
When the
doubleValuetype is set, the value of the resource must be a double precision floating-point type.longValue -> (long)
When the
longValuetype is set, the value of the resource must be an extended precision floating-point type.integerValue -> (integer)
When the
integerValuetype is set, the value of the resource must be an integer.stringSetValue -> (list)
When the
stringSetValuetype is set, the value of the resource must be a string type.(string)
Shorthand Syntax:
name=string,type=string,doubleValue=double,longValue=long,integerValue=integer,stringSetValue=string,string ...
JSON Syntax:
[
  {
    "name": "string",
    "type": "string",
    "doubleValue": double,
    "longValue": long,
    "integerValue": integer,
    "stringSetValue": ["string", ...]
  }
  ...
]
--version-info (structure)
The version information for the Amazon ECS container agent and Docker daemon running on the container instance.
agentVersion -> (string)
The version number of the Amazon ECS container agent.
agentHash -> (string)
The Git commit hash for the Amazon ECS container agent build on the amazon-ecs-agent GitHub repository.
dockerVersion -> (string)
The Docker version running on the container instance.
Shorthand Syntax:
agentVersion=string,agentHash=string,dockerVersion=string
JSON Syntax:
{
  "agentVersion": "string",
  "agentHash": "string",
  "dockerVersion": "string"
}
--container-instance-arn (string)
The ARN of the container instance (if it was previously registered).
--attributes (list)
The container instance attributes that this container instance supports.
(structure)
An attribute is a name-value pair associated with an Amazon ECS object. Attributes enable you to extend the Amazon ECS data model by adding custom metadata to your resources. For more information, see Attributes in the Amazon Elastic Container Service Developer Guide .
name -> (string)
The name of the attribute. The
namemust contain between 1 and 128 characters and name may contain letters (uppercase and lowercase), numbers, hyphens, underscores, forward slashes, back slashes, or periods.value -> (string)
The value of the attribute. The
valuemust contain between 1 and 128 characters and may contain letters (uppercase and lowercase), numbers, hyphens, underscores, periods, at signs (@), forward slashes, back slashes, colons, or spaces. The value cannot contain any leading or trailing whitespace.targetType -> (string)
The type of the target with which to attach the attribute. This parameter is required if you use the short form ID for a resource instead of the full ARN.
targetId -> (string)
The ID of the target. You can specify the short form ID for a resource or the full Amazon Resource Name (ARN).
Shorthand Syntax:
name=string,value=string,targetType=string,targetId=string ...
JSON Syntax:
[
  {
    "name": "string",
    "value": "string",
    "targetType": "container-instance",
    "targetId": "string"
  }
  ...
]
--platform-devices (list)
The devices that are available on the container instance. The only supported device type is a GPU.
(structure)
The devices that are available on the container instance. The only supported device type is a GPU.
id -> (string)
The ID for the GPU(s) on the container instance. The available GPU IDs can also be obtained on the container instance in the
/var/lib/ecs/gpu/nvidia_gpu_info.jsonfile.type -> (string)
The type of device that is available on the container instance. The only supported value is
GPU.
Shorthand Syntax:
id=string,type=string ...
JSON Syntax:
[
  {
    "id": "string",
    "type": "GPU"
  }
  ...
]
--tags (list)
The metadata that you apply to the container instance to help you categorize and organize them. Each tag consists of a key and an optional value, both of which you define.
The following basic restrictions apply to tags:
Maximum number of tags per resource - 50
For each resource, each tag key must be unique, and each tag key can have only one value.
Maximum key length - 128 Unicode characters in UTF-8
Maximum value length - 256 Unicode characters in UTF-8
If your tagging schema is used across multiple services and resources, remember that other services may have restrictions on allowed characters. Generally allowed characters are: letters, numbers, and spaces representable in UTF-8, and the following characters: + - = . _ : / @.
Tag keys and values are case-sensitive.
Do not use
aws:,AWS:, or any upper or lowercase combination of such as a prefix for either keys or values as it is reserved for Amazon Web Services use. You cannot edit or delete tag keys or values with this prefix. Tags with this prefix do not count against your tags per resource limit.(structure)
The metadata that you apply to a resource to help you categorize and organize them. Each tag consists of a key and an optional value, both of which you define.
The following basic restrictions apply to tags:
Maximum number of tags per resource - 50
For each resource, each tag key must be unique, and each tag key can have only one value.
Maximum key length - 128 Unicode characters in UTF-8
Maximum value length - 256 Unicode characters in UTF-8
If your tagging schema is used across multiple services and resources, remember that other services may have restrictions on allowed characters. Generally allowed characters are: letters, numbers, and spaces representable in UTF-8, and the following characters: + - = . _ : / @.
Tag keys and values are case-sensitive.
Do not use
aws:,AWS:, or any upper or lowercase combination of such as a prefix for either keys or values as it is reserved for Amazon Web Services use. You cannot edit or delete tag keys or values with this prefix. Tags with this prefix do not count against your tags per resource limit.key -> (string)
One part of a key-value pair that make up a tag. A
keyis a general label that acts like a category for more specific tag values.value -> (string)
The optional part of a key-value pair that make up a tag. A
valueacts as a descriptor within a tag category (key).
Shorthand Syntax:
key=string,value=string ...
JSON Syntax:
[
  {
    "key": "string",
    "value": "string"
  }
  ...
]
--cli-input-json | --cli-input-yaml (string)
Reads arguments from the JSON string provided. The JSON string follows the format provided by --generate-cli-skeleton. If other arguments are provided on the command line, those values will override the JSON-provided values. It is not possible to pass arbitrary binary values using a JSON-provided value as the string will be taken literally. This may not be specified along with --cli-input-yaml.
--generate-cli-skeleton (string)
Prints a JSON skeleton to standard output without sending an API request. If provided with no value or the value input, prints a sample input JSON that can be used as an argument for --cli-input-json. Similarly, if provided yaml-input it will print a sample input YAML that can be used with --cli-input-yaml. If provided with the value output, it validates the command inputs and returns a sample output JSON for that command.
See ‘aws help’ for descriptions of global parameters.
containerInstance -> (structure)
The container instance that was registered.
containerInstanceArn -> (string)
The Amazon Resource Name (ARN) of the container instance. The ARN contains the
arn:aws:ecsnamespace, followed by the Region of the container instance, the Amazon Web Services account ID of the container instance owner, thecontainer-instancenamespace, and then the container instance ID. For example,arn:aws:ecs:region:aws_account_id:container-instance/container_instance_ID.ec2InstanceId -> (string)
The ID of the container instance. For Amazon EC2 instances, this value is the Amazon EC2 instance ID. For external instances, this value is the Amazon Web Services Systems Manager managed instance ID.
capacityProviderName -> (string)
The capacity provider associated with the container instance.
version -> (long)
The version counter for the container instance. Every time a container instance experiences a change that triggers a CloudWatch event, the version counter is incremented. If you are replicating your Amazon ECS container instance state with CloudWatch Events, you can compare the version of a container instance reported by the Amazon ECS APIs with the version reported in CloudWatch Events for the container instance (inside the
detailobject) to verify that the version in your event stream is current.versionInfo -> (structure)
The version information for the Amazon ECS container agent and Docker daemon running on the container instance.
agentVersion -> (string)
The version number of the Amazon ECS container agent.
agentHash -> (string)
The Git commit hash for the Amazon ECS container agent build on the amazon-ecs-agent GitHub repository.
dockerVersion -> (string)
The Docker version running on the container instance.
remainingResources -> (list)
For CPU and memory resource types, this parameter describes the remaining CPU and memory that has not already been allocated to tasks and is therefore available for new tasks. For port resource types, this parameter describes the ports that were reserved by the Amazon ECS container agent (at instance registration time) and any task containers that have reserved port mappings on the host (with the
hostorbridgenetwork mode). Any port that is not specified here is available for new tasks.(structure)
Describes the resources available for a container instance.
name -> (string)
The name of the resource, such as
CPU,MEMORY,PORTS,PORTS_UDP, or a user-defined resource.type -> (string)
The type of the resource, such as
INTEGER,DOUBLE,LONG, orSTRINGSET.doubleValue -> (double)
When the
doubleValuetype is set, the value of the resource must be a double precision floating-point type.longValue -> (long)
When the
longValuetype is set, the value of the resource must be an extended precision floating-point type.integerValue -> (integer)
When the
integerValuetype is set, the value of the resource must be an integer.stringSetValue -> (list)
When the
stringSetValuetype is set, the value of the resource must be a string type.(string)
registeredResources -> (list)
For CPU and memory resource types, this parameter describes the amount of each resource that was available on the container instance when the container agent registered it with Amazon ECS. This value represents the total amount of CPU and memory that can be allocated on this container instance to tasks. For port resource types, this parameter describes the ports that were reserved by the Amazon ECS container agent when it registered the container instance with Amazon ECS.
(structure)
Describes the resources available for a container instance.
name -> (string)
The name of the resource, such as
CPU,MEMORY,PORTS,PORTS_UDP, or a user-defined resource.type -> (string)
The type of the resource, such as
INTEGER,DOUBLE,LONG, orSTRINGSET.doubleValue -> (double)
When the
doubleValuetype is set, the value of the resource must be a double precision floating-point type.longValue -> (long)
When the
longValuetype is set, the value of the resource must be an extended precision floating-point type.integerValue -> (integer)
When the
integerValuetype is set, the value of the resource must be an integer.stringSetValue -> (list)
When the
stringSetValuetype is set, the value of the resource must be a string type.(string)
status -> (string)
The status of the container instance. The valid values are
REGISTERING,REGISTRATION_FAILED,ACTIVE,INACTIVE,DEREGISTERING, orDRAINING.If your account has opted in to the
awsvpcTrunkingaccount setting, then any newly registered container instance will transition to aREGISTERINGstatus while the trunk elastic network interface is provisioned for the instance. If the registration fails, the instance will transition to aREGISTRATION_FAILEDstatus. You can describe the container instance and see the reason for failure in thestatusReasonparameter. Once the container instance is terminated, the instance transitions to aDEREGISTERINGstatus while the trunk elastic network interface is deprovisioned. The instance then transitions to anINACTIVEstatus.The
ACTIVEstatus indicates that the container instance can accept tasks. TheDRAININGindicates that new tasks are not placed on the container instance and any service tasks running on the container instance are removed if possible. For more information, see Container Instance Draining in the Amazon Elastic Container Service Developer Guide .statusReason -> (string)
The reason that the container instance reached its current status.
agentConnected -> (boolean)
This parameter returns
trueif the agent is connected to Amazon ECS. Registered instances with an agent that may be unhealthy or stopped returnfalse. Only instances connected to an agent can accept placement requests.runningTasksCount -> (integer)
The number of tasks on the container instance that are in the
RUNNINGstatus.pendingTasksCount -> (integer)
The number of tasks on the container instance that are in the
PENDINGstatus.agentUpdateStatus -> (string)
The status of the most recent agent update. If an update has never been requested, this value is
NULL.attributes -> (list)
The attributes set for the container instance, either by the Amazon ECS container agent at instance registration or manually with the PutAttributes operation.
(structure)
An attribute is a name-value pair associated with an Amazon ECS object. Attributes enable you to extend the Amazon ECS data model by adding custom metadata to your resources. For more information, see Attributes in the Amazon Elastic Container Service Developer Guide .
name -> (string)
The name of the attribute. The
namemust contain between 1 and 128 characters and name may contain letters (uppercase and lowercase), numbers, hyphens, underscores, forward slashes, back slashes, or periods.value -> (string)
The value of the attribute. The
valuemust contain between 1 and 128 characters and may contain letters (uppercase and lowercase), numbers, hyphens, underscores, periods, at signs (@), forward slashes, back slashes, colons, or spaces. The value cannot contain any leading or trailing whitespace.targetType -> (string)
The type of the target with which to attach the attribute. This parameter is required if you use the short form ID for a resource instead of the full ARN.
targetId -> (string)
The ID of the target. You can specify the short form ID for a resource or the full Amazon Resource Name (ARN).
registeredAt -> (timestamp)
The Unix timestamp for when the container instance was registered.
attachments -> (list)
The resources attached to a container instance, such as elastic network interfaces.
(structure)
An object representing a container instance or task attachment.
id -> (string)
The unique identifier for the attachment.
type -> (string)
The type of the attachment, such as
ElasticNetworkInterface.status -> (string)
The status of the attachment. Valid values are
PRECREATED,CREATED,ATTACHING,ATTACHED,DETACHING,DETACHED, andDELETED.details -> (list)
Details of the attachment. For elastic network interfaces, this includes the network interface ID, the MAC address, the subnet ID, and the private IPv4 address.
(structure)
A key-value pair object.
name -> (string)
The name of the key-value pair. For environment variables, this is the name of the environment variable.
value -> (string)
The value of the key-value pair. For environment variables, this is the value of the environment variable.
tags -> (list)
The metadata that you apply to the container instance to help you categorize and organize them. Each tag consists of a key and an optional value, both of which you define.
The following basic restrictions apply to tags:
Maximum number of tags per resource - 50
For each resource, each tag key must be unique, and each tag key can have only one value.
Maximum key length - 128 Unicode characters in UTF-8
Maximum value length - 256 Unicode characters in UTF-8
If your tagging schema is used across multiple services and resources, remember that other services may have restrictions on allowed characters. Generally allowed characters are: letters, numbers, and spaces representable in UTF-8, and the following characters: + - = . _ : / @.
Tag keys and values are case-sensitive.
Do not use
aws:,AWS:, or any upper or lowercase combination of such as a prefix for either keys or values as it is reserved for Amazon Web Services use. You cannot edit or delete tag keys or values with this prefix. Tags with this prefix do not count against your tags per resource limit.(structure)
The metadata that you apply to a resource to help you categorize and organize them. Each tag consists of a key and an optional value, both of which you define.
The following basic restrictions apply to tags:
Maximum number of tags per resource - 50
For each resource, each tag key must be unique, and each tag key can have only one value.
Maximum key length - 128 Unicode characters in UTF-8
Maximum value length - 256 Unicode characters in UTF-8
If your tagging schema is used across multiple services and resources, remember that other services may have restrictions on allowed characters. Generally allowed characters are: letters, numbers, and spaces representable in UTF-8, and the following characters: + - = . _ : / @.
Tag keys and values are case-sensitive.
Do not use
aws:,AWS:, or any upper or lowercase combination of such as a prefix for either keys or values as it is reserved for Amazon Web Services use. You cannot edit or delete tag keys or values with this prefix. Tags with this prefix do not count against your tags per resource limit.key -> (string)
One part of a key-value pair that make up a tag. A
keyis a general label that acts like a category for more specific tag values.value -> (string)
The optional part of a key-value pair that make up a tag. A
valueacts as a descriptor within a tag category (key).