首页 > 解决方案 > aws-cdk aws-cli cloudformation 在 arn 中生成额外的字符

问题描述

我正在使用 aws-cdk 创建 cloudformation 模板,实际上只是 SNS 和 SQS。我的问题是生成的主题和队列的名称不是我在 yaml 文件中看到的。

这是 CDK 的 TypeScript:

export class TheQThingStack extends cdk.Stack {
  constructor(scope: cdk.App, id: string, props?: cdk.StackProps) {
    super(scope, id, props);
    const queue = new sqs.Queue(this, 'ExampleQueue');
    const topic = new sns.Topic(this, 'ExampleTopic');
    topic.addSubscription(new subs.SqsSubscription(queue));
  }
}

生成的yaml:

Resources:
  ExampleQueue4CEF454C:
    Type: AWS::SQS::Queue
    Metadata:
      aws:cdk:path: dev/ExampleQueue/Resource
  ExampleQueuePolicy3CE69BA4:
    Type: AWS::SQS::QueuePolicy
    Properties:
      PolicyDocument:
        Statement:
          - Action: sqs:SendMessage
            Condition:
              ArnEquals:
                aws:SourceArn:
                  Ref: ExampleTopic65117661
            Effect: Allow
            Principal:
              Service: sns.amazonaws.com
            Resource:
              Fn::GetAtt:
                - ExampleQueue4CEF454C
                - Arn
        Version: "2012-10-17"
      Queues:
        - Ref: ExampleQueue4CEF454C
    Metadata:
      aws:cdk:path: dev/ExampleQueue/Policy/Resource
  ExampleQueuedevExampleTopic2BB620969F483AE8:
    Type: AWS::SNS::Subscription
    Properties:
      Protocol: sqs
      TopicArn:
        Ref: ExampleTopic65117661
      Endpoint:
        Fn::GetAtt:
          - ExampleQueue4CEF454C
          - Arn
    Metadata:
      aws:cdk:path: dev/ExampleQueue/devExampleTopic2BB62096/Resource
  ExampleTopic65117661:
    Type: AWS::SNS::Topic
    Metadata:
      aws:cdk:path: dev/ExampleTopic/Resource
  CDKMetadata:
    Type: AWS::CDK::Metadata
    Properties:
      Modules: aws-cdk=1.22.0,@aws-cdk/aws-cloudwatch=1.22.0,@aws-cdk/aws-iam=1.22.0,@aws-cdk/aws-kms=1.22.0,@aws-cdk/aws-sns=1.22.0,@aws-cdk/aws-sns-subscriptions=1.22.0,@aws-cdk/aws-sqs=1.22.0,@aws-cdk/core=1.22.0,@aws-cdk/cx-api=1.22.0,@aws-cdk/region-info=1.22.0,jsii-runtime=node.js/v12.11.1

如果我运行cdk deployor aws cloudformation create-stack dev --template-body file://the-template.yaml,这些名称就会被破坏。

$ aws sqs list-queues                                                                                            {
    "QueueUrls": [
        "https://region.queue.amazonaws.com/SECRET/dev-ExampleQueue4CEF454C-J3YMCE8ER8LW"
    ]
}
$ aws sns list-topics                                                                                         
{
    "Topics": [
        {
            "TopicArn": "arn:aws:sns:region:SECRET:dev-ExampleTopic65117661-1HEC7UGNZNT9U"
        }
    ]
}

我知道名称后面的数字是路径的哈希值。dev-ExampleTopic65117661->65117661是哈希。

哪里1HEC7UGNZNT9U来的?!cloudformation 会生成它吗?我在代码中的任何地方都找不到它?提交后,该号码是由 AWS 创建的吗?为什么?

如果我做:

$ aws sqs create-queue --queue-name my-queue
{
    "QueueUrls": [
        "https://region.queue.amazonaws.com/SECRET/my_queue"
    ]
}

我没有得到名称末尾的额外数字。是什么赋予了?它一定是云形成的一部分。

回答:

我接受了下面的答案,这是一个代码示例:

export class TheQThingStack extends cdk.Stack {
  constructor(scope: cdk.App, id: string, props?: cdk.StackProps) {
    super(scope, id, props);
    const queue = new sqs.Queue(this, 'ExampleQueue', { queueName: `${id}-ExampleQueue` });
    const topic = new sns.Topic(this, 'ExampleTopic', { topicName: `${id}-ExampleTopic` });
    topic.addSubscription(new subs.SqsSubscription(queue));
  }
}

我想ExampleQueue并且ExampleTopic是名字。他们是IDs。如果您通过 a name,它将覆盖其他所有内容。如果你不传递 a name,它会logicalId从你的ID、 thestackId和一个散列中构造一个 a 。所以用名字!

标签: amazon-cloudformationaws-cliaws-cdk

解决方案


如果您不为某些内容指定名称,CloudFormation 将根据堆栈名称和资源名称生成名称。他们会在结尾添加一些额外的内容,以确保它是独一无二的。

https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-name.html


推荐阅读