gpt4 book ai didi

aws-cloudformation - aws-cdk aws-cli cloudformation 在 arn 中生成额外字符

转载 作者:行者123 更新时间:2023-12-03 07:13:35 25 4
gpt4 key购买 nike

我正在使用 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部署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"
]
}

我没有在名称末尾看到额外的数字。是什么赋予了?它一定是 cloudformation 的一部分。

答案:

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

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));
}
}

我以为 ExampleQueueExampleTopic 是名称。它们是ID。如果您传递名称,它将覆盖其他所有内容。如果您不传递 name,它会根据您的 IDstackId 和哈希构造一个 ticalId 。所以使用名称!

最佳答案

如果您没有指定某个名称,CloudFormation 将根据堆栈名称和资源名称生成名称。他们会在其末尾添加一些额外内容以确保其独特。

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

关于aws-cloudformation - aws-cdk aws-cli cloudformation 在 arn 中生成额外字符,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59957128/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com