AWSSupport-SetupIPMonitoringFromVPC
Description
                AWSSupport-SetupIPMonitoringFromVPC creates an Amazon Elastic Compute Cloud (Amazon EC2)
                instance in the specified subnet and monitors selected target IPs (IPv4 or IPv6) by
                continuously running ping, MTR, traceroute and tracetcp tests. The results are
                stored in Amazon CloudWatch Logs logs, and metric filters are applied to quickly visualize
                latency and packet loss statistics in a CloudWatch dashboard. 
Additional Information
The CloudWatch Logs data can be used for network troubleshooting and analysis of pattern/trends. Additionally, you can configure CloudWatch alarms with Amazon SNS notifications when packet loss and/or latency reach a threshold. The data can also be used when opening a case with Amazon Web Services Support, to help isolate an issue quickly and reduce time to resolution when investigating a network issue.
Note
 To clean up resources created by
                        AWSSupport-SetupIPMonitoringFromVPC, you can use the runbook
                        AWSSupport-TerminateIPMonitoringFromVPC . For more information,
                    see AWSSupport-TerminateIPMonitoringFromVPC .
                
Document type
Automation
Owner
Amazon
Platforms
Linux, macOS, Windows
Parameters
- 
                    AutomationAssumeRole Type: String Description: (Optional) The Amazon Resource Name (ARN) of the Amazon Identity and Access Management (IAM) role that allows Systems Manager Automation to perform the actions on your behalf. If no role is specified, Systems Manager Automation uses the permissions of the user that starts this runbook. 
- 
                    CloudWatchLogGroupNamePrefix Type: String Default: /AWSSupport-SetupIPMonitoringFromVPCDescription: (Optional) Prefix used for each CloudWatch log group created for the test results. 
- 
                    CloudWatchLogGroupRetentionInDays Type: String Valid values: 1 | 3 | 5 | 7 | 14 | 30 | 60 | 90 | 120 | 150 | 180 | 365 | 400 | 545 | 731 | 1827 | 3653 Default: 7 Description: (Optional) Number of days you want to keep the network monitoring results for. 
- 
                    InstanceType Type: String Valid values: t2.micro | t2.small | t2.medium | t2.large | t3.micro | t3.small | t3.medium | t3.large | t4g.micro | t4g.small | t4g.medium | t4g.large Default: t3.micro Description: (Optional) The EC2 instance type for the EC2Rescue instance. Recommended size: t3.micro. 
- 
                    SubnetId Type: String Description: (Required) The subnet ID for the monitor instance. Be aware that if you specify a private subnet, then you must make sure there is Internet access to allow the monitor instance to setup the test (meaning, install the CloudWatch Logs agent, interact with Systems Manager and CloudWatch). 
- 
                    TargetIPs Type: String Description: (Required) Comma separated list of IPv4s and/or IPv6s to monitor. No spaces allowed. Maximum size is 255 characters. Be aware that if you provide an invalid IP, then the automation will fail and rollback the test setup. 
- 
                    TestInstanceSecurityGroupId Type: String Description: (Optional) The security group ID for the test instance. If not specified, the automation creates one during the instance creation. Make sure the security group allows outbound access to the monitoring IPs. 
- 
                    TestInstanceProfileName Type: String Description: (Optional) The name of an existing IAM instance profile for the test instance. If not specified, the automation creates one during the instance creation. The role must have the following permissions: logs:CreateLogStream,logs:DescribeLogGroups,logs:DescribeLogStreams, andlogs:PutLogEventsand the Amazon Managed PolicyAmazonSSMManagedInstanceCore.
- 
                    TestInterval Type: String Description: (Optional) The number of minutes between test intervals. The default value is 1minute and the maximum is10minutes.
- 
                    RetainDashboardAndLogsOnDeletion Type: String Description: (Optional) Specify Falseto delete the Amazon CloudWatch dashboard and Logs when deleting the Amazon Amazon CloudFormation stack. The default value isTrue. By default, the dashboard and logs are retained and will need to be manually deleted when they are no longer needed.
Required IAM permissions
The AutomationAssumeRole parameter requires the following actions to
                 use the runbook successfully.
Warning
 It is recommended to pass TestInstanceProfileName parameter or
                    ensure security guardrails in place to prevent misuse of mutable IAM
                    permissions. 
It is recommended that the user who runs the automation have the AmazonSSMAutomationRole IAM managed policy attached. In addition, the user must have the following policy attached to their user account, group, or role:
If the TestInstanceProfileName parameter is provided, the following
                IAM permissions are not required to execute the runbook:
- 
                    iam:CreateRole 
- 
                    iam:CreateInstanceProfile 
- 
                    iam:DetachRolePolicy 
- 
                    iam:AttachRolePolicy 
- 
                    iam:AddRoleToInstanceProfile 
- 
                    iam:RemoveRoleFromInstanceProfile 
- 
                    iam:DeleteRole 
- 
                    iam:DeleteRolePolicy 
- 
                    iam:DeleteInstanceProfile 
Document Steps
- 
                    aws:executeAwsApi- describe the provided subnet.
- 
                    aws:branch- evaluate the TargetIPs input.(IPv6) If TargetIPs contains an IPv6: aws:assertAwsResourceProperty- check the provided subnet has an IPv6 pool associated
- 
                    aws:executeScript- get the architecture of instance type and public parameter path for latest Amazon Linux 2 AMI.
- 
                    aws:executeAwsApi- get the latest Amazon Linux 2 AMI from Parameter Store.
- 
                    aws:executeAwsApi- create a security group for the test in the subnet's VPC.(Cleanup) If the security group creation fails: aws:executeAwsApi- delete the security group created by the automation, if it exists.
- 
                    aws:executeAwsApi- allow all outbound traffic in the test security group.(Cleanup) If the security group egress rule creation fails: aws:executeAwsApi- delete the security group created by the automation, if it exists.
- 
                    aws:executeAwsApi- create an IAM role for the test EC2 instance(Cleanup) If the role creation fails: - 
                            aws:executeAwsApi- delete the IAM role created by the automation, if it exists.
- 
                            aws:executeAwsApi- delete the security group created by the automation, if it exists.
 
- 
                            
- 
                    aws:executeAwsApi- attach the AmazonSSMManagedInstanceCore managed policy(Cleanup) If the policy attachment fails: - 
                            aws:executeAwsApi- detach the AmazonSSMManagedInstanceCore managed policy from the role created by the automation, if attached.
- 
                            aws:executeAwsApi- delete the IAM role created by the automation.
- 
                            aws:executeAwsApi- delete the security group created by the automation, if it exists.
 
- 
                            
- 
                    aws:executeAwsApi- attach an inline policy to allow setting CloudWatch log group retentions and creating a CloudWatch dashboard(Cleanup) If the inline policy attachment fails: - 
                            aws:executeAwsApi- delete the CloudWatch inline policy from the role created by the automation, if created.
- 
                            aws:executeAwsApi- detach the AmazonSSMManagedInstanceCore managed policy from the role created by the automation.
- 
                            aws:executeAwsApi- delete the IAM role created by the automation.
- 
                            aws:executeAwsApi- delete the security group created by the automation, if it exists.
 
- 
                            
- 
                    aws:executeAwsApi- create an IAM instance profile.(Cleanup) If the instance profile creation fails: - 
                            aws:executeAwsApi- delete the IAM instance profile created by the automation, if it exists.
- 
                            aws:executeAwsApi- delete the CloudWatch inline policy from the role created by the automation.
- 
                            aws:executeAwsApi- delete the AmazonSSMManagedInstanceCore managed policy from the role created by the automation.
- 
                            aws:executeAwsApi- delete the IAM role created by the automation.
- 
                            aws:executeAwsApi- delete the security group created by the automation, if it exists.
 
- 
                            
- 
                    aws:executeAwsApi- associate the IAM instance profile to the IAM role.(Cleanup) If the instance profile and role association fails: - 
                            aws:executeAwsApi- remove the IAM instance profile from the role, if associated.
- 
                            aws:executeAwsApi- delete the IAM instance profile created by the automation.
- 
                            aws:executeAwsApi- delete the CloudWatch inline policy from the role created by the automation.
- 
                            aws:executeAwsApi- detach the AmazonSSMManagedInstanceCore managed policy from the role created by the automation.
- 
                            aws:executeAwsApi- delete the IAM role created by the automation.
- 
                            aws:executeAwsApi- delete the security group created by the automation, if it exists.
 
- 
                            
- 
                    aws:sleep- wait for the instance profile to become available.
- 
                    aws:runInstances- create the test instance in the specified subnet, and with the instance profile created earlier attached.(Cleanup) If the step fails: - 
                            aws:changeInstanceState- terminate the test instance.
- 
                            aws:executeAwsApi- remove the IAM instance profile from the role.
- 
                            aws:executeAwsApi- delete the IAM instance profile created by the automation.
- 
                            aws:executeAwsApi- delete the CloudWatch inline policy from the role created by the automation.
- 
                            aws:executeAwsApi- detach the AmazonSSMManagedInstanceCore managed policy from the role created by the automation.
- 
                            aws:executeAwsApi- delete the IAM role created by the automation.
- 
                            aws:executeAwsApi- delete the security group created by the automation, if it exists.
 
- 
                            
- 
                    aws:branch- evaluate the TargetIPs input.(IPv6) If TargetIPs contains an IPv6: aws:executeAwsApi- assign an IPv6 to the test instance.
- 
                    aws:waitForAwsResourceProperty- wait for the test instance to become a managed instance.(Cleanup) If the step fails: - 
                            aws:changeInstanceState- terminate the test instance.
- 
                            aws:executeAwsApi- remove the IAM instance profile from the role.
- 
                            aws:executeAwsApi- delete the IAM instance profile created by the automation.
- 
                            aws:executeAwsApi- delete the CloudWatch inline policy from the role created by the automation.
- 
                            aws:executeAwsApi- detach the AmazonSSMManagedInstanceCore managed policy from the role created by the automation.
- 
                            aws:executeAwsApi- delete the IAM role created by the automation.
- 
                            aws:executeAwsApi- delete the security group created by the automation, if it exists.
 
- 
                            
- 
                    aws:runCommand- install test pre-requisites:(Cleanup) If the step fails: - 
                            aws:changeInstanceState- terminate the test instance.
- 
                            aws:executeAwsApi- remove the IAM instance profile from the role.
- 
                            aws:executeAwsApi- delete the IAM instance profile created by the automation.
- 
                            aws:executeAwsApi- delete the CloudWatch inline policy from the role created by the automation.
- 
                            aws:executeAwsApi- detach the AmazonSSMManagedInstanceCore managed policy from the role created by the automation.
- 
                            aws:executeAwsApi- delete the IAM role created by the automation.
- 
                            aws:executeAwsApi- delete the security group created by the automation, if it exists.
 
- 
                            
- 
                    aws:runCommand- validate the provided IPs are syntactically correct IPv4 and/or IPv6 addresses:(Cleanup) If the step fails: - 
                            aws:changeInstanceState- terminate the test instance.
- 
                            aws:executeAwsApi- remove the IAM instance profile from the role.
- 
                            aws:executeAwsApi- delete the IAM instance profile created by the automation.
- 
                            aws:executeAwsApi- delete the CloudWatch inline policy from the role created by the automation.
- 
                            aws:executeAwsApi- detach the AmazonSSMManagedInstanceCore managed policy from the role created by the automation.
- 
                            aws:executeAwsApi- delete the IAM role created by the automation.
- 
                            aws:executeAwsApi- delete the security group created by the automation, if it exists.
 
- 
                            
- 
                    aws:runCommand- define the MTR test for each of the provided IPs.(Cleanup) If the step fails: - 
                            aws:changeInstanceState- terminate the test instance.
- 
                            aws:executeAwsApi- remove the IAM instance profile from the role.
- 
                            aws:executeAwsApi- delete the IAM instance profile created by the automation.
- 
                            aws:executeAwsApi- delete the CloudWatch inline policy from the role created by the automation.
- 
                            aws:executeAwsApi- detach the AmazonSSMManagedInstanceCore managed policy from the role created by the automation.
- 
                            aws:executeAwsApi- delete the IAM role created by the automation.
- 
                            aws:executeAwsApi- delete the security group created by the automation, if it exists.
 
- 
                            
- 
                    aws:runCommand- define the first ping test for each of the provided IPs.(Cleanup) If the step fails: - 
                            aws:changeInstanceState- terminate the test instance.
- 
                            aws:executeAwsApi- remove the IAM instance profile from the role.
- 
                            aws:executeAwsApi- delete the IAM instance profile created by the automation.
- 
                            aws:executeAwsApi- delete the CloudWatch inline policy from the role created by the automation.
- 
                            aws:executeAwsApi- detach the AmazonSSMManagedInstanceCore managed policy from the role created by the automation.
- 
                            aws:executeAwsApi- delete the IAM role created by the automation.
- 
                            aws:executeAwsApi- delete the security group created by the automation, if it exists.
 
- 
                            
- 
                    aws:runCommand- define the second ping test for each of the provided IPs.(Cleanup) If the step fails: - 
                            aws:changeInstanceState- terminate the test instance.
- 
                            aws:executeAwsApi- remove the IAM instance profile from the role.
- 
                            aws:executeAwsApi- delete the IAM instance profile created by the automation.
- 
                            aws:executeAwsApi- delete the CloudWatch inline policy from the role created by the automation.
- 
                            aws:executeAwsApi- detach the AmazonSSMManagedInstanceCore managed policy from the role created by the automation.
- 
                            aws:executeAwsApi- delete the IAM role created by the automation.
- 
                            aws:executeAwsApi- delete the security group created by the automation, if it exists.
 
- 
                            
- 
                    aws:runCommand- define the tracepath test for each of the provided IPs.(Cleanup) If the step fails: - 
                            aws:changeInstanceState- terminate the test instance.
- 
                            aws:executeAwsApi- remove the IAM instance profile from the role.
- 
                            aws:executeAwsApi- delete the IAM instance profile created by the automation.
- 
                            aws:executeAwsApi- delete the CloudWatch inline policy from the role created by the automation.
- 
                            aws:executeAwsApi- detach the AmazonSSMManagedInstanceCore managed policy from the role created by the automation.
- 
                            aws:executeAwsApi- delete the IAM role created by the automation.
- 
                            aws:executeAwsApi- delete the security group created by the automation, if it exists.
 
- 
                            
- 
                    aws:runCommand- define the traceroute test for each of the provided IPs.(Cleanup) If the step fails: - 
                            aws:changeInstanceState- terminate the test instance.
- 
                            aws:executeAwsApi- remove the IAM instance profile from the role.
- 
                            aws:executeAwsApi- delete the IAM instance profile created by the automation.
- 
                            aws:executeAwsApi- delete the CloudWatch inline policy from the role created by the automation.
- 
                            aws:executeAwsApi- detach the AmazonSSMManagedInstanceCore managed policy from the role created by the automation.
- 
                            aws:executeAwsApi- delete the IAM role created by the automation.
- 
                            aws:executeAwsApi- delete the security group created by the automation, if it exists.
 
- 
                            
- 
                    aws:runCommand- configure CloudWatch logs.(Cleanup) If the step fails: - 
                            aws:changeInstanceState- terminate the test instance.
- 
                            aws:executeAwsApi- remove the IAM instance profile from the role.
- 
                            aws:executeAwsApi- delete the IAM instance profile created by the automation.
- 
                            aws:executeAwsApi- delete the CloudWatch inline policy from the role created by the automation.
- 
                            aws:executeAwsApi- detach the AmazonSSMManagedInstanceCore managed policy from the role created by the automation.
- 
                            aws:executeAwsApi- delete the IAM role created by the automation.
- 
                            aws:executeAwsApi- delete the security group created by the automation, if it exists.
 
- 
                            
- 
                    aws:runCommand- schedule cronjobs to run each test every minute.(Cleanup) If the step fails: - 
                            aws:changeInstanceState- terminate the test instance.
- 
                            aws:executeAwsApi- remove the IAM instance profile from the role.
- 
                            aws:executeAwsApi- delete the IAM instance profile created by the automation.
- 
                            aws:executeAwsApi- delete the CloudWatch inline policy from the role created by the automation.
- 
                            aws:executeAwsApi- detach the AmazonSSMManagedInstanceCore managed policy from the role created by the automation.
- 
                            aws:executeAwsApi- delete the IAM role created by the automation.
- 
                            aws:executeAwsApi- delete the security group created by the automation, if it exists.
 
- 
                            
- 
                    aws:sleep- wait for the tests to generate some data.
- 
                    aws:runCommand- set the desired CloudWatch log group retentions.(Cleanup) If the step fails: - 
                            aws:changeInstanceState- terminate the test instance.
- 
                            aws:executeAwsApi- remove the IAM instance profile from the role.
- 
                            aws:executeAwsApi- delete the IAM instance profile created by the automation.
- 
                            aws:executeAwsApi- delete the CloudWatch inline policy from the role created by the automation.
- 
                            aws:executeAwsApi- detach the AmazonSSMManagedInstanceCore managed policy from the role created by the automation.
- 
                            aws:executeAwsApi- delete the IAM role created by the automation.
- 
                            aws:executeAwsApi- delete the security group created by the automation, if it exists.
 
- 
                            
- 
                    aws:runCommand- set the CloudWatch log group metric filters.(Cleanup) If the step fails: - 
                            aws:changeInstanceState- terminate the test instance.
- 
                            aws:executeAwsApi- remove the IAM instance profile from the role.
- 
                            aws:executeAwsApi- delete the IAM instance profile created by the automation.
- 
                            aws:executeAwsApi- delete the CloudWatch inline policy from the role created by the automation.
- 
                            aws:executeAwsApi- detach the AmazonSSMManagedInstanceCore managed policy from the role created by the automation.
- 
                            aws:executeAwsApi- delete the IAM role created by the automation.
- 
                            aws:executeAwsApi- delete the security group created by the automation, if it exists.
 
- 
                            
- 
                    aws:runCommand- create the CloudWatch dashboard.(Cleanup) If the step fails: - 
                            aws:executeAwsApi- delete the CloudWatch dashboard, if it exists.
- 
                            aws:changeInstanceState- terminate the test instance.
- 
                            aws:executeAwsApi- remove the IAM instance profile from the role.
- 
                            aws:executeAwsApi- delete the IAM instance profile created by the automation.
- 
                            aws:executeAwsApi- delete the CloudWatch inline policy from the role created by the automation.
- 
                            aws:executeAwsApi- detach the AmazonSSMManagedInstanceCore managed policy from the role created by the automation.
- 
                            aws:executeAwsApi- delete the IAM role created by the automation.
- 
                            aws:executeAwsApi- delete the security group created by the automation, if it exists.
 
- 
                            
Outputs
createCloudWatchDashboards.Output - the URL of the CloudWatch dashboard.
createManagedInstance.InstanceIds - the test instance ID.