参数化构建代码发布、pipeline流水线代码发布

jenkins  1.配置Java环境    2. /usr/local/tomcat/webapps目录下删除原有内容,放jenkins.war包    启动访问ip:8080/jenkins

安装基础环境

git

gitlab 192.168.222.123

jenkins  192.168.222.130

nginx   192.168.222.121

shell


jenkins主机写入脚本,并给予权限 chmod a+x /cron/control.sh

jenkins页面配置

gitlab主机写入脚本,并给予权限  chmod a+x /cron/update.sh

gitlab,nginx主机拉取代码库,创建文件index.html(代码存放)并提交

密码认证:1.gitlab和nginx的公钥上传到gitlab网页中

2.jenkins 主机执行  ssh-keygen
                                ssh-copy-id -i 192.168.222.121   可以自动化免密执行脚本
3.gitlab 主机执行 scp ~/.ssh/id_rsa.pub 192.168.222.121:/root/.ssh/

或jenkins主机执行 scp ~/.ssh/id_rsa 192.168.222.121:/root/.ssh 私钥拷贝到nginx主机


pipeline流水线代码发布

1.通过ansible 进行管理及相关备份 优点: 编辑简单、方便更改等等 比较难做到很好版本管理

2.通过jenkins pipeline + gitlab 方式进行 配置文件治理。    版本管理方便、回退方便、完全可以自动化发布    需要 知晓整个构建原理、以及根据实际业务需要编写 相关脚本、需要知识相对负载。

架构思路

git push 到gitlab >> 触发jenkins webhooks API >> 执行ansible

jenkins所需插件:在插件里面搜索pipeline ,凡是有pipeline的都安装,完成后,重启jenkins

pipeline {

    agent any

    environment {

        def GIT_NAME = "my-test1"

        def CODE_DIR = "/cron"

        def GIT_ADDR = "[email protected]:root/my-test1.git"

        def ANSIBLE_HOST_DIR = "/cron/ansible/hosts-nginx"

        def ANSIBLE_HOST_NAME = "nginx1"

    }

    stages {

        stage('Git') {

            steps {

                sh '/root/scripts/jenkins_pip_git_pull.sh $CODE_DIR $GIT_NAME $GIT_ADDR'

            }

        }

        stage('Ansible Git pull') {

            steps {

                sh 'ansible -i $ANSIBLE_HOST_DIR $ANSIBLE_HOST_NAME  -m shell -a "cd $CODE_DIR/$GIT_NAME;git pull"'

            }

        }

    }

}
在你的ansible机器上创建 jenkins_pip_git_pull.sh

#!/bin/bash

## Version:1.0​

GIT_DIR=$1

GIT_NAME=$2

GIT_ADDR=$3

#echo $GIT_DIR $GIT_NAME $GIT_ADDR

if [ -d ${GIT_DIR}/${GIT_NAME} ];then

       cd ${GIT_DIR}/${GIT_NAME}

       git pull

else

       cd ${GIT_DIR}

#       git clone ${GIT_ADDR}/${GIT_NAME}.git

       git clone ${GIT_ADDR}

fi

创建文件,脚本给权限,机器给公钥

你可能感兴趣的:(参数化构建代码发布、pipeline流水线代码发布)