amazon-cloudformation - 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 deploy
or 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
是名字。他们是ID
s。如果您通过 a name
,它将覆盖其他所有内容。如果你不传递 a name
,它会logicalId
从你的ID
、 thestackId
和一个散列中构造一个 a 。所以用名字!
解决方案
如果您不为某些内容指定名称,CloudFormation 将根据堆栈名称和资源名称生成名称。他们会在结尾添加一些额外的内容,以确保它是独一无二的。
https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-name.html
推荐阅读
- javascript - EXT JS 使用列表显示使用表格的值。在表头中重复所有行
- json - jq:对象不能是 csv 格式,只能是数组
- python - 修改后无法将 makemigrations 应用于模型
- html - :valid ~ 标签不起作用,输入的 html 元素无效但按原样注册
- javascript - 将自定义文本添加到谷歌饼图中的值?
- c - 为什么将文本分配给指针会将内存位置存储到文本?
- wordpress - 禁用 WP 提要时产品提要出现 5XX 错误
- angular - 使用 asp.net Core 授权 Angular 的最佳方法是什么?
- ruby - 如何在数组中查找共享重复属性的元素
- ios - 如何获取最后一个单元格并从 api 加载更多数据