首页 > 解决方案 > 在 AWS CloudFormation 的 DashboardBody 中使用 Fn::FindInMap

问题描述

我正在使用 CloudFormation 创建一个 AWS CloudWatch 仪表板,并尝试在 DashboardBody 正文中使用Fn::FindInMap 。但是,该值没有被成功替换。有人可以帮忙吗?

下面是我的代码:

Mappings:
  EnvSource:
    Dev:
      "SMSFailed": sns/us-east-1/XXX/DirectPublishToPhoneNumber/Failure
Resources: 
  MonitoringDashboard: 
    Type: "AWS::CloudWatch::Dashboard"
    Properties: 
      DashboardName:
        Monitoring-Test-Dashboard
      DashboardBody:
        !Sub "{\"widgets\":[{\"height\":6,\"width\":12,\"y\":1,\"x\":12,\"type\":\"log\",\"properties\":{\"query\":\"SOURCE 'Fn::FindInMap' : [ 'ABC', 'DomainParameters', 'DomainName'] | fields @timestamp, @message, delivery.providerResponse, status\\n| filter @message like //\\n|stats count(status) as ErrorCount by delivery.providerResponse\\n| sort @timestamp asc\",\"region\":\"us-east-1\",\"title\":\"SMS Failed\",\"view\":\"table\"}}]}"

输出: 在此处输入图像描述

标签: amazon-web-servicesamazon-cloudformationamazon-cloudwatch

解决方案


您可以使用以下列表形式Sub

Resources: 
  MonitoringDashboard: 
    Type: "AWS::CloudWatch::Dashboard"
    Properties: 
      DashboardName:
        Monitoring-Test-Dashboard
      DashboardBody:
        !Sub 
           - "{\"widgets\":[{\"height\":6,\"width\":12,\"y\":1,\"x\":12,\"type\":\"log\",\"properties\":{\"query\":\"SOURCE ${FindInMap} | fields @timestamp, @message, delivery.providerResponse, status\\n| filter @message like //\\n|stats count(status) as ErrorCount by delivery.providerResponse\\n| sort @timestamp asc\",\"region\":\"us-east-1\",\"title\":\"SMS Failed\",\"view\":\"table\"}}]}"
           - DomainName: !FindInMap [ 'ABC', 'DomainParameters', 'DomainName']

推荐阅读