[ aws . imagebuilder ]
create-lifecycle-policy
--name <value>
[--description <value>]
[--status <value>]
--execution-role <value>
--resource-type <value>
--policy-details <value>
--resource-selection <value>
[--tags <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]
--name
(string)
The name of the lifecycle policy to create.
--description
(string)
Optional description for the lifecycle policy.
--status
(string)
Indicates whether the lifecycle policy resource is enabled.
Possible values:
DISABLED
ENABLED
--execution-role
(string)
The role name or Amazon Resource Name (ARN) for the IAM role that grants Image Builder access to run lifecycle actions.
--resource-type
(string)
The type of Image Builder resource that the lifecycle policy applies to.
Possible values:
AMI_IMAGE
CONTAINER_IMAGE
--policy-details
(list)
Configuration details for the lifecycle policy rules.
(structure)
The configuration details for a lifecycle policy resource.
action -> (structure)
Configuration details for the policy action.
type -> (string)
Specifies the lifecycle action to take.includeResources -> (structure)
Specifies the resources that the lifecycle policy applies to.
amis -> (boolean)
Specifies whether the lifecycle action should apply to distributed AMIs.snapshots -> (boolean)
Specifies whether the lifecycle action should apply to snapshots associated with distributed AMIs.containers -> (boolean)
Specifies whether the lifecycle action should apply to distributed containers.filter -> (structure)
Specifies the resources that the lifecycle policy applies to.
type -> (string)
Filter resources based on eitherage
orcount
.value -> (integer)
The number of units for the time period or for the count. For example, a value of
6
might refer to six months or six AMIs.Note
For count-based filters, this value represents the minimum number of resources to keep on hand. If you have fewer resources than this number, the resource is excluded from lifecycle actions.unit -> (string)
Defines the unit of time that the lifecycle policy uses to determine impacted resources. This is required for age-based rules.retainAtLeast -> (integer)
For age-based filters, this is the number of resources to keep on hand after the lifecycleDELETE
action is applied. Impacted resources are only deleted if you have more than this number of resources. If you have fewer resources than this number, the impacted resource is not deleted.exclusionRules -> (structure)
Additional rules to specify resources that should be exempt from policy actions.
tagMap -> (map)
Contains a list of tags that Image Builder uses to skip lifecycle actions for AMIs that have them.
key -> (string)
value -> (string)
amis -> (structure)
Lists configuration values that apply to AMIs that Image Builder should exclude from the lifecycle action.
isPublic -> (boolean)
Configures whether public AMIs are excluded from the lifecycle action.regions -> (list)
Specifies Amazon Web Services accounts whose resources are excluded from the lifecycle action.
(string)
sharedAccounts -> (list)
Specifies configuration details for Image Builder to exclude the most recent resources from lifecycle actions.
(string)
lastLaunched -> (structure)
Configures Amazon Web Services Regions that are excluded from the lifecycle action.
value -> (integer)
The integer number of units for the time period. For example6
(months).unit -> (string)
Defines the unit of time that the lifecycle policy uses to calculate elapsed time since the last instance launched from the AMI. For example: days, weeks, months, or years.tagMap -> (map)
Lists tags that should be excluded from lifecycle actions for the AMIs that have them.
key -> (string)
value -> (string)
JSON Syntax:
[
{
"action": {
"type": "DELETE"|"DEPRECATE"|"DISABLE",
"includeResources": {
"amis": true|false,
"snapshots": true|false,
"containers": true|false
}
},
"filter": {
"type": "AGE"|"COUNT",
"value": integer,
"unit": "DAYS"|"WEEKS"|"MONTHS"|"YEARS",
"retainAtLeast": integer
},
"exclusionRules": {
"tagMap": {"string": "string"
...},
"amis": {
"isPublic": true|false,
"regions": ["string", ...],
"sharedAccounts": ["string", ...],
"lastLaunched": {
"value": integer,
"unit": "DAYS"|"WEEKS"|"MONTHS"|"YEARS"
},
"tagMap": {"string": "string"
...}
}
}
}
...
]
--resource-selection
(structure)
Selection criteria for the resources that the lifecycle policy applies to.
recipes -> (list)
A list of recipes that are used as selection criteria for the output images that the lifecycle policy applies to.
(structure)
Specifies an Image Builder recipe that the lifecycle policy uses for resource selection.
name -> (string)
The name of an Image Builder recipe that the lifecycle policy uses for resource selection.semanticVersion -> (string)
The version of the Image Builder recipe specified by thename
field.tagMap -> (map)
A list of tags that are used as selection criteria for the resources that the lifecycle policy applies to.
key -> (string)
value -> (string)
Shorthand Syntax:
recipes=[{name=string,semanticVersion=string},{name=string,semanticVersion=string}],tagMap={KeyName1=string,KeyName2=string}
JSON Syntax:
{
"recipes": [
{
"name": "string",
"semanticVersion": "string"
}
...
],
"tagMap": {"string": "string"
...}
}
--tags
(map)
Tags to apply to the lifecycle policy resource.
key -> (string)
value -> (string)
Shorthand Syntax:
KeyName1=string,KeyName2=string
JSON Syntax:
{"string": "string"
...}
--client-token
(string)
Unique, case-sensitive identifier you provide to ensure idempotency of the request. For more information, see Ensuring idempotency in the Amazon EC2 API Reference .
--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.
--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.
clientToken -> (string)
The client token that uniquely identifies the request.
lifecyclePolicyArn -> (string)
The Amazon Resource Name (ARN) of the lifecycle policy that the request created.