lifecycle_hooks
Creates, updates, deletes or gets a lifecycle_hook
resource or lists lifecycle_hooks
in a region
Overview
Name | lifecycle_hooks |
Type | Resource |
Description | Resource Type definition for AWS::AutoScaling::LifecycleHook |
Id | aws.autoscaling.lifecycle_hooks |
Fields
Name | Datatype | Description |
---|---|---|
auto_scaling_group_name | string | The name of the Auto Scaling group for the lifecycle hook. |
default_result | string | The action the Auto Scaling group takes when the lifecycle hook timeout elapses or if an unexpected failure occurs. The valid values are CONTINUE and ABANDON (default). |
heartbeat_timeout | integer | The maximum time, in seconds, that can elapse before the lifecycle hook times out. The range is from 30 to 7200 seconds. The default value is 3600 seconds (1 hour). If the lifecycle hook times out, Amazon EC2 Auto Scaling performs the action that you specified in the DefaultResult property. |
lifecycle_hook_name | string | The name of the lifecycle hook. |
lifecycle_transition | string | The instance state to which you want to attach the lifecycle hook. |
notification_metadata | string | Additional information that is included any time Amazon EC2 Auto Scaling sends a message to the notification target. |
notification_target_arn | string | The Amazon Resource Name (ARN) of the notification target that Amazon EC2 Auto Scaling uses to notify you when an instance is in the transition state for the lifecycle hook. You can specify an Amazon SQS queue or an Amazon SNS topic. The notification message includes the following information: lifecycle action token, user account ID, Auto Scaling group name, lifecycle hook name, instance ID, lifecycle transition, and notification metadata. |
role_arn | string | The ARN of the IAM role that allows the Auto Scaling group to publish to the specified notification target, for example, an Amazon SNS topic or an Amazon SQS queue. |
region | string | AWS region. |
Methods
Name | Accessible by | Required Params |
---|---|---|
create_resource | INSERT | LifecycleTransition, AutoScalingGroupName, region |
delete_resource | DELETE | data__Identifier, region |
update_resource | UPDATE | data__Identifier, data__PatchDocument, region |
list_resources | SELECT | region |
get_resource | SELECT | data__Identifier, region |
SELECT
examples
Gets all lifecycle_hooks
in a region.
SELECT
region,
auto_scaling_group_name,
default_result,
heartbeat_timeout,
lifecycle_hook_name,
lifecycle_transition,
notification_metadata,
notification_target_arn,
role_arn
FROM aws.autoscaling.lifecycle_hooks
WHERE region = 'us-east-1';
Gets all properties from an individual lifecycle_hook
.
SELECT
region,
auto_scaling_group_name,
default_result,
heartbeat_timeout,
lifecycle_hook_name,
lifecycle_transition,
notification_metadata,
notification_target_arn,
role_arn
FROM aws.autoscaling.lifecycle_hooks
WHERE region = 'us-east-1' AND data__Identifier = '<AutoScalingGroupName>|<LifecycleHookName>';
INSERT
example
Use the following StackQL query and manifest file to create a new lifecycle_hook
resource, using stack-deploy
.
- Required Properties
- All Properties
- Manifest
/*+ create */
INSERT INTO aws.autoscaling.lifecycle_hooks (
AutoScalingGroupName,
LifecycleTransition,
region
)
SELECT
'{{ AutoScalingGroupName }}',
'{{ LifecycleTransition }}',
'{{ region }}';
/*+ create */
INSERT INTO aws.autoscaling.lifecycle_hooks (
AutoScalingGroupName,
DefaultResult,
HeartbeatTimeout,
LifecycleHookName,
LifecycleTransition,
NotificationMetadata,
NotificationTargetARN,
RoleARN,
region
)
SELECT
'{{ AutoScalingGroupName }}',
'{{ DefaultResult }}',
'{{ HeartbeatTimeout }}',
'{{ LifecycleHookName }}',
'{{ LifecycleTransition }}',
'{{ NotificationMetadata }}',
'{{ NotificationTargetARN }}',
'{{ RoleARN }}',
'{{ region }}';
version: 1
name: stack name
description: stack description
providers:
- aws
globals:
- name: region
value: '{{ vars.AWS_REGION }}'
resources:
- name: lifecycle_hook
props:
- name: AutoScalingGroupName
value: '{{ AutoScalingGroupName }}'
- name: DefaultResult
value: '{{ DefaultResult }}'
- name: HeartbeatTimeout
value: '{{ HeartbeatTimeout }}'
- name: LifecycleHookName
value: '{{ LifecycleHookName }}'
- name: LifecycleTransition
value: '{{ LifecycleTransition }}'
- name: NotificationMetadata
value: '{{ NotificationMetadata }}'
- name: NotificationTargetARN
value: '{{ NotificationTargetARN }}'
- name: RoleARN
value: '{{ RoleARN }}'
DELETE
example
/*+ delete */
DELETE FROM aws.autoscaling.lifecycle_hooks
WHERE data__Identifier = '<AutoScalingGroupName|LifecycleHookName>'
AND region = 'us-east-1';
Permissions
To operate on the lifecycle_hooks
resource, the following permissions are required:
Create
autoscaling:PutLifecycleHook,
autoscaling:DescribeLifecycleHooks,
iam:PassRole
Read
autoscaling:DescribeLifecycleHooks
Update
autoscaling:PutLifecycleHook,
autoscaling:DescribeLifecycleHooks,
iam:PassRole
Delete
autoscaling:DeleteLifecycleHook,
autoscaling:DescribeLifecycleHooks
List
autoscaling:DescribeLifecycleHooks