我正在尝试开发我的自动化构建。
所以我们想要实现的是,每当开发人员将代码推送到新分支时,它将根据该分支名称在 Kubernetes 中创建一个新的命名空间。然后我将在该命名空间中进行所有部署。
创建命名空间的最佳方法是什么?
- name: 'gcr.io/cloud-builders/kubectl'
args:
- 'create'
- 'namespace'
- '${BRANCH_NAME}
当命名空间存在时会出现问题。所以,我打算改用文件,然后我可以通过
- name: 'gcr.io/cloud-builders/kubectl'
args:
- 'apply'
- '-f'
- 'filename.yaml'
这是文件名.yaml:
apiVersion: v1
kind: Namespace
metadata:
name: '${<BRANCH>}'
现在我的问题是,如果我采用第二种方法,如何传递这个分支名称。如果我采用第一种方法,我不知道如何检查命名空间是否存在。
请帮忙。
谢谢。