Jenkins+pipeline+参数构建+人工干预确定
Jenkins+pipeline+参数构建+人工干预
实现了以下功能
1. 可以选择环境,单选;可以选择需要发布的项目,多选

2.发布过程可视化

3. 可以人工干预是否继续发布。
初始化配置需要很久,比如拉镜像这些事情,我可以提前操作。配置做好之后,等到下班时间,再进行发布操作。有时候会遇到,我初始化配置做好之后,测试通知还有变动。我可以人工干预,不进行继续发布。再次进行配置初始化后再发布。

4.查看日志,鼠标停留在蓝色进度图时,会自动出现Log提示按钮

5.点击Log,可以看日志。

6.点击日志里面的文字,可以看日志详细情况

7.日志详细情况

实现上述功能的步骤
1.安装启动Jenkins:我以容器的方式启动。
docker run -itd -p : -p : --name jenkins --privileged=true -m 1500M -v /data/jenkins_home/:/var/jenkins_home -v /usr/bin/dos2unix:/usr/bin/dos2unix -v /var/run/docker.sock:/var/run/docker.sock -v $(which docker):/usr/bin/docker -v /usr/lib64/libltdl.so.:/usr/lib/x86_64-linux-gnu/libltdl.so. -v /usr/share/zoneinfo/Asia/Shanghai:/etc/localtime -v /etc/timezone:/etc/timezone jenkins
2.安装插件:Extended Choice Parameter Plug-In 和 Pipeline
3.自己按照工作环境进行shell脚本编写。
初始化配置的脚本:
[root@cloud_250 shell]# cat init_configure_choice.sh
#!/bin/bash #对比文件,获取需要发布的文件
ID1=`git log -|grep commit|awk '{print $2}'`
ID2=`git log -|grep commit|awk '{print $2}'|tail -n `
echo "本次有变更的配置是:"
git diff ${ID1} ${ID2}|grep diff|grep "template/stack"|awk -F"/" '{print $5}' uptime=`date +%Y-%m-%d" "%H:%M`
echo "$WORKSPACE/template/pull_images_and_check_md5.sh"
sh $WORKSPACE/template/pull_images_and_check_md5.sh if [ "$?" != "" ];then
exit
fi
#调用Jenkins中选择的环境变量,注意要与Jenkins上配置的名称一样,我在截图中会框出来。
/usr/bin/python conf_to_stack.py --type=${Environment} cat $WORKSPACE/template/address.txt > $WORKSPACE/${Environment}/address.txt git add .
git status iplist_zyx_p="192.168...."
iplist_zyx="192.168.5......"
iplist_emp="192.168.5X.XX"
#根据环境名称确定ip列表,这个zyx,zyx_p是对应Jenkins中可以选择的环境参数选项。
if [ "${Environment}" = "zyx_p" ];then
iplist=$iplist_zyx_p
fi
if [ "${Environment}" = "emp" ];then
iplist=$iplist_emp
fi if [ "${Environment}" = "zyx" ];then
iplist=$iplist_zyx
fi #将更新内容同步到服务器,拉取镜像
for ip in $iplist;
do
echo $ip
ssh root@$ip "/usr/bin/rm -rf /data/git/${Environment}/*"
scp -r $WORKSPACE/${Environment}/ root@$ip:/data/git/
ssh root@$ip "cd /data/git/${Environment};/usr/bin/sh /data/git/${Environment}/pull_images.sh"
return=`ssh root@$ip "/usr/bin/cat /data/git/${Environment}/return"`
if [ "${return}" != "" ];then
exit $return
else
continue
fi
done
部署脚本:
[root@cloud_250 shell]# cat deploy_choice.sh
#!/bin/bash
#由于Jenkins提供的选择的多个项目名称会以“name1,name2,name3”的方式提供,我们需要进行字符串切割处理,去掉逗号,和双引号。
projectlist=`echo ${ProjectName} | sed -r 's/,/ /g'| sed -r 's/"/ /g'`
#根据环境进行判断,选择需要发布的服务器节点。
if [ "${Environment}" = "zyx_p" ];then
ipnode=192.168.x
fi if [ "${Environment}" = "zyx" ];then
ipnode=192.168.x
fi if [ "${Environment}" = "emp" ];then
ipnode=192.168.x
fi
#发布,ssh远程到服务器上进行启动服务
for NAME in ${projectlist};
do
ssh root@$ipnode "docker stack deploy -c /data/git/$Environment/stack_$NAME.yaml $NAME"
sleep 30s
done
3. Jenkins上创建一个pipeline的项目


红色框框,ProjectName 是会作为变量传给shell脚本的。check Boxes 类型是表示能选择多个项目。delimiter 填写 “,” 表示项目名称以逗号隔开。

value ,填写项目名称,并且以“,”隔开。

添加pipeline的脚本:

node {
stage('初始化配置 ') { // for display purposes
git 'git@192.168.0.75:/data/git/zyx_t'
sh "/var/jenkins_home/shell/init_configure_choice.sh" 调用初始化配置的shell脚本
}
}
#人工干预是否继续发布。
stage '确定是否发布'
input 'Do you approve deployment?'
#确定发布后,在进行部署
node{
stage('部署') {
sh "/var/jenkins_home/shell/deploy_choice.sh" 调用发布的shell脚本
}
}
Jenkins+pipeline+参数构建+人工干预确定的更多相关文章
- Jenkins Pipeline 参数详解
Pipeline 是什么 Jenkins Pipeline 实际上是基于 Groovy 实现的 CI/CD 领域特定语言(DSL),主要分为两类,一类叫做 Declarative Pipeline,一 ...
- 使用Jenkins pipeline流水线构建docker镜像和发布
新建一个pipeline job 选择Pipeline任务,然后进入配置页面. 对于Pipeline, Definition选择 "Pipeline script from SCM" ...
- Jenkins Pipeline+sonar构建质量平台
前提: Jenkins JDK 目录: 1.安装sonar插件:SonarQube Scanner for Jenkins 2.安装SonarQube 3.安装sonar-scanner ++++++ ...
- Jenkins Pipeline Job构建配置
1.创建pipeline job任务,新建任务>输入任务名称>选择“流水线”>点击[确定] 添加描述,This is my first test pipelin ...
- Jenkins pipeline job 根据参数动态获取触发事件的分支
此文需要有Jenkins pipeline job 的简单使用经验 场景 我们日常的测试函数, 一般是不能仅仅在本地跑的,还需要一个公共的跑测试的环境,作为合并新的PR的依据. 如果用Jenkins ...
- Jenkins + Pipeline 构建流水线发布
Jenkins + Pipeline 构建流水线发布 利用Jenkins的Pipeline配置发布流水线 参考: https://jenkins.io/doc/pipeline/tour/depl ...
- jenkins pipeline构建后返回构建结果给gitlab
jenkins pipeline构建后返回构建结果给gitlab 使用场景 gitlab 合并请求时要求管道任务必须成功,否则无法执行合并操作,又不想使用gitlab ci 工具. 实现方法 1.Ge ...
- jenkins pipeline构建项目
以前用的jenkins自由风格发布代码.界面丑陋,出现问题位置不够清晰.今天改进一下流程使用jenkins pipeline构建项目. 学习使我快乐 步骤一.安装pipeline插件 点击系统管理-& ...
- 【最新】Android使用jenkins全自动构建打包-Windows版本(Android,Jenkins,360加固,Email,QRcode,参数构建,蒲公英)
Android打包喝咖啡系列(Windows版) 这篇博客主要讲述的内容: 1.windows上部署Jenkins https://jenkins.io 2.基于SVN或Git https://git ...
随机推荐
- Java并发编程总结(一)Syncronized解析
Syncronized解析 作用: )确保线程互斥的访问同步代码 )保证共享变量的修改能够及时可见 )有效解决重排序问题. 用法: )修饰普通方法(锁是当前实例对象) )修饰静态方法(锁是当前对象的C ...
- 大型php网站性能和并发访问优化方案
网站性能优化对于大型网站来说非常重要,一个网站的访问打开速度影响着用户体验度,网站访问速度慢会造成高跳出率,小网站很好解决,那对于大型网站由于栏目多,图片和图像都比较庞大,那该怎么进行整体性能优化呢? ...
- PHP compact
1.函数的作用:将变量转成数组 2.函数的参数: @params string $varname1 @params string $varname2 ... @params array $varnam ...
- [Luogu1291][SHOI2002]百事世界杯之旅
题目描述 “……在2002年6月之前购买的百事任何饮料的瓶盖上都会有一个百事球星的名字.只要凑齐所有百事球星的名字,就可参加百事世界杯之旅的抽奖活动,获得球星背包,随声听,更克赴日韩观看世界杯.还不赶 ...
- postman简单介绍
- spark cdh5编译安装[spark-1.0.2 hadoop2.3.0 cdh5.1.0]
前提你得安装有Hadoop 我的版本hadoop2.3-cdh5.1.0 1.下载maven包 2.配置M2_HOME环境变量,配置maven 的bin目录到path路径 3.export MAVEN ...
- ESP32 开发之旅② Arduino For ESP32说明
授人以鱼不如授人以渔,目的不是为了教会你具体项目开发,而是学会学习的能力.希望大家分享给你周边需要的朋友或者同学,说不定大神成长之路有博哥的奠基石... QQ技术互动交流群:ESP8266&3 ...
- 基于 HTML5 + Canvas 实现楼宇自控系统
前言 楼宇自控是指楼宇中电力设备,如电梯.水泵.风机.空调等,其主要工作性质是强电驱动.通常这些设备是开放性的工作状态,也就是说没有形成一个闭环回路.只要接通电源,设备就在工作,至于工作状态.进程.能 ...
- 如何在 GitHub 的项目中创建一个分支呢?
如何在 GitHub 的项目中创建一个分支呢? 其实很简单啦,直接点击 Branch,然后在弹出的文本框中添加自己的 Branch Name 然后点击蓝色的Create branch就可以了,这样一来 ...
- webpack 4.x 初级学习记录
首先声明下,本人不擅长文字表达,文采不行,所以文章中文字较少,请看代码,初级学习,不足之处请多多指教 GitHub链接 看云kancloud [TOC] webpack 4.x 安装 首先需要在全局中 ...