AWS SSM代理-使用aws cli,是否可以列出所有缺少SSM代理的AWS实例?

时间:2020-02-05 21:05:31

标签: amazon-web-services ssm aws-ssm

我需要审核大量的AWS账户,以确定哪些EC2实例缺少SSM代理。然后我需要输出所有这些实例及其标签。

运行aws ssm describe-instance-information列出了已安装代理且正在运行的所有实例,但未列出缺少代理或可能已关闭的系统的实例。

2 个答案:

答案 0 :(得分:1)

这将打印所有实例的列表,在管理实例的下方显示“成功”。

for instance in $(aws ec2 describe-instances --query 'Reservations[*].Instances[*].[InstanceId]' --output text )
do;
  managed=$(aws ssm describe-instance-information  --filters "Key=InstanceIds,Values=$instance" --query 'InstanceInformationList[*].[AssociationStatus]' --output text)
  echo "$instance  $managed";
done

要添加一组简单但格式不正确的标签,请用

替换回显行
if [[ "$managed" != "Success" ]]; then 
  managed="Fail"; 
fi
echo "$instance  $managed"
aws --profile GC-Staging ec2 describe-instances --instance-id $instance --query 'Reservations[*].Instances[*].[Tags[*].Value]' --output text 

答案 1 :(得分:0)

#!/bin/bash
for instance in $(aws ec2 describe-instances --query 'Reservations[*].Instances[*].[InstanceId]' --output text )
do
  managed=$(aws ssm describe-instance-information  --filters "Key=InstanceIds,Values=$instance" --query 'InstanceInformationList[*].[AssociationStatus]' --output text)
  if [[ "$managed" != "Success" ]]; then 
  managed="Not Managed"; 
fi
aws ec2 describe-instances --instance-id $instance --output text --query 'Reservations[*].Instances[*].[InstanceId, Placement.AvailabilityZone, [Tags[?Key==`Name`].Value] [0][0], [Tags[?Key==`App`].Value] [0][0], [Tags[?Key==`Product`].Value] [0][0], [Tags[?Key==`Team`].Value] [0][0] ]' 
echo "$managed"
done

保存并使脚本可执行,然后运行

script.sh > file.tsv

最后将其导入excel

相关问题