日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

CICD联动阿里云容器服务Kubernetes实践之Bamboo篇

發布時間:2024/8/23 编程问答 28 豆豆
生活随笔 收集整理的這篇文章主要介紹了 CICD联动阿里云容器服务Kubernetes实践之Bamboo篇 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

本文檔以構建一個 Java 軟件項目并部署到 阿里云容器服務的Kubernetes集群 為例說明如何使用 Bamboo在阿里云Kubernetes服務上運行Remote Agents并在agents上運行Build Plans。

1. 源碼項目

本示例中創建的GitHub源碼項目地址為:

https://github.com/AliyunContainerService/jenkins-demo.git

分支為:

bamboo

2. 在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.com

2.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:latest

3.2.4 kubectl部署應用到kubernetes


本示例中script body為:

sed -i 's#IMAGE_URL#registry.cn-hangzhou.aliyuncs.com/haoshuwei/bamboo-java-demo:latest#' ./*.yaml kubectl apply -f ./

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篇的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。