kubernetes實戰-交付dubbo服務到k8s集群(四)使用blue ocean流水線構建dubbo-demo-service


使用jenkins創建一個新的項目:dubbo-demo,選擇流水線構建

 

 勾選保存構建歷史和指定項目為參數化構建項目:

 

 

添加構建參數:以下配置項,是王導根據多年生產經驗總結出來的甩鍋大法

 

除了base_image和maven是choice parameter,其他都是string parameter

添加完成后,效果如圖:

 

 編寫pipeline:仔細查看這個pipeline,里面都是我們上面編寫的參數。

pipeline {
  agent any 
    stages {
      stage('pull') { //get project code from repo 
        steps {
          sh "git clone ${params.git_repo} ${params.app_name}/${env.BUILD_NUMBER} && cd ${params.app_name}/${env.BUILD_NUMBER} && git checkout ${params.git_ver}"
        }
      }
      stage('build') { //exec mvn cmd
        steps {
          sh "cd ${params.app_name}/${env.BUILD_NUMBER}  && /var/jenkins_home/maven-${params.maven}/bin/${params.mvn_cmd}"
        }
      }
      stage('package') { //move jar file into project_dir
        steps {
          sh "cd ${params.app_name}/${env.BUILD_NUMBER} && cd ${params.target_dir} && mkdir project_dir && mv *.jar ./project_dir"
        }
      }
      stage('image') { //build image and push to registry
        steps {
          writeFile file: "${params.app_name}/${env.BUILD_NUMBER}/Dockerfile", text: """FROM harbor.od.com/${params.base_image}
ADD ${params.target_dir}/project_dir /opt/project_dir"""
          sh "cd  ${params.app_name}/${env.BUILD_NUMBER} && docker build -t harbor.od.com/${params.image_name}:${params.git_ver}_${params.add_tag} . && docker push harbor.od.com/${params.image_name}:${params.git_ver}_${params.add_tag}"
        }
      }
    }
}

 

 

 完成第一次構建:填寫我們剛才配置的參數化構建參數:

 

 

填寫完以后執行bulid:第一次構建需要下載很多依賴包,時間很長,抽根煙,喝杯茶~

 

 經過漫長的等待后,已經構建完成了,可以點擊open blue ocean 查看構建歷史及過程:

 

 檢查harbor是否已經有這版鏡像:

 

 

已經有了,接下來交付dubbo-demo-service服務到k8s:

准備k8s資源配置清單:7-200  紅色部分,需要根據自己構建鏡像的tag來進行修改

# mkdir /data/k8s-yaml/dubbo-server/
# cd /data/k8s-yaml/dubbo-server
# vi dp.yaml
kind: Deployment
apiVersion: extensions/v1beta1
metadata:
  name: dubbo-demo-service
  namespace: app
  labels: 
    name: dubbo-demo-service
spec:
  replicas: 1
  selector:
    matchLabels: 
      name: dubbo-demo-service
  template:
    metadata:
      labels: 
        app: dubbo-demo-service
        name: dubbo-demo-service
    spec:
      containers:
      - name: dubbo-demo-service
        image: harbor.od.com/app/dubbo-demo-service:master_191201_1200
        ports:
        - containerPort: 20880
          protocol: TCP
        env:
        - name: JAR_BALL
          value: dubbo-server.jar
        imagePullPolicy: IfNotPresent
      imagePullSecrets:
      - name: harbor
      restartPolicy: Always
      terminationGracePeriodSeconds: 30
      securityContext: 
        runAsUser: 0
      schedulerName: default-scheduler
  strategy:
    type: RollingUpdate
    rollingUpdate: 
      maxUnavailable: 1
      maxSurge: 1
  revisionHistoryLimit: 7
  progressDeadlineSeconds: 600

由於我們使用的harbor私有鏡像的項目是app,是個私有項目,所以需要創建secret資源:

創建 app命名空間:

# kubectl create ns app

創建secret資源:

# kubectl create secret docker-registry harbor --docker-server=harbor.od.com --docker-username=admin --docker-password=Harbor12345 -n app

應用資源配置文件:

# kubectl apply -f http://k8s-yaml.od.com/dubbo-server/dp.yaml

檢查pod是否創建:

# kubectl get pod -n app

 

 檢查是否啟動成功:

# kubectl logs dubbo-demo-service-77b687c6f8-v556v -n app

 

 檢查dubbo-server服務是否已經注冊到了zookeeper:

# sh /opt/zookeeper/bin/zkCli.sh
# ls /
# ls /dubbo

 

 

至此,dubbo-demo-service就已經交付到k8s中了。

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM