Nec*_*vil 14 continuous-integration azure gitlab kubernetes azure-kubernetes
我们以前的基于GitLab的CI/CD使用Authenticated curl请求到特定的REST API端点,以触发将更新的容器重新部署到我们的服务,如果您使用类似于基于Kubernetes的部署,则此问题适合您.
我们在Azure AKS群集上运行生产站点/应用程序(基于Ghost博客).现在我们手动将更新的容器推送到私有ACR(Azure容器注册表),然后使用Kubectl从命令行进行更新.
话虽如此,我们之前使用Docker Cloud进行编排,并使用GitLab-Ci完全集成了我们的生产/登台服务.
GitLab-Ci集成是目标,而"为什么"背后是这个问题.
由于我们之前使用过Docker Cloud(doh,应该从一开始就使用K8),我们应该如何处理GitLab-Ci能够利用Secrets创建Docker Cloud CLI然后使用Docker Cloud API进行身份验证以触发操作的事实在我们的节点上(即用新容器重新部署等).
虽然我相信我们可以构建一个容器(由我们的GitLab-Ci运行器使用),其中包含Kubectl和Azure CLI,但我知道Kubernetes也有类似的(对于docker cloud)Rest API,可以在这里找到(https ://kubernetes.io/docs/tasks/access-application-cluster/access-cluster) - 特别是关于连接WITHOUT Kubectl的部分似乎是相关的(关于HTTP REST API的部分).
我的问题是任何连接到Azure(或可能是其他托管Kubernetes服务)的人:
您的Ci/CD服务器如何通过Kubernetes服务提供商的Management Server进行身份验证,然后您如何触发更新/重新部署更新的容器/服务?
如果您使用Kubernetes HTTP Rest API重新部署服务,那么您的想法特别有价值!
在我完成整个过程时会更新.
lmc*_*iro 35
我有同样的问题,如何将GitLab CI/CD与我的Azure AKS Kubernetes集群集成.我创建了这个问题是因为当我尝试将我的Kubernetes cluester信息添加到GitLab时出现了一些错误.
如何整合它们:
az login命令从CLI(您需要在PC上安装Azure CLI)连接到Azure帐户,然后执行此其他命令获取Kubernetes集群凭据:az aks get-credentials --resource-group <resource-group-name> --name <kubernetes-cluster-name>~/.kube/config文件,打开此文件,您必须在GitLab"添加Kubernetes集群"表单中填写的字段内容都在此.kube/config文件中这些是领域:
.kube/config文件中.server是.kube/config文件字段中的URL .certificate-authority-data中的.kube/config文件,但你必须为base64解码.解码后,它必须是这样的:
-----BEGIN CERTIFICATE-----
...
some base64 strings here
...
-----END CERTIFICATE-----
Run Code Online (Sandbox Code Playgroud)
token中的十六进制字符串.kube/config(它可能还需要基本64解码?).您需要使用属于具有集群管理员权限的帐户的令牌,因此GitLab可以使用它来验证和安装集群上的内容.实现这一目标的最简单方法是为GitLab创建一个新帐户:使用服务帐户定义创建一个YAML文件(在默认名称空间中创建一个gitlab服务帐户下可以看到此示例)并通过方式将其应用于您的集群的.kubectl apply -f serviceaccount.yml点击"保存"即可完成.您的GitLab项目现在必须连接到您的Kubernetes集群.
在您的部署作业中(在管道中),您将需要一些环境变量来使用该kubectl命令访问您的集群,以下是所有可用变量的列表:
https://docs.gitlab.com/ee/user/project/clusters/index.html#deployment-variables
要在部署作业中注入这些变量,有一些条件:
.gitlab-ci.yml)必须具有environment密钥(请参阅本示例中的第31行),并且环境名称必须匹配您在菜单"操作">"环境"中使用的名称.以下是一个包含三个阶段的.gitlab-ci.yml示例:
exit 0稍后改变它kubectl,复制.kube/config文件以便能够kubectl在集群中运行命令并执行a kubectl cluster-info以确保它正常工作.在我的项目中,我没有完成编写部署脚本来真正执行部署.但是这个kubectl cluster-info命令执行得很好.提示:要查看所有环境变量及其值(Jenkins有一个包含此视图的页面,GitLab CI没有),您可以env在部署阶段的脚本中执行该命令.调试工作有很大帮助.
| 归档时间: |
|
| 查看次数: |
4840 次 |
| 最近记录: |