我想使用地形为基础设施部署创建一个云构建触发器。我希望使用用户指定的“地形服务帐户”来创建和运行云构建触发器(即希望在云构建中实现服务帐户模拟概念)。“地形服务帐户”存在于另一个项目中,而不是云构建项目中。

执行的步骤:

  1. 手动创建两个项目-“种子项目”&;“cicd项目”。

  2. Terraform服务帐户和gcs桶(用于存储tf状态文件)是在“种子项目”中创建的。

  3. 云构建触发器需要在“cicd项目”中创建。

  4. 要使用,请在云构建触发器中使用用户指定的服务帐户,请遵循参考文章中的以下权限。

a) 禁用了“种子项目”上的组织策略“disableCrossProjectServiceAccountUsage”。

b) 将“roles/iam.serviceAccountTokenCreator”角色授予在“种子项目”中创建的terraform服务帐户上的项目“cicd项目”的云构建服务代理。

参考:https://cloud.google.com/build/docs/securing-builds/configure-user-specified-service-accounts

  1. 此外,由于我正在手动创建云构建触发器,因此我已授予用户电子邮件以下权限

a) “种子项目”的“所有者”角色。

b) “cicd项目”上的“所有者”角色。

c) “种子项目”中存在的地形服务帐户上的“服务帐户令牌创建者”角色。

错误:

创建生成触发器时,我收到以下错误:

未能创建触发器:generic::permission_denied:用户对指定的触发器服务帐户没有模拟权限:projects/ccid project/serviceAccounts/terraform-manual-sa@seed-project.iam.gserviceaccount.com

我无法理解实现这个用例所需的缺失权限。

任何帮助都将不胜感激。提前感谢。

使用另一个项目中存在的用户指定服务帐户创建云生成触发器的更多相关文章

  1. 具有资源id的连接(_E)

    我试图使用本地结构中的for_each来使用名称资源,例如:本地人我尝试访问它以创建network_id的方式,但无论如何,我都会收到以下错误:

  2. 使用另一个项目中存在的用户指定服务帐户创建云生成触发器

    我希望使用用户指定的“地形服务帐户”来创建和运行云构建触发器。Terraform服务帐户和gcs桶是在“种子项目”中创建的。a)禁用了“种子项目”上的组织策略“disableCrossProjectServiceAccountUsage”。c)“种子项目”中存在的地形服务帐户上的“服务帐户令牌创建者”角色。

  3. 我想在GCP中创建一个触发云函数的API,这是可能的吗?

    我正在学习谷歌云,并开始阅读各种不同工具的文档。我正在使用NodeJS+express创建一个restfulAPI。当我的一个端点启动时,我希望它获取从数据库接收的数据,在本例中是一个字符串值,并将其发送到云,在云函数中,只需反转字符串,然后向MongoDB数据库发送更新,以使用反转的字符串更新文档。这是概念的证明,没有什么疯狂的。不过,我想知道我是否走上了正确的轨道。我是否应该结合其他技术来做到这一点?

  4. 如何在云IDE VS代码上本地调试Flask应用程序?

    当程序运行到app.run时,它会卡住,而不启动服务器。尝试过的解决方案:调试设置为False。程序的行为与正常模式下执行的一样——Flask应用程序启动,但不会触发断点。添加默认Flask配置。正在尝试解决新问题:将“模块”:“烧瓶”更改为“程序”:“${file}”。

  5. 如何使用预先安装的地形提供程序构建docker图像

    我正在尝试构建一个docker映像,其中包含多个源repo所需的所有必要插件/提供程序,这样当自动terraformvalidate运行时,就不必下载大量冗余数据。然而,我认识到这提供了一个维护问题,因为有人可能会更新插件版本,这需要下载,因为docker图像不会包含它。问题我如何预下载所有提供程序和插件告诉CLI使用这些预下载的插件,还告诉它,如果它在本地找不到所需的内容,那么它可以转到网络以下是相关文件:.terraformrctflintDockerfile

  6. 将环境变量文件传递到GCP实例启动脚本的最佳方法

    我有一个环境变量文件,需要在应用程序启动时添加到应用程序目录中。由于明显的原因,我无法将其签入源代码管理,启动时将此文件传递给我的应用程序的最佳方法是什么?现在,我有一个负载平衡器连接到一个实例组,当一个新实例启动时,它遵循启动脚本,我无法确定如何通过启动脚本传递我的秘密。

  7. identityServer 4中的外部登录提供程序

    我已经实现了一个identityserver4服务,它运行良好。facebook和linkedin等外部登录功能正常。但当我将Google添加为外部登录提供商时,我遇到了这个错误。

  8. 我的GKE吊舱因错误而停止“;没有指定命令:CreateContainerError”;

    一切正常,节点在几个月内都很好,但突然一些pod停止,并出现错误我试图删除pod和节点,但问题相同。

  9. 得到“;找不到API密钥。请传递有效的API密钥“”;来自GCP Identity Platform,但密钥绝对正确

    v=ny92vcpOQFs...but我收到一个400错误,返回消息“找不到API密钥。请传递有效的API密钥”。提供API密钥的代码部分是从GCPIdentityPlatform接口直接复制的,我已经检查了多次。我不知道从哪里开始,所有的教程都认为这是理所当然的。最小复制如下所示,但如果我尝试使用firebase-ui-auth,则会得到相同的结果:

  10. dataproc hadoop/spark作业无法通过私有IP连接到cloudSQL

    如何从dataproc访问CloudSQLps:在完成了几乎所有的文档之后,在调试2天后寻求帮助。

随机推荐

  1. 如何扩展ATmega324PB微控制器的以下宏寄存器?

    我目前正在学习嵌入式,我有以下练习:展开以下宏寄存器:如果有人解决了这个问题,我将不胜感激,以便将来参考

  2. Python将ONNX运行时设置为返回张量而不是numpy数组

    在python中,我正在加载预定义的模型:然后我加载一些数据并运行它:到目前为止,它仍在正常工作,但我希望它默认返回Tensor列表,而不是numpy数组。我对ONNX和PyTorch都是新手,我觉得这是我在这里缺少的基本内容。这将使转换中的一些开销相同。

  3. 在macOS上的终端中使用Shell查找文件中的单词

    我有一个文本文件,其中有一行:我需要找到ID并将其提取到变量中。我想出了一个RexEx模式:但它似乎对我尝试过的任何东西都不起作用:grep、sed——不管怎样。我的一个尝试是:我为这样一个看似愚蠢的问题感到抱歉,但我在互联网上找不到任何东西:我在SO和SE上读了几十个类似的问题,并在谷歌上搜索了几个教程,但仍然无法找到答案。欢迎提供任何指导!

  4. react-chartjs-2甜甜圈图中只有标题未更新

    我正在使用react-chartjs-2在我的网站中实现甜甜圈图。下面是我用来呈现图表的代码。我将甜甜圈图的详细信息从父组件传递到子组件,所有道具都正确传递。当我在beforeDraw函数外部记录props.title时,它会记录正确的值,但当我在beforeDraw函数内部记录props.title时,它将记录标题的前一个值,从而呈现标题的前值。我在这里做错了什么?

  5. 如何在tkinter中使用Python生成器函数?

    生成器函数承诺使某些代码更易于编写。但我并不总是知道如何使用它们。假设我有一个斐波那契生成器函数fib(),我想要一个显示第一个结果的tkinter应用程序。当我点击“下一步”按钮时,它会显示第二个数字,依此类推。我如何构建应用程序来实现这一点?我可能需要在线程中运行生成器。但如何将其连接回GUI?

  6. 如何为每次提交将存储库历史记录拆分为一行?

    我正在尝试获取存储库的历史记录,但结果仅以单行文本的形式返回给我。

  7. 尝试在颤振项目上初始化Firebase时出错

    当尝试在我的颤振项目上初始化firebase时,我收到了这个错误有人知道我能做什么吗?应用程序分级Gradle插件Gradle项目颤振相关性我已经将firebase设置为Google文档已经在另一个模拟器上尝试过,已经尝试过创建一个全新的模拟器,已经在不同的设备上尝试过了,已经尝试了特定版本的firebase,已经尝试添加但没有任何效果,已经在youtube上看到了关于它的每一个视频,该应用程序在android和iOS两个平台上都抛出了这个错误

  8. 在unix中基于当前日期添加新列

    我试图在unix中基于时间戳列在最后一个单元格中添加一个状态列。我不确定如何继续。

  9. 麦克斯·蒙特利。我一直得到UncaughtReferenceError:当我在终端中写入node-v时,节点未定义

    如果这是您应该知道的,请确认:我已将所有shell更改为默认为zsh。当我在终端中写入node-v时,我一直收到“UncaughtReferenceError:nodeisnotdefined”。但它显示节点已安装。我是个新手,在这方面经验不足。

  10. 如何在前端单击按钮时调用后端中的函数?

    那么如何在后端添加一个新的端点,点击按钮调用这个函数。

返回
顶部