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 方式进行 配置文件治理。 版本管理方便、回退方便、完全可以自动化发布 需要 知晓整个构建原理、以及根据实际业务需要编写 相关脚本、需要知识相对负载。
架构思路
jenkins所需插件:在插件里面搜索pipeline ,凡是有pipeline的都安装,完成后,重启jenkins
pipeline {
agent any
environment {
def GIT_NAME = "my-test1"
def CODE_DIR = "/cron"
def GIT_ADDR = "git@10.3.138.30: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
创建文件,脚本给权限,机器给公钥