CICD联动阿里云容器服务Kubernetes实践之Bamboo篇
本文檔以構建一個 Java 軟件項目并部署到 阿里云容器服務的Kubernetes集群 為例說明如何使用 Bamboo在阿里云Kubernetes服務上運行Remote Agents并在agents上運行Build Plans。
1. 源碼項目
本示例中創建的GitHub源碼項目地址為:
https://github.com/AliyunContainerService/jenkins-demo.git分支為:
bamboo2. 在Kubernetes中部署Remote Agent
2.1 創建kaniko-docker-cfg secret
kaniko-docker-cfg secret用于Remote Agent上構建任務使用kaniko推送容器鏡像時的權限配置
kubectl -n bamboo create secret generic kaniko-docker-cfg --from-file=/root/.docker/config.json上面命令中的/root/.docker/config.json,是在linux服務器上使用root用戶通過以下命令生成的:
docker login registry.cn-hangzhou.aliyuncs.com2.2 創建serviceaccount bamboo以及clusterrolebinding用于kubectl部署應用到kubernetes集群的權限設置,創建bamboo-agent deployment
注意: 本示例中的clusterrolebinding為admin權限, 具體使用中可以根據自己的需要創建最小權限的serviceaccount
bamboo-agent.yaml:
--- apiVersion: v1 kind: ServiceAccount metadata:namespace: bambooname: bamboo--- apiVersion: rbac.authorization.k8s.io/v1 kind: ClusterRoleBinding metadata:name: bamboo-cluster-admin subjects:- kind: ServiceAccountname: bamboonamespace: bamboo roleRef:kind: ClusterRolename: cluster-adminapiGroup: rbac.authorization.k8s.io--- apiVersion: apps/v1beta2 kind: Deployment metadata:name: bamboo-agent spec:replicas: 1selector:matchLabels:app: bamboo-agenttemplate:metadata:labels:app: bamboo-agentspec:serviceAccountName: bamboocontainers:- name: bamboo-agentenv:- name: BAMBOO_SERVER_URLvalue: http://xx.xx.xx.xx:8085image: registry.cn-hangzhou.aliyuncs.com/haoshuwei/docker-bamboo-agent:v1imagePullPolicy: AlwaysvolumeMounts:- mountPath: /root/.docker/name: kaniko-docker-cfgvolumes:- name: kaniko-docker-cfgsecret:secretName: kaniko-docker-cfg kubectl -n bamboo apply -f bamboo-agent.yaml上述kubernetes資源創建完畢后等待remote agent完成初始化配置, 可以使用如下命令查看日志:
kubectl -n bamboo logs -f <bamboo agent pod name>Remote Agent注冊成功后可以在?Bamboo administration?->?Agents?->?Remote agents?下查看:
3. 配置一個build plan完成應用源碼拉取、編譯打包、容器鏡像打包和推送、應用部署的過程
3.1 創建一個build plan bamboo-ack-demo
3.2 配置Stages并添加Job
Job配置:
3.2.1 源碼拉取
3.2.2 mvn打包
3.2.3 kaniko打包和推送容器鏡像
本示例中script body為:
kaniko -f `pwd`/Dockerfile -c `pwd` --destination=registry.cn-hangzhou.aliyuncs.com/haoshuwei/bamboo-java-demo:latest3.2.4 kubectl部署應用到kubernetes
本示例中script body為:
3.3 運行build
3.4 訪問應用服務
[root@iZbp12i73koztp1cz75skaZ bamboo]# kubectl -n bamboo get svc NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE jenkins-java-demo LoadBalancer xx.xx.xx.xx xx.xx.xx.xx 80:32668/TCP 39m
原文鏈接
本文為云棲社區原創內容,未經允許不得轉載。
總結
以上是生活随笔為你收集整理的CICD联动阿里云容器服务Kubernetes实践之Bamboo篇的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Akka in Schedulerx2.
- 下一篇: 当60亿次攻击来袭,人机联合打了一场漂亮