如何访问云构建器中的私有Github存储库?

时间:2017-12-15 15:22:18

标签: go google-cloud-platform

我在Github,A和B上有两个私有存储库。两个都是Golang项目。项目A依赖于存储库B.我已将这两个存储库链接到Google源代码并同意权限。

Cloudbuild.yaml

 - name: 'gcr.io/cloud-builders/git'
   args: ['clone', 'https://source.developers.google.com/p/$PROJECT_ID/r/B']

从容器构建器记录

Starting Step #0
Step #0: Already have image (with digest): gcr.io/cloud-builders/git
Step #0: Cloning into 'B'...
Finished Step #0

...

Step #1: [0;33m[WARN]   [mUnable to checkout github.com/user/B
Step #1: [0;31m[ERROR]  [mUpdate failed for github.com/user/B: Unable to get repository: Cloning into '/builder/home/.glide/cache/src/B'...
Step #1: fatal: could not read Username for 'https://github.com': No such device or address
Step #1: : exit status 128

有没有人可以与容器构建器和googles拥有自己的源代码库一起工作?我不想使用云密钥管理服务'解决这个问题。

已经尝试过:https://github.com/GoogleCloudPlatform/cloud-builders/issues/44#issuecomment-325144047

1 个答案:

答案 0 :(得分:1)

我没有使用云构建的经验,但您应该使用ssh://而不是https://来克隆您的git存储库。然后你需要在repo中添加一个SSH密钥(在github中称为部署密钥,每个repo或你的用户帐户)并在克隆时使用相同的密钥(在Linux中通常足以将私钥文件放在的〜/ .ssh)。我想您可能找到的涉及Cloud KMS的解决方案会做同样的事情,但会安全地存储私钥。