Class CfnAssociation
- All Implemented Interfaces:
IConstruct
,IDependable
,IInspectable
,software.amazon.jsii.JsiiSerializable
,software.constructs.IConstruct
AWS::SSM::Association
.
The AWS::SSM::Association
resource creates a State Manager association for your managed instances. A State Manager association defines the state that you want to maintain on your instances. For example, an association can specify that anti-virus software must be installed and running on your instances, or that certain ports must be closed. For static targets, the association specifies a schedule for when the configuration is reapplied. For dynamic targets, such as an AWS Resource Groups or an AWS Auto Scaling Group, State Manager applies the configuration when new instances are added to the group. The association also specifies actions to take when applying the configuration. For example, an association for anti-virus software might run once a day. If the software is not installed, then State Manager installs it. If the software is installed, but the service is not running, then the association might instruct State Manager to start the service.
Example:
// The code below shows an example of how to instantiate this type. // The values are placeholders you should change. import software.amazon.awscdk.services.ssm.*; Object parameters; CfnAssociation cfnAssociation = CfnAssociation.Builder.create(this, "MyCfnAssociation") .name("name") // the properties below are optional .applyOnlyAtCronInterval(false) .associationName("associationName") .automationTargetParameterName("automationTargetParameterName") .calendarNames(List.of("calendarNames")) .complianceSeverity("complianceSeverity") .documentVersion("documentVersion") .instanceId("instanceId") .maxConcurrency("maxConcurrency") .maxErrors("maxErrors") .outputLocation(InstanceAssociationOutputLocationProperty.builder() .s3Location(S3OutputLocationProperty.builder() .outputS3BucketName("outputS3BucketName") .outputS3KeyPrefix("outputS3KeyPrefix") .outputS3Region("outputS3Region") .build()) .build()) .parameters(parameters) .scheduleExpression("scheduleExpression") .scheduleOffset(123) .syncCompliance("syncCompliance") .targets(List.of(TargetProperty.builder() .key("key") .values(List.of("values")) .build())) .waitForSuccessTimeoutSeconds(123) .build();
-
Nested Class Summary
Modifier and TypeClassDescriptionstatic final class
A fluent builder forCfnAssociation
.static interface
InstanceAssociationOutputLocation
is a property of the AWS::SSM::Association resource that specifies an Amazon S3 bucket where you want to store the results of this association request.static interface
S3OutputLocation
is a property of the AWS::SSM::Association resource that specifies an Amazon S3 bucket where you want to store the results of this association request.static interface
Target
is a property of the AWS::SSM::Association resource that specifies the targets for an SSM document in Systems Manager .Nested classes/interfaces inherited from class software.amazon.jsii.JsiiObject
software.amazon.jsii.JsiiObject.InitializationMode
Nested classes/interfaces inherited from interface software.amazon.awscdk.core.IConstruct
IConstruct.Jsii$Default
Nested classes/interfaces inherited from interface software.constructs.IConstruct
software.constructs.IConstruct.Jsii$Default
Nested classes/interfaces inherited from interface software.amazon.awscdk.core.IInspectable
IInspectable.Jsii$Default, IInspectable.Jsii$Proxy
-
Field Summary
Modifier and TypeFieldDescriptionstatic final String
The CloudFormation resource type name for this resource class. -
Constructor Summary
ModifierConstructorDescriptionCfnAssociation
(Construct scope, String id, CfnAssociationProps props) Create a newAWS::SSM::Association
.protected
CfnAssociation
(software.amazon.jsii.JsiiObject.InitializationMode initializationMode) protected
CfnAssociation
(software.amazon.jsii.JsiiObjectRef objRef) -
Method Summary
Modifier and TypeMethodDescriptionBy default, when you create a new association, the system runs it immediately after it is created and then according to the schedule you specified.Specify a descriptive name for the association.The association ID.Choose the parameter that will define how your automation will branch out.The names or Amazon Resource Names (ARNs) of the Change Calendar type documents your associations are gated under.The severity level that is assigned to the association.The version of the SSM document to associate with the target.The ID of the instance that the SSM document is associated with.The maximum number of targets allowed to run the association at the same time.The number of errors that are allowed before the system stops sending requests to run the association on additional targets.getName()
The name of the SSM document that contains the configuration information for the instance.An Amazon Simple Storage Service (Amazon S3) bucket where you want to store the output details of the request.The parameters for the runtime configuration of the document.A cron expression that specifies a schedule when the association runs.Number of days to wait after the scheduled day to run an association.The mode for generating association compliance.The targets for the association.The number of seconds the service should wait for the association status to show "Success" before proceeding with the stack execution.void
inspect
(TreeInspector inspector) Examines the CloudFormation resource and discloses attributes.renderProperties
(Map<String, Object> props) void
By default, when you create a new association, the system runs it immediately after it is created and then according to the schedule you specified.void
By default, when you create a new association, the system runs it immediately after it is created and then according to the schedule you specified.void
setAssociationName
(String value) Specify a descriptive name for the association.void
Choose the parameter that will define how your automation will branch out.void
setCalendarNames
(List<String> value) The names or Amazon Resource Names (ARNs) of the Change Calendar type documents your associations are gated under.void
setComplianceSeverity
(String value) The severity level that is assigned to the association.void
setDocumentVersion
(String value) The version of the SSM document to associate with the target.void
setInstanceId
(String value) The ID of the instance that the SSM document is associated with.void
setMaxConcurrency
(String value) The maximum number of targets allowed to run the association at the same time.void
setMaxErrors
(String value) The number of errors that are allowed before the system stops sending requests to run the association on additional targets.void
The name of the SSM document that contains the configuration information for the instance.void
setOutputLocation
(IResolvable value) An Amazon Simple Storage Service (Amazon S3) bucket where you want to store the output details of the request.void
An Amazon Simple Storage Service (Amazon S3) bucket where you want to store the output details of the request.void
setParameters
(Object value) The parameters for the runtime configuration of the document.void
setScheduleExpression
(String value) A cron expression that specifies a schedule when the association runs.void
setScheduleOffset
(Number value) Number of days to wait after the scheduled day to run an association.void
setSyncCompliance
(String value) The mode for generating association compliance.void
setTargets
(List<Object> value) The targets for the association.void
setTargets
(IResolvable value) The targets for the association.void
The number of seconds the service should wait for the association status to show "Success" before proceeding with the stack execution.Methods inherited from class software.amazon.awscdk.core.CfnResource
addDeletionOverride, addDependsOn, addMetadata, addOverride, addPropertyDeletionOverride, addPropertyOverride, applyRemovalPolicy, applyRemovalPolicy, applyRemovalPolicy, getAtt, getCfnOptions, getCfnResourceType, getMetadata, getUpdatedProperites, isCfnResource, shouldSynthesize, toString, validateProperties
Methods inherited from class software.amazon.awscdk.core.CfnRefElement
getRef
Methods inherited from class software.amazon.awscdk.core.CfnElement
getCreationStack, getLogicalId, getStack, isCfnElement, overrideLogicalId
Methods inherited from class software.amazon.awscdk.core.Construct
getNode, isConstruct, onPrepare, onSynthesize, onValidate, prepare, synthesize, validate
Methods inherited from class software.amazon.jsii.JsiiObject
jsiiAsyncCall, jsiiAsyncCall, jsiiCall, jsiiCall, jsiiGet, jsiiGet, jsiiSet, jsiiStaticCall, jsiiStaticCall, jsiiStaticGet, jsiiStaticGet, jsiiStaticSet, jsiiStaticSet
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait
Methods inherited from interface software.amazon.jsii.JsiiSerializable
$jsii$toJson
-
Field Details
-
CFN_RESOURCE_TYPE_NAME
The CloudFormation resource type name for this resource class.
-
-
Constructor Details
-
CfnAssociation
protected CfnAssociation(software.amazon.jsii.JsiiObjectRef objRef) -
CfnAssociation
protected CfnAssociation(software.amazon.jsii.JsiiObject.InitializationMode initializationMode) -
CfnAssociation
@Stability(Stable) public CfnAssociation(@NotNull Construct scope, @NotNull String id, @NotNull CfnAssociationProps props) Create a newAWS::SSM::Association
.- Parameters:
scope
-- scope in which this resource is defined.
id
-- scoped id of the resource.
props
-- resource properties.
-
-
Method Details
-
inspect
Examines the CloudFormation resource and discloses attributes.- Specified by:
inspect
in interfaceIInspectable
- Parameters:
inspector
-- tree inspector to collect and process attributes.
-
renderProperties
@Stability(Stable) @NotNull protected Map<String,Object> renderProperties(@NotNull Map<String, Object> props) - Overrides:
renderProperties
in classCfnResource
- Parameters:
props
- This parameter is required.
-
getAttrAssociationId
The association ID. -
getCfnProperties
- Overrides:
getCfnProperties
in classCfnResource
-
getName
The name of the SSM document that contains the configuration information for the instance.You can specify
Command
orAutomation
documents. The documents can be AWS -predefined documents, documents you created, or a document that is shared with you from another account. For SSM documents that are shared with you from other AWS accounts , you must specify the complete SSM document ARN, in the following format:arn:partition:ssm:region:account-id:document/document-name
For example:
arn:aws:ssm:us-east-2:12345678912:document/My-Shared-Document
For AWS -predefined documents and SSM documents you created in your account, you only need to specify the document name. For example,
AWS -ApplyPatchBaseline
orMy-Document
. -
setName
The name of the SSM document that contains the configuration information for the instance.You can specify
Command
orAutomation
documents. The documents can be AWS -predefined documents, documents you created, or a document that is shared with you from another account. For SSM documents that are shared with you from other AWS accounts , you must specify the complete SSM document ARN, in the following format:arn:partition:ssm:region:account-id:document/document-name
For example:
arn:aws:ssm:us-east-2:12345678912:document/My-Shared-Document
For AWS -predefined documents and SSM documents you created in your account, you only need to specify the document name. For example,
AWS -ApplyPatchBaseline
orMy-Document
. -
getParameters
The parameters for the runtime configuration of the document. -
setParameters
The parameters for the runtime configuration of the document. -
getApplyOnlyAtCronInterval
By default, when you create a new association, the system runs it immediately after it is created and then according to the schedule you specified.Specify this option if you don't want an association to run immediately after you create it. This parameter is not supported for rate expressions.
-
setApplyOnlyAtCronInterval
By default, when you create a new association, the system runs it immediately after it is created and then according to the schedule you specified.Specify this option if you don't want an association to run immediately after you create it. This parameter is not supported for rate expressions.
-
setApplyOnlyAtCronInterval
By default, when you create a new association, the system runs it immediately after it is created and then according to the schedule you specified.Specify this option if you don't want an association to run immediately after you create it. This parameter is not supported for rate expressions.
-
getAssociationName
Specify a descriptive name for the association. -
setAssociationName
Specify a descriptive name for the association. -
getAutomationTargetParameterName
Choose the parameter that will define how your automation will branch out.This target is required for associations that use an Automation runbook and target resources by using rate controls. Automation is a capability of AWS Systems Manager .
-
setAutomationTargetParameterName
Choose the parameter that will define how your automation will branch out.This target is required for associations that use an Automation runbook and target resources by using rate controls. Automation is a capability of AWS Systems Manager .
-
getCalendarNames
The names or Amazon Resource Names (ARNs) of the Change Calendar type documents your associations are gated under.The associations only run when that Change Calendar is open. For more information, see AWS Systems Manager Change Calendar .
-
setCalendarNames
The names or Amazon Resource Names (ARNs) of the Change Calendar type documents your associations are gated under.The associations only run when that Change Calendar is open. For more information, see AWS Systems Manager Change Calendar .
-
getComplianceSeverity
The severity level that is assigned to the association. -
setComplianceSeverity
The severity level that is assigned to the association. -
getDocumentVersion
The version of the SSM document to associate with the target.Note the following important information.
- State Manager doesn't support running associations that use a new version of a document if that document is shared from another account. State Manager always runs the
default
version of a document if shared from another account, even though the Systems Manager console shows that a new version was processed. If you want to run an association using a new version of a document shared form another account, you must set the document version todefault
. DocumentVersion
is not valid for documents owned by AWS , such asAWS-RunPatchBaseline
orAWS-UpdateSSMAgent
. If you specifyDocumentVersion
for an AWS document, the system returns the following error: "Error occurred during operation 'CreateAssociation'." (RequestToken:, HandlerErrorCode: GeneralServiceException).
- State Manager doesn't support running associations that use a new version of a document if that document is shared from another account. State Manager always runs the
-
setDocumentVersion
The version of the SSM document to associate with the target.Note the following important information.
- State Manager doesn't support running associations that use a new version of a document if that document is shared from another account. State Manager always runs the
default
version of a document if shared from another account, even though the Systems Manager console shows that a new version was processed. If you want to run an association using a new version of a document shared form another account, you must set the document version todefault
. DocumentVersion
is not valid for documents owned by AWS , such asAWS-RunPatchBaseline
orAWS-UpdateSSMAgent
. If you specifyDocumentVersion
for an AWS document, the system returns the following error: "Error occurred during operation 'CreateAssociation'." (RequestToken:, HandlerErrorCode: GeneralServiceException).
- State Manager doesn't support running associations that use a new version of a document if that document is shared from another account. State Manager always runs the
-
getInstanceId
The ID of the instance that the SSM document is associated with.You must specify the
InstanceId
orTargets
property.InstanceId
has been deprecated. To specify an instance ID for an association, use theTargets
parameter. If you use the parameterInstanceId
, you cannot use the parametersAssociationName
,DocumentVersion
,MaxErrors
,MaxConcurrency
,OutputLocation
, orScheduleExpression
. To use these parameters, you must use theTargets
parameter. -
setInstanceId
The ID of the instance that the SSM document is associated with.You must specify the
InstanceId
orTargets
property.InstanceId
has been deprecated. To specify an instance ID for an association, use theTargets
parameter. If you use the parameterInstanceId
, you cannot use the parametersAssociationName
,DocumentVersion
,MaxErrors
,MaxConcurrency
,OutputLocation
, orScheduleExpression
. To use these parameters, you must use theTargets
parameter. -
getMaxConcurrency
The maximum number of targets allowed to run the association at the same time.You can specify a number, for example 10, or a percentage of the target set, for example 10%. The default value is 100%, which means all targets run the association at the same time.
If a new managed node starts and attempts to run an association while Systems Manager is running
MaxConcurrency
associations, the association is allowed to run. During the next association interval, the new managed node will process its association within the limit specified forMaxConcurrency
. -
setMaxConcurrency
The maximum number of targets allowed to run the association at the same time.You can specify a number, for example 10, or a percentage of the target set, for example 10%. The default value is 100%, which means all targets run the association at the same time.
If a new managed node starts and attempts to run an association while Systems Manager is running
MaxConcurrency
associations, the association is allowed to run. During the next association interval, the new managed node will process its association within the limit specified forMaxConcurrency
. -
getMaxErrors
The number of errors that are allowed before the system stops sending requests to run the association on additional targets.You can specify either an absolute number of errors, for example 10, or a percentage of the target set, for example 10%. If you specify 3, for example, the system stops sending requests when the fourth error is received. If you specify 0, then the system stops sending requests after the first error is returned. If you run an association on 50 managed nodes and set
MaxError
to 10%, then the system stops sending the request when the sixth error is received.Executions that are already running an association when
MaxErrors
is reached are allowed to complete, but some of these executions may fail as well. If you need to ensure that there won't be more than max-errors failed executions, setMaxConcurrency
to 1 so that executions proceed one at a time. -
setMaxErrors
The number of errors that are allowed before the system stops sending requests to run the association on additional targets.You can specify either an absolute number of errors, for example 10, or a percentage of the target set, for example 10%. If you specify 3, for example, the system stops sending requests when the fourth error is received. If you specify 0, then the system stops sending requests after the first error is returned. If you run an association on 50 managed nodes and set
MaxError
to 10%, then the system stops sending the request when the sixth error is received.Executions that are already running an association when
MaxErrors
is reached are allowed to complete, but some of these executions may fail as well. If you need to ensure that there won't be more than max-errors failed executions, setMaxConcurrency
to 1 so that executions proceed one at a time. -
getOutputLocation
An Amazon Simple Storage Service (Amazon S3) bucket where you want to store the output details of the request. -
setOutputLocation
An Amazon Simple Storage Service (Amazon S3) bucket where you want to store the output details of the request. -
setOutputLocation
@Stability(Stable) public void setOutputLocation(@Nullable CfnAssociation.InstanceAssociationOutputLocationProperty value) An Amazon Simple Storage Service (Amazon S3) bucket where you want to store the output details of the request. -
getScheduleExpression
A cron expression that specifies a schedule when the association runs.The schedule runs in Coordinated Universal Time (UTC).
-
setScheduleExpression
A cron expression that specifies a schedule when the association runs.The schedule runs in Coordinated Universal Time (UTC).
-
getScheduleOffset
Number of days to wait after the scheduled day to run an association. -
setScheduleOffset
Number of days to wait after the scheduled day to run an association. -
getSyncCompliance
The mode for generating association compliance.You can specify
AUTO
orMANUAL
. InAUTO
mode, the system uses the status of the association execution to determine the compliance status. If the association execution runs successfully, then the association isCOMPLIANT
. If the association execution doesn't run successfully, the association isNON-COMPLIANT
.In
MANUAL
mode, you must specify theAssociationId
as a parameter for the PutComplianceItems API action. In this case, compliance data is not managed by State Manager. It is managed by your direct call to the PutComplianceItems API action.By default, all associations use
AUTO
mode. -
setSyncCompliance
The mode for generating association compliance.You can specify
AUTO
orMANUAL
. InAUTO
mode, the system uses the status of the association execution to determine the compliance status. If the association execution runs successfully, then the association isCOMPLIANT
. If the association execution doesn't run successfully, the association isNON-COMPLIANT
.In
MANUAL
mode, you must specify theAssociationId
as a parameter for the PutComplianceItems API action. In this case, compliance data is not managed by State Manager. It is managed by your direct call to the PutComplianceItems API action.By default, all associations use
AUTO
mode. -
getTargets
The targets for the association.You must specify the
InstanceId
orTargets
property. You can target all instances in an AWS account by specifying theInstanceIds
key with a value of*
. To view a JSON and a YAML example that targets all instances, see "Create an association for all managed instances in an AWS account " on the Examples page. -
setTargets
The targets for the association.You must specify the
InstanceId
orTargets
property. You can target all instances in an AWS account by specifying theInstanceIds
key with a value of*
. To view a JSON and a YAML example that targets all instances, see "Create an association for all managed instances in an AWS account " on the Examples page. -
setTargets
The targets for the association.You must specify the
InstanceId
orTargets
property. You can target all instances in an AWS account by specifying theInstanceIds
key with a value of*
. To view a JSON and a YAML example that targets all instances, see "Create an association for all managed instances in an AWS account " on the Examples page. -
getWaitForSuccessTimeoutSeconds
The number of seconds the service should wait for the association status to show "Success" before proceeding with the stack execution.If the association status doesn't show "Success" after the specified number of seconds, then stack creation fails.
-
setWaitForSuccessTimeoutSeconds
The number of seconds the service should wait for the association status to show "Success" before proceeding with the stack execution.If the association status doesn't show "Success" after the specified number of seconds, then stack creation fails.
-