简介
Pipeline,简而言之,就是一套运行于Jenkins上的工作流框架,将原本独立运行于单个或者多个节点的任务连接起来,实现单个任务难以完成的复杂流程编排与可视化。
Pipeline是Jenkins2.X的最核心的特性,帮助Jenkins实现从CI到CD与DevOps的转变。
一,创建pipeline项目
二,清除部分历史构建
三,参数化构建
这里使用三个参数,分别对应是否拉取代码,项目名称,以及发版选项
四,编写pipeline脚本
选择pipeline script
编写pipeline脚本
def userMap def proMap = ['api': 'test_api', 'report':'test_report', 'job': 'test_job'] //定义项目字典 def deployMap = ['test-pipeline': 'test-pro.sh'] //定义发版脚本 def predeployMap = ['test-pipeline': 'test-pre.sh'] //定义预发布脚本 def rollbackMap = ['test-pipeline': 'test-pro-rollback.sh'] //定义回滚脚本 pipeline { agent any //parameters { string(defaultValue: '', name: 'PULL_FLAG', description: '请根据发布类型进行选择发布:\n1,输入-TESTING-发布-最新代码-到灰度\n2,输入-LATEST-发布-最新代码-到生产\n3,输入-版本号-发布-制定版本-到生产 ' ) } stages { stage('Checkout') { when { //判断是否要拉取代码 environment name: 'PULL_FLAG', value: 'yes' } steps { echo "${PULL_FLAG}" //拉取代码 checkout([$class: 'GitSCM', branches: [[name: '*/master']], doGenerateSubmoduleConfigurations: false, extensions: [[$class: 'CleanBeforeCheckout']], submoduleCfg: [], userRemoteConfigs: [[credentialsId: '797fddfc-d9d6-42a7-9a2b-38421a6963b0', url: 'git@git.test.com:test/test.git']]]) echo 'Checkout' } } stage('Build') { when { environment name: 'PULL_FLAG', value: 'yes' } steps { echo 'Building' // 使用maven进行构建 sh 'mvn clean install -Dmaven.test.skip=true -Pprod' } } stage('Push package') { when { environment name: 'PULL_FLAG', value: 'yes' } steps { echo 'push package' //上传war包至跳板机 sh 'sh /srv/shell/PAY_scp_pipe.sh ' } } stage('Deploy/Rollback') { steps { //定义发版密码校验,只有输入口令正确,才会发版到线上机器,密码保存在环境变量中 timeout(60) { script { userMap = input message: 'please input password', ok: 'ok', submitter: 'admin', parameters: [password(name:'password', defaultValue: '', description: '发布代码口令' )], submitterParameter: 'admin' if (userMap['password'].toString() == PASSWORD) { echo '密码正确' if (DEPLOY_FLAG == 'deploy') { echo "发版" sh "ssh test 'cd /data/faban && sh ${deployMap[env.JOB_NAME]} ${proMap[PROJECT]}'" }else if (DEPLOY_FLAG == 'predeploy') { echo '预发布' sh "ssh test 'cd /data/faban/pre-release && sh ${predeployMap[env.JOB_NAME]} ${proMap[PROJECT]}'" }else if (DEPLOY_FLAG == 'rollback') { echo '回滚' sh "ssh test 'cd /data/faban && sh ${rollbackMap[env.JOB_NAME]} ${proMap[PROJECT]}'" } }else { echo '密码错误' echo "${env.JOB_NAME}" } } } } } } post { always { echo 'This will always run' //发版结束后删除jenkins workspace下的临时目录 deleteDir() } success { echo 'This task is successful!' //记录日志信息 sh """ printf '%s %s %s %s %s %s' `date +'%F %H:%M:%S'` "${env.JOB_NAME}" "${proMap[PROJECT]}" "${DEPLOY_FLAG}" "success!\n" >> /srv/jk_logs/jk.log """ } } }
五,用到的shell脚本
1, 上传war包的脚本 /srv/shell/TEST_scp_pipe.sh
#!/bin/bash scp -r /srv/jenkins/workspace/test/test/api/target/api.war test:/data/faban/server_war/risk_api.war scp -r /srv/jenkins/workspace/test/test/report/target/report.war test:/data/faban/server_war/risk_report.war scp -r /srv/jenkins/workspace/test/test/job/target/job.war test:/data/faban/server_war/risk_job.war
2, 发版脚本(跳板机)
#!/bin/bash project="$1" java_config=/data/faban/java_config war_rebuild=/data/faban/war_rebuild if [ $# -lt 1 ]; then echo "usage: $0 <project>" exit 1 fi case "$project" in test_api) tomcat=/opt/tomcat_api server="test" ;; test_report) tomcat=/opt/tomcat_report server="test" ;; test_job) tomcat=/opt/tomcat_job server="test" ;; esac rm -rf $war_rebuild/* rsync -av /data/faban/server_war/$project.war /data/faban/war_rebuild cd $war_rebuild ssh $server "pkill -9 -f $tomcat" ssh $server "rm -rf $tomcat/webapps/ROOT; mv $tomcat/webapps/ROOT.war $tomcat/webapps/ROOT.war.bak" scp $project.war $server:$tomcat/webapps/ROOT.war ssh $server "chown www.www $tomcat/webapps/ROOT.war" ssh $server "su - www -c $tomcat/bin/startup.sh" sleep 5
3, 回滚脚本(跳板机)
#!/bin/bash project="$1" if [ $# -lt 1 ]; then echo "usage: $0 <project>" exit 1 fi case "$project" in test_api) tomcat=/opt/tomcat_api server="test" ;; test_report) tomcat=/opt/tomcat_report server="test" ;; test_job) tomcat=/opt/tomcat_job server="test" ;; esac ssh $server "pkill -9 -f $tomcat" ssh $server "rm -rf $tomcat/webapps/ROOT; mv $tomcat/webapps/ROOT.war.bak $tomcat/webapps/ROOT.war" ssh $server "su - www -c $tomcat/bin/startup.sh" sleep 5
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持小牛知识库。
本文向大家介绍使用gulp构建前端自动化的方法示例,包括了使用gulp构建前端自动化的方法示例的使用技巧和注意事项,需要的朋友参考一下 gulp是一个自动化构建工具,开发者可以用它来自动执行一些常见的任务。这里以我之前做的一个demo为例,简要介绍如何使用gulp实现前端工程自动化。 项目结构 其中src目录下表示的是项目的源代码,可以看到其中有less、js、html等,而dist目录则是保存的
想象一下没有自动化构建工具的场景 大部分的软件开发者都会面临下面的情形: 让IDE完成所有的工作. 用IDE来编码,导航到源代码、实现新特性、编译代码、重构代码、运行单元测试,一旦代码写完了,就按下编译按钮。一旦IDE提示没有编译错误测试通过,然后就把代码放入版本控制系统中以便与其他人分享。IDE是非常强大的工具,但是每个人都要安装一套标准的版本来执行上面介绍的任务,当你需要使用一个只有新版IDE
问题内容: 从历史上看,我曾使用Ant + Ivy或Maven来构建Java项目。我现在正在研究非基于XML的解决方案。 Gradle可以编译,修改和发布我的项目,几乎没有问题。 我可以对SBT做同样的事情吗?如果是这样,您能否提供一个使用sbt构建仅Java项目的简单示例。 问题答案: 是的,这完全有可能。完全不需要设置,一个小的build.sbt文件应该可以解决问题,例如: 并从命令行运行。
我在GGTS上有我的Grails项目。 我怎样才能最好地在周期性的基础上包括战争的自动(比如每周构建)构建。有插件吗?
上一节我们简要介绍了如何编写一个单机的To Do应用,接下来要打包部署成可执行的应用,我们需要编译源代码,生成的class文件需要打包到JAR文件中。JDK提供了javac 和jar工具帮助你实现这些任务,但是你也不想每次源代码发生变化时你都手动去执行这些任务吧。 Gradle插件能够自动化完成这些任务,插件引入了一些领域特有的观念,其中一个Gradle插件就是java插件,Java插件不仅仅只有
本文向大家介绍在Mac OS上安装使用Node.js的项目自动化构建工具Gulp,包括了在Mac OS上安装使用Node.js的项目自动化构建工具Gulp的使用技巧和注意事项,需要的朋友参考一下 安装 node.js 首先需要安装 node.js, 通常情况下,只需要到 Node.js 官网下载安装包安装就可以了。不过我可耻的失败了,弹出了如下错误: 于是我换成了 brew 大法: 安装 Gulp