使用 terraform 脚本的 pubsub 主题和订阅之间的依赖关系

Posted

技术标签:

【中文标题】使用 terraform 脚本的 pubsub 主题和订阅之间的依赖关系【英文标题】:Dependency between pubsub topic and subscription using terraform script 【发布时间】:2021-09-28 14:17:37 【问题描述】:

我正在使用一个 terraform 脚本来创建 pub 子主题和订阅。如果订阅需要订阅由同一脚本创建的主题,有没有办法创建一个依赖项,以便 terraform 仅在创建主题后才尝试创建 pub/sub 订阅? 我的主文件如下所示:

  version = ""

  project = var.project_id
  region  = var.region
  zone    = var.zone

    
# module "Dataflow" 
 #source = "../modules/cloud-dataflow"
# 

module "PubSubTopic" 
 source = "../modules/pubsub_topic"


#module "PubSubSubscription" 
# source = "../modules/pubsub_subscription"
#

#module "CloudFunction" 
# source = "../modules/cloud-function"
#


【问题讨论】:

../modules/pubsub_topic 和 ../pubsub_subscription 里面有什么? 【参考方案1】:

Terraform 将尝试按照正确的顺序创建资源,但会回答您的问题以及您要查找的是模块依赖项“depends_on”。

例如,订阅模块只有在主题资源创建后才会创建。这样你应该在订阅模块上添加depends_on。

例子:

resource "aws_iam_policy_attachment" "example" 
  name       = "example"
  roles      = [aws_iam_role.example.name]
  policy_arn = aws_iam_policy.example.arn


module "uses-role" 
  # ...

  depends_on = [aws_iam_policy_attachment.example]

官方文档:https://www.terraform.io/docs/language/meta-arguments/depends_on.html

【讨论】:

【参考方案2】:

您可以在您的文件系统上使用这个 sn-p 创建一个简单的 pubsub 主题和订阅(只需为具有足够权限的服务帐户添加 .json):

provider "google" 
  credentials = "$file("account.json")" # Or use GOOGLE_APPLICATION_CREDENTIALS
  project     = "__your_project_id__"
  region      = "europe-west4" # Amsterdam


resource "google_pubsub_topic" "incoming_data" 
  name = "incoming-data"


resource "google_pubsub_subscription" "incoming_subs" 
  name = "Subscription_for_incoming_data"
  topic =  google_pubsub_topic.incoming_data.name

  # Time since Pubsub receives a message  to deletion.
  expiration_policy 
    ttl = "300000s"
  

  # Time from client reception to ACK
  message_retention_duration = "1200s"
  retain_acked_messages      = false
  enable_message_ordering    = false

要将订阅与 terraform 中的主题链接,您只需将其链接到:

topic = google_pubsub_topic.TERRAFORM_TOPIC.name

请注意 Google 对主题和订阅标识符的要求。如果它们无效,terraform plan 将通过,但您将获得 Error 400 : You have passed an invalid argument to the service

【讨论】:

以上是关于使用 terraform 脚本的 pubsub 主题和订阅之间的依赖关系的主要内容,如果未能解决你的问题,请参考以下文章

如何通过 terraform 使用服务帐户创建 google cloud pubsub pull 订阅?

terraform : 到 bigquery 的数据流 pubsubtopics

Terraform aws - 无法使用 terraform 脚本创建 AWS SFTP 服务器

创建谷歌云存储桶并使用相同的 terraform 脚本将 terraform 状态保存到其中?

使用 pubsub 推送触发器运行云功能

使用 terraform 配置 bigquery 数据集