Updates a compute node group. You can update many of the fields related to your compute node group including the configurations for networking, compute nodes, and settings specific to your scheduler (such as Slurm).
See also: AWS API Documentation
  update-compute-node-group
--cluster-identifier <value>
--compute-node-group-identifier <value>
[--ami-id <value>]
[--subnet-ids <value>]
[--custom-launch-template <value>]
[--purchase-option <value>]
[--spot-options <value>]
[--scaling-configuration <value>]
[--iam-instance-profile-arn <value>]
[--slurm-configuration <value>]
[--client-token <value>]
[--cli-input-json | --cli-input-yaml]
[--generate-cli-skeleton <value>]
[--debug]
[--endpoint-url <value>]
[--no-verify-ssl]
[--no-paginate]
[--output <value>]
[--query <value>]
[--profile <value>]
[--region <value>]
[--version <value>]
[--color <value>]
[--no-sign-request]
[--ca-bundle <value>]
[--cli-read-timeout <value>]
[--cli-connect-timeout <value>]
[--cli-binary-format <value>]
[--no-cli-pager]
[--cli-auto-prompt]
[--no-cli-auto-prompt]
--cluster-identifier (string) [required]
The name or ID of the cluster of the compute node group.
Constraints:
- pattern:
(pcs_[a-zA-Z0-9]+|[A-Za-z][A-Za-z0-9-]{2,40})
--compute-node-group-identifier (string) [required]
The name or ID of the compute node group.
Constraints:
- pattern:
(pcs_[a-zA-Z0-9]+|[A-Za-z][A-Za-z0-9-]{2,25})
--ami-id (string)
The ID of the Amazon Machine Image (AMI) that PCS uses to launch instances. If not provided, PCS uses the AMI ID specified in the custom launch template.
Constraints:
- pattern:
ami-[a-z0-9]+
--subnet-ids (list)
The list of subnet IDs where the compute node group provisions instances. The subnets must be in the same VPC as the cluster.
(string)
Syntax:
"string" "string" ...
--custom-launch-template (structure)
An Amazon EC2 launch template PCS uses to launch compute nodes.
id -> (string) [required]
The ID of the EC2 launch template to use to provision instances.
Example:
lt-xxxxversion -> (string) [required]
The version of the EC2 launch template to use to provision instances.
Shorthand Syntax:
id=string,version=string
JSON Syntax:
{
  "id": "string",
  "version": "string"
}
--purchase-option (string)
Specifies how EC2 instances are purchased on your behalf. PCS supports On-Demand Instances, Spot Instances, and Amazon EC2 Capacity Blocks for ML. For more information, see Amazon EC2 billing and purchasing options in the Amazon Elastic Compute Cloud User Guide . For more information about PCS support for Capacity Blocks, see Using Amazon EC2 Capacity Blocks for ML with PCS in the PCS User Guide . If you don’t provide this option, it defaults to On-Demand.
Possible values:
ONDEMAND
SPOT
CAPACITY_BLOCK
--spot-options (structure)
Additional configuration when you specify
SPOTas thepurchaseOptionfor theCreateComputeNodeGroupAPI action.allocationStrategy -> (string)
The Amazon EC2 allocation strategy PCS uses to provision EC2 instances. PCS supports lowest price , capacity optimized , and price capacity optimized . For more information, see Use allocation strategies to determine how EC2 Fleet or Spot Fleet fulfills Spot and On-Demand capacity in the Amazon Elastic Compute Cloud User Guide . If you don’t provide this option, it defaults to price capacity optimized .
Possible values:
lowest-price
capacity-optimized
price-capacity-optimized
Shorthand Syntax:
allocationStrategy=string
JSON Syntax:
{
  "allocationStrategy": "lowest-price"|"capacity-optimized"|"price-capacity-optimized"
}
--scaling-configuration (structure)
Specifies the boundaries of the compute node group auto scaling.
minInstanceCount -> (integer) [required]
The lower bound of the number of instances allowed in the compute fleet.
Constraints:
- min:
0maxInstanceCount -> (integer) [required]
The upper bound of the number of instances allowed in the compute fleet.
Constraints:
- min:
0
Shorthand Syntax:
minInstanceCount=integer,maxInstanceCount=integer
JSON Syntax:
{
  "minInstanceCount": integer,
  "maxInstanceCount": integer
}
--iam-instance-profile-arn (string)
The Amazon Resource Name (ARN) of the IAM instance profile used to pass an IAM role when launching EC2 instances. The role contained in your instance profile must have the
pcs:RegisterComputeNodeGroupInstancepermission and the role name must start withAWSPCSor must have the path/aws-pcs/. For more information, see IAM instance profiles for PCS in the PCS User Guide .Constraints:
- pattern:
arn:aws([a-zA-Z-]{0,10})?:iam::[0-9]{12}:instance-profile/([!-~]{1,510}/)?([\w+=,.@-]{1,128})
--slurm-configuration (structure)
Additional options related to the Slurm scheduler.
slurmCustomSettings -> (list)
Additional Slurm-specific configuration that directly maps to Slurm settings.
(structure)
Additional settings that directly map to Slurm settings.
Warning
PCS supports a subset of Slurm settings. For more information, see Configuring custom Slurm settings in PCS in the PCS User Guide .parameterName -> (string) [required]
PCS supports custom Slurm settings for clusters, compute node groups, and queues. For more information, see Configuring custom Slurm settings in PCS in the PCS User Guide .parameterValue -> (string) [required]
The values for the configured Slurm settings.
Shorthand Syntax:
slurmCustomSettings=[{parameterName=string,parameterValue=string},{parameterName=string,parameterValue=string}]
JSON Syntax:
{
  "slurmCustomSettings": [
    {
      "parameterName": "string",
      "parameterValue": "string"
    }
    ...
  ]
}
--client-token (string)
A unique, case-sensitive identifier that you provide to ensure the idempotency of the request. Idempotency ensures that an API request completes only once. With an idempotent request, if the original request completes successfully, the subsequent retries with the same client token return the result from the original successful request and they have no additional effect. If you don’t specify a client token, the CLI and SDK automatically generate 1 for you.
Constraints:
- min:
8- max:
100
--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. The generated JSON skeleton is not stable between versions of the AWS CLI and there are no backwards compatibility guarantees in the JSON skeleton generated.
--debug (boolean)
Turn on debug logging.
--endpoint-url (string)
Override command’s default URL with the given URL.
--no-verify-ssl (boolean)
By default, the AWS CLI uses SSL when communicating with AWS services. For each SSL connection, the AWS CLI will verify SSL certificates. This option overrides the default behavior of verifying SSL certificates.
--no-paginate (boolean)
Disable automatic pagination. If automatic pagination is disabled, the AWS CLI will only make one call, for the first page of results.
--output (string)
The formatting style for command output.
--query (string)
A JMESPath query to use in filtering the response data.
--profile (string)
Use a specific profile from your credential file.
--region (string)
The region to use. Overrides config/env settings.
--version (string)
Display the version of this tool.
--color (string)
Turn on/off color output.
--no-sign-request (boolean)
Do not sign requests. Credentials will not be loaded if this argument is provided.
--ca-bundle (string)
The CA certificate bundle to use when verifying SSL certificates. Overrides config/env settings.
--cli-read-timeout (int)
The maximum socket read time in seconds. If the value is set to 0, the socket read will be blocking and not timeout. The default value is 60 seconds.
--cli-connect-timeout (int)
The maximum socket connect time in seconds. If the value is set to 0, the socket connect will be blocking and not timeout. The default value is 60 seconds.
--cli-binary-format (string)
The formatting style to be used for binary blobs. The default format is base64. The base64 format expects binary blobs to be provided as a base64 encoded string. The raw-in-base64-out format preserves compatibility with AWS CLI V1 behavior and binary values must be passed literally. When providing contents from a file that map to a binary blob fileb:// will always be treated as binary and use the file contents directly regardless of the cli-binary-format setting. When using file:// the file contents will need to properly formatted for the configured cli-binary-format.
--no-cli-pager (boolean)
Disable cli pager for output.
--cli-auto-prompt (boolean)
Automatically prompt for CLI input parameters.
--no-cli-auto-prompt (boolean)
Disable automatically prompt for CLI input parameters.
computeNodeGroup -> (structure)
A compute node group associated with a cluster.
name -> (string) [required]
The name that identifies the compute node group.
Constraints:
- min:
3- max:
25- pattern:
(?!pcs_)^[A-Za-z][A-Za-z0-9-]+id -> (string) [required]
The generated unique ID of the compute node group.arn -> (string) [required]
The unique Amazon Resource Name (ARN) of the compute node group.clusterId -> (string) [required]
The ID of the cluster of the compute node group.createdAt -> (timestamp) [required]
The date and time the resource was created.modifiedAt -> (timestamp) [required]
The date and time the resource was modified.status -> (string) [required]
The provisioning status of the compute node group.
Note
The provisioning status doesn’t indicate the overall health of the compute node group.Warning
The resource enters theSUSPENDINGandSUSPENDEDstates when the scheduler is beyond end of life and we have suspended the cluster. When in these states, you can’t use the cluster. The cluster controller is down and all compute instances are terminated. The resources still count toward your service quotas. You can delete a resource if its status isSUSPENDED. For more information, see Frequently asked questions about Slurm versions in PCS in the PCS User Guide .Possible values:
CREATING
ACTIVE
UPDATING
DELETING
CREATE_FAILED
DELETE_FAILED
UPDATE_FAILED
DELETED
SUSPENDING
SUSPENDEDamiId -> (string)
The ID of the Amazon Machine Image (AMI) that PCS uses to launch instances. If not provided, PCS uses the AMI ID specified in the custom launch template.
Constraints:
- pattern:
ami-[a-z0-9]+subnetIds -> (list) [required]
The list of subnet IDs where instances are provisioned by the compute node group. The subnets must be in the same VPC as the cluster.
Constraints:
- min:
1(string)
Constraints:
- pattern:
subnet-\w{8,17}purchaseOption -> (string)
Specifies how EC2 instances are purchased on your behalf. PCS supports On-Demand Instances, Spot Instances, and Amazon EC2 Capacity Blocks for ML. For more information, see Amazon EC2 billing and purchasing options in the Amazon Elastic Compute Cloud User Guide . For more information about PCS support for Capacity Blocks, see Using Amazon EC2 Capacity Blocks for ML with PCS in the PCS User Guide . If you don’t provide this option, it defaults to On-Demand.
Possible values:
ONDEMAND
SPOT
CAPACITY_BLOCKcustomLaunchTemplate -> (structure) [required]
An Amazon EC2 launch template PCS uses to launch compute nodes.
id -> (string) [required]
The ID of the EC2 launch template to use to provision instances.
Example:
lt-xxxxversion -> (string) [required]
The version of the EC2 launch template to use to provision instances.iamInstanceProfileArn -> (string) [required]
The Amazon Resource Name (ARN) of the IAM instance profile used to pass an IAM role when launching EC2 instances. The role contained in your instance profile must have the
pcs:RegisterComputeNodeGroupInstancepermission and the role name must start withAWSPCSor must have the path/aws-pcs/. For more information, see IAM instance profiles for PCS in the PCS User Guide .Constraints:
- pattern:
arn:aws([a-zA-Z-]{0,10})?:iam::[0-9]{12}:instance-profile/([!-~]{1,510}/)?([\w+=,.@-]{1,128})scalingConfiguration -> (structure) [required]
Specifies the boundaries of the compute node group auto scaling.
minInstanceCount -> (integer) [required]
The lower bound of the number of instances allowed in the compute fleet.
Constraints:
- min:
0maxInstanceCount -> (integer) [required]
The upper bound of the number of instances allowed in the compute fleet.
Constraints:
- min:
0instanceConfigs -> (list) [required]
A list of EC2 instance configurations that PCS can provision in the compute node group.
(structure)
An EC2 instance configuration PCS uses to launch compute nodes.
instanceType -> (string)
The EC2 instance type that PCS can provision in the compute node group.
Example:
t2.xlargespotOptions -> (structure)
Additional configuration when you specify
SPOTas thepurchaseOptionfor theCreateComputeNodeGroupAPI action.allocationStrategy -> (string)
The Amazon EC2 allocation strategy PCS uses to provision EC2 instances. PCS supports lowest price , capacity optimized , and price capacity optimized . For more information, see Use allocation strategies to determine how EC2 Fleet or Spot Fleet fulfills Spot and On-Demand capacity in the Amazon Elastic Compute Cloud User Guide . If you don’t provide this option, it defaults to price capacity optimized .
Possible values:
lowest-price
capacity-optimized
price-capacity-optimizedslurmConfiguration -> (structure)
Additional options related to the Slurm scheduler.
slurmCustomSettings -> (list)
Additional Slurm-specific configuration that directly maps to Slurm settings.
(structure)
Additional settings that directly map to Slurm settings.
Warning
PCS supports a subset of Slurm settings. For more information, see Configuring custom Slurm settings in PCS in the PCS User Guide .parameterName -> (string) [required]
PCS supports custom Slurm settings for clusters, compute node groups, and queues. For more information, see Configuring custom Slurm settings in PCS in the PCS User Guide .parameterValue -> (string) [required]
The values for the configured Slurm settings.errorInfo -> (list)
The list of errors that occurred during compute node group provisioning.
(structure)
An error that occurred during resource creation.
code -> (string)
The short-form error code.message -> (string)
The detailed error information.