Jenkins自动构建部署项目

2024-09-08 07:32

本文主要是介绍Jenkins自动构建部署项目,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1. 楔子

在实际开发中,经常需要编译、静态代码检查、自动化测试、打包、部署、启动等一连串重复机械的动作,浪费时间、而且容易出错,而Jenkins就是专门Continuous integration(CI)/ Continuous Deploy(CD)开源工具,本文简单介绍Jenkins的使用。

在线无安装免费试用Jenkins:http://www.jenkins.org.cn/test

2.jenkins介绍

Jenkins只是一个平台,真正运作的都是插件。这就是jenkins流行的原因,因为jenkins什么插件都有
Hudson是Jenkins的前身,是基于Java开发的一种持续集成工具,用于监控程序重复的工作,Hudson后来被收购,成为商业版。后来创始人又写了一个jenkins,jenkins在功能上远远超过hudson

官网:https://jenkins.io/
插件库:https://plugins.jenkins.io/

3.创建流水线

首先创建一个新的自由风格的流水线,是功能比较强大和自由的流水线方式。
在这里插入图片描述
填写流水线信息和构建结果保留策略:
在这里插入图片描述
配置代码管理,主要是拉取哪个目录的代码、放入哪个目录。
在这里插入图片描述
代码仓库结构为:
在这里插入图片描述
拉取到的效果为:(当前目录为workspace/Travel-dev-deploy Travel-dev-deploy为流水线项目名字)
在这里插入图片描述
可以配置流水线触发策略,比如定时,间隔或者cron表达式等:
在这里插入图片描述
执行gradle脚本完成构建、部署等。主要功能有gradle脚本完成。
在这里插入图片描述
一定要配置gradle脚本的目录,不然gradle的命令task找不到。
在这里插入图片描述
一个可用的部署脚本为:

    task deploy(dependsOn: distTar) {println("configDir------->" + System.getProperty("configDir"))def role = ""if (System.getProperty("configDir") == null || System.getProperty("configDir").isEmpty()) {role = "debug"}println "buildDir------>$buildDir"doLast {ssh.run {session(remotes.travle) {println "role" + role
//                    if (role.equals("debug")) {executeScript '''#!/bin/shcd /u01/SINO/SSP-Travel-Devbin/SSP-Travel stoppwdmv -f /u01/SINO/SSP-Travel-Dev/log /u01/SINO/log-devrm -rf /u01/SINO/SSP-Travel-Dev'''put from: "$buildDir/distributions/SSP-Travel-${version}.tar", into: '/u01/SINO/'execute "tar -xvf /u01/SINO/SSP-Travel-${version}.tar -C /u01/SINO/"execute "mv /u01/SINO/SSP-Travel-${version} /u01/SINO/SSP-Travel-Dev"execute "mv -f /u01/SINO/log-dev /u01/SINO/SSP-Travel-Dev/log"execute "rm -rf /u01/SINO/SSP-Travel-${version}.tar"executeScript '''#!/bin/shcd /u01/SINO/SSP-Travel-Devbin/SSP-Travel stopbin/SSP-Travel debug 5006'''}}}}ssh.settings {knownHosts = allowAnyHosts}remotes {travle {role('debug')host = '1.1.1.1'user = 'root'password = 'xxxxxxx'}}

归档打包部署完成的包:
在这里插入图片描述
构建成果文件在Jenkins上的位置如下,需要把这个文件拷贝归档。
在这里插入图片描述
采用匹配的方式,把所有符合规则的构建成果文件进行归档,效果如下:
在这里插入图片描述
配置邮件发送,构建成功或者失败给 特定的人 和 更改过代码的人发送邮件:

Default Content:默认邮件内容;这里是关键;我这里使用的是模板${SCRIPT, template="groovy-html-dev.template"};后面会讲;当然不想使用模板的话,可以通过使用jenkins自身提供的变量来自己定义;
在这里插入图片描述
下面一定要注意:
在这里插入图片描述
邮件模板采用groovy模板,官方给出了很多的模板(matrix模板、groovy模板):
在这里插入图片描述
本文采用的是Gradle的变成语言groovy模板,官方实例为:
https://github.com/jenkinsci/email-ext-plugin/blob/master/src/main/resources/hudson/plugins/emailext/templates/groovy-html.template

<STYLE>BODY, TABLE, TD, TH, P {font-family: Calibri, Verdana, Helvetica, sans serif;font-size: 12px;color: black;}.console {font-family: Courier New;}.filesChanged {width: 10%;padding-left: 10px;}.section {width: 100%;border: thin black dotted;}.td-title-main {color: white;font-size: 200%;padding-left: 5px;font-weight: bold;}.td-title {color: white;font-size: 120%;font-weight: bold;padding-left: 5px;text-transform: uppercase;}.td-title-tests {font-weight: bold;font-size: 120%;}.td-header-maven-module {font-weight: bold;font-size: 120%;    }.td-maven-artifact {padding-left: 5px;}.tr-title {background-color: <%= (build.result == null || build.result.toString() == 'SUCCESS') ? '#27AE60' : build.result.toString() == 'FAILURE' ? '#E74C3C' : '#f4e242' %>;}.test {padding-left: 20px;}.test-fixed {color: #27AE60;}.test-failed {color: #E74C3C;}
</STYLE>
<BODY><!-- BUILD RESULT --><table class="section"><tr class="tr-title"><td class="td-title-main" colspan=2>BUILD ${build.result ?: 'COMPLETED'}</td></tr><tr><td>URL:</td><td><A href="${rooturl}${build.url}">${rooturl}${build.url}</A></td></tr><tr><td>Project:</td><td>${project.name}</td></tr><tr><td>Date:</td><td>${it.timestampString}</td></tr><tr><td>Duration:</td><td>${build.durationString}</td></tr><tr><td>Cause:</td><td><% build.causes.each() { cause -> %> ${cause.shortDescription} <%  } %></td></tr></table><br/><!-- CHANGE SET --><%def changeSets = build.changeSetsif(changeSets != null) {def hadChanges = false %><table class="section"><tr class="tr-title"><td class="td-title" colspan="2">CHANGES</td></tr><% changeSets.each() { cs_list -> cs_list.each() { cs -> hadChanges = true %><tr><td>Revision<%= cs.metaClass.hasProperty('commitId') ? cs.commitId : cs.metaClass.hasProperty('revision') ? cs.revision : cs.metaClass.hasProperty('changeNumber') ? cs.changeNumber : "" %>by <B><%= cs.author %></B></td><td>${cs.msgAnnotated}</td></tr><% cs.affectedFiles.each() {p -> %><tr><td class="filesChanged">${p.editType.name}</td><td>${p.path}</td></tr><% }}}if ( !hadChanges ) { %><tr><td colspan="2">No Changes</td></tr><% } %></table><br/><% } %><!-- ARTIFACTS --><% def artifacts = build.artifactsif ( artifacts != null && artifacts.size() > 0 ) { %><table class="section"><tr class="tr-title"><td class="td-title">BUILD ARTIFACTS</td></tr><% artifacts.each() {f -> %><tr><td><a href="${rooturl}${build.url}artifact/${f}">${f}</a></td></tr><% } %></table><br/><% } %><!-- MAVEN ARTIFACTS --><%try {def mbuilds = build.moduleBuildsif ( mbuilds != null ) { %><table class="section"><tr class="tr-title"><td class="td-title">BUILD ARTIFACTS</td></tr><%try {mbuilds.each() {m -> %><tr><td class="td-header-maven-module">${m.key.displayName}</td></tr><%m.value.each() { mvnbld -> def artifactz = mvnbld.artifactsif ( artifactz != null && artifactz.size() > 0) { %><tr><td class="td-maven-artifact"><% artifactz.each() {f -> %><a href="${rooturl}${mvnbld.url}artifact/${f}">${f}</a><br/><% } %></td></tr><% }}}} catch(e) {// we don't do anything} %></table><br/><% }} catch(e) {// we don't do anything} %><!-- JUnit TEMPLATE --><%def junitResultList = it.JUnitTestResulttry {def cucumberTestResultAction = it.getAction("org.jenkinsci.plugins.cucumber.jsontestsupport.CucumberTestResultAction")junitResultList.add( cucumberTestResultAction.getResult() )} catch(e) {//cucumberTestResultAction not exist in this build}if ( junitResultList.size() > 0 ) { %><table class="section"><tr class="tr-title"><td class="td-title" colspan="5">${junitResultList.first().displayName}</td></tr><tr><td class="td-title-tests">Name</td><td class="td-title-tests">Failed</td><td class="td-title-tests">Passed</td><td class="td-title-tests">Skipped</td><td class="td-title-tests">Total</td></tr><% junitResultList.each {junitResult -> junitResult.getChildren().each {packageResult -> %><tr><td>${packageResult.getName()}</td><td>${packageResult.getFailCount()}</td><td>${packageResult.getPassCount()}</td><td>${packageResult.getSkipCount()}</td><td>${packageResult.getPassCount() + packageResult.getFailCount() + packageResult.getSkipCount()}</td></tr><% packageResult.getPassedTests().findAll({it.getStatus().toString() == "FIXED";}).each{test -> %><tr><td class="test test-fixed" colspan="5">${test.getFullName()} ${test.getStatus()}</td></tr><% } %><% packageResult.getFailedTests().sort({a,b -> a.getAge() <=> b.getAge()}).each{failed_test -> %><tr><td class="test test-failed" colspan="5">${failed_test.getFullName()} (Age: ${failed_test.getAge()})</td></tr><% }}} %></table><br/><% } %><!-- CONSOLE OUTPUT --><%if ( build.result == hudson.model.Result.FAILURE ) { %><table class="section" cellpadding="0" cellspacing="0"><tr class="tr-title"><td class="td-title">CONSOLE OUTPUT</td></tr><% 	build.getLog(100).each() {line -> %><tr><td class="console">${org.apache.commons.lang.StringEscapeUtils.escapeHtml(line)}</td></tr><% } %></table><br/><% } %>
</BODY>

模板需要在Jenkins的主目录下建立email-templates目录,把模板放入其中,如下所示:
在这里插入图片描述
可以测试下邮件效果:
在这里插入图片描述
邮件的最终效果如下:
在这里插入图片描述

4.邮件添加附件和附件正文

进行如下配置即可添加附件:
在这里插入图片描述
效果如下:
在这里插入图片描述
实现把附件的内容添加到邮件正文,需要使用groovy的邮件模板,采用groovy编程语言的优势进行文件的读取和显示:
在这里插入图片描述
在这里插入图片描述
结果如下:
在这里插入图片描述

5.认证,使用域账户登录

在这里插入图片描述

6.参考文献

  • jenkins 邮件配置之良心之作
  • Jenkins进阶系列之——01使用email-ext替换Jenkins的默认邮件通知
  • Jenkins自动构建部署项目到远程服务器上

这篇关于Jenkins自动构建部署项目的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1147495

相关文章

闲置电脑也能活出第二春?鲁大师AiNAS让你动动手指就能轻松部署

对于大多数人而言,在这个“数据爆炸”的时代或多或少都遇到过存储告急的情况,这使得“存储焦虑”不再是个别现象,而将会是随着软件的不断臃肿而越来越普遍的情况。从不少手机厂商都开始将存储上限提升至1TB可以见得,我们似乎正处在互联网信息飞速增长的阶段,对于存储的需求也将会不断扩大。对于苹果用户而言,这一问题愈发严峻,毕竟512GB和1TB版本的iPhone可不是人人都消费得起的,因此成熟的外置存储方案开

这15个Vue指令,让你的项目开发爽到爆

1. V-Hotkey 仓库地址: github.com/Dafrok/v-ho… Demo: 戳这里 https://dafrok.github.io/v-hotkey 安装: npm install --save v-hotkey 这个指令可以给组件绑定一个或多个快捷键。你想要通过按下 Escape 键后隐藏某个组件,按住 Control 和回车键再显示它吗?小菜一碟: <template

如何用Docker运行Django项目

本章教程,介绍如何用Docker创建一个Django,并运行能够访问。 一、拉取镜像 这里我们使用python3.11版本的docker镜像 docker pull python:3.11 二、运行容器 这里我们将容器内部的8080端口,映射到宿主机的80端口上。 docker run -itd --name python311 -p

嵌入式QT开发:构建高效智能的嵌入式系统

摘要: 本文深入探讨了嵌入式 QT 相关的各个方面。从 QT 框架的基础架构和核心概念出发,详细阐述了其在嵌入式环境中的优势与特点。文中分析了嵌入式 QT 的开发环境搭建过程,包括交叉编译工具链的配置等关键步骤。进一步探讨了嵌入式 QT 的界面设计与开发,涵盖了从基本控件的使用到复杂界面布局的构建。同时也深入研究了信号与槽机制在嵌入式系统中的应用,以及嵌入式 QT 与硬件设备的交互,包括输入输出设

阿里开源语音识别SenseVoiceWindows环境部署

SenseVoice介绍 SenseVoice 专注于高精度多语言语音识别、情感辨识和音频事件检测多语言识别: 采用超过 40 万小时数据训练,支持超过 50 种语言,识别效果上优于 Whisper 模型。富文本识别:具备优秀的情感识别,能够在测试数据上达到和超过目前最佳情感识别模型的效果。支持声音事件检测能力,支持音乐、掌声、笑声、哭声、咳嗽、喷嚏等多种常见人机交互事件进行检测。高效推

Retrieval-based-Voice-Conversion-WebUI模型构建指南

一、模型介绍 Retrieval-based-Voice-Conversion-WebUI(简称 RVC)模型是一个基于 VITS(Variational Inference with adversarial learning for end-to-end Text-to-Speech)的简单易用的语音转换框架。 具有以下特点 简单易用:RVC 模型通过简单易用的网页界面,使得用户无需深入了

在cscode中通过maven创建java项目

在cscode中创建java项目 可以通过博客完成maven的导入 建立maven项目 使用快捷键 Ctrl + Shift + P 建立一个 Maven 项目 1 Ctrl + Shift + P 打开输入框2 输入 "> java create"3 选择 maven4 选择 No Archetype5 输入 域名6 输入项目名称7 建立一个文件目录存放项目,文件名一般为项目名8 确定

Vue3项目开发——新闻发布管理系统(六)

文章目录 八、首页设计开发1、页面设计2、登录访问拦截实现3、用户基本信息显示①封装用户基本信息获取接口②用户基本信息存储③用户基本信息调用④用户基本信息动态渲染 4、退出功能实现①注册点击事件②添加退出功能③数据清理 5、代码下载 八、首页设计开发 登录成功后,系统就进入了首页。接下来,也就进行首页的开发了。 1、页面设计 系统页面主要分为三部分,左侧为系统的菜单栏,右侧

maven 编译构建可以执行的jar包

💝💝💝欢迎莅临我的博客,很高兴能够在这里和您见面!希望您在这里可以感受到一份轻松愉快的氛围,不仅可以获得有趣的内容和知识,也可以畅所欲言、分享您的想法和见解。 推荐:「stormsha的主页」👈,「stormsha的知识库」👈持续学习,不断总结,共同进步,为了踏实,做好当下事儿~ 专栏导航 Python系列: Python面试题合集,剑指大厂Git系列: Git操作技巧GO

基于51单片机的自动转向修复系统的设计与实现

文章目录 前言资料获取设计介绍功能介绍设计清单具体实现截图参考文献设计获取 前言 💗博主介绍:✌全网粉丝10W+,CSDN特邀作者、博客专家、CSDN新星计划导师,一名热衷于单片机技术探索与分享的博主、专注于 精通51/STM32/MSP430/AVR等单片机设计 主要对象是咱们电子相关专业的大学生,希望您们都共创辉煌!✌💗 👇🏻 精彩专栏 推荐订阅👇🏻 单片机