将此代码添加(复制并粘贴)到您的Terraform代码中,以允许对公共 API 或网站进行未经身份验证的调用:
data "google_iam_policy" "noauth" {
binding {
role = "roles/run.invoker"
members = [
"allUsers",
]
}
}
resource "google_cloud_run_service_iam_policy" "noauth" {
location = google_cloud_run_service.default.location
project = google_cloud_run_service.default.project
service = google_cloud_run_service.default.name
policy_data = data.google_iam_policy.noauth.policy_data
}
所以这是完整的代码:
provider "google" {
credentials = file("myCredentials.json")
project = "myproject-214771"
region = "asia-northeast1"
}
resource "google_cloud_run_service" "default" {
name = "hello-world"
location = "asia-northeast1"
template {
spec {
containers {
image = "gcr.io/myproject-214771/hello-world:latest"
}
}
}
traffic {
percent = 100
latest_revision = true
}
}
data "google_iam_policy" "noauth" {
binding {
role = "roles/run.invoker"
members = [
"allUsers",
]
}
}
resource "google_cloud_run_service_iam_policy" "noauth" {
location = google_cloud_run_service.default.location
project = google_cloud_run_service.default.project
service = google_cloud_run_service.default.name
policy_data = data.google_iam_policy.noauth.policy_data
}
最后,您的 URL 可以正确显示您的网站:
data:image/s3,"s3://crabby-images/91959/91959e6f815916352d484ae2ed70195685dcf98f" alt="在此处输入图像描述"
此外,现在“身份验证”是“允许未经身份验证”:
data:image/s3,"s3://crabby-images/c62b7/c62b75f3c2171790a4d9a8919a2eae9e7b89105c" alt="在此处输入图像描述"
不要忘记将角色“Cloud Run Admin”添加到您的服务帐户:
data:image/s3,"s3://crabby-images/afad8/afad857bc93a0999b3554d422f4f6a2ad50d6471" alt="在此处输入图像描述"
否则,您不能允许对公共 API 或网站进行未经身份验证的调用,那么您将在下面收到此错误:
为 cloudrun 服务“v1/projects/myproject-214771/locations/asia-northeast1/services/hello-world”设置 IAM 策略时出错:googleapi:错误 403:资源 'projects/myproject- 上的权限'run.services.setIamPolicy'被拒绝214771/locations/asia-northeast1/services/hello-world'(或资源可能不存在)。
此外,使用以下这些角色,您不能允许对公共 API 或网站进行未经身份验证的调用:
data:image/s3,"s3://crabby-images/9e698/9e6984b46d3435cd5571945ac64de3027ac12164" alt="在此处输入图像描述"
只有角色“Cloud Run Admin”才能允许对公共 API 或网站进行未经身份验证的调用。
data:image/s3,"s3://crabby-images/afad8/afad857bc93a0999b3554d422f4f6a2ad50d6471" alt="在此处输入图像描述"