Rancher pipeline 实践

Rancher 2.1针对CI/CD进行了新的升级,带来了更好用的pipeline,这篇文章针对Rancher 2.1版本,讲解如何使用Rancher pipeline来做SpringBoot工程的CI/CD.

演示代码工程准备

首先创建一个SpringBoot的demo工程,push到github上(演示代码工程地址:https://github.com/huangll99/demo)。

Rancher设置代码库

首先需要设置代码仓库的认证,使用github需要创建自己的app,获取Client ID和Client Secret.

在流水线模块选择设置代码库,选择认证&同步代码库,填入申请的Client ID和Client Secret.

然后启用你需要做CI/CD的代码库。

添加compile阶段

编辑步骤,使用maven镜像作为编译阶段的基础镜像。使用mvn clean package命令编译打包SpringBoot工程。

添加publish阶段

编辑步骤,将maven打包得到得可执行jar包,构建为docker镜像

dockerfile如下:

FROM 10.3.10.131:5000/gsafety/java:8

MAINTAINER huangll99@126.com
ADD target/demo-0.0.1-SNAPSHOT.jar /app.jar

EXPOSE 8080
ENTRYPOINT ["java","-Xmx300m","-Dserver.port=8080","-jar","app.jar"]

然后推送到镜像仓库,这里使用了自己内部部署得harbor镜像仓库。

添加deploy阶段

编辑步骤,部署刚刚构建好的镜像。

使用的deploy.yml如下:

apiVersion: extensions/v1beta1
kind: Deployment
metadata:
  name: demo-deployment
spec:
  replicas: 1
  template:
    metadata:
      labels:
        app: demo
        track: stable
    spec:
      containers:
      - name: demo
        image: 10.3.10.131:5000/gsafety/demo:v3
        ports:
        - containerPort: 8080

---
apiVersion: v1
kind: Service
metadata:
  name: demo-svc
spec:
  type: NodePort
  selector:
    app: demo
  ports:
  - protocol: TCP
    port: 8080
    targetPort: 8080

rancher的pileline会在代码工程里创建对应的配置文件.rancher-pipeline.yml

完整的pipeline配置文件如下:

stages:
- name: compile
  steps:
  - runScriptConfig:
      image: maven:v1
      shellScript: mvn clean package
- name: publish
  steps:
  - publishImageConfig:
      dockerfilePath: ./Dockerfile
      buildContext: .
      tag: gsafety/demo:v3
      pushRemote: true
      registry: 10.3.10.131:5000
    env:
      PLUGIN_DEBUG: "true"
      PLUGIN_INSECURE: "true"
- name: deploy
  steps:
  - applyYamlConfig:
      path: ./deployment.yaml
timeout: 60
branch:
  include:
  - master

从rancher的面板上看就是如下图所示:

posted @ 2018-11-02 15:21  huangll99  阅读(7013)  评论(2编辑  收藏  举报