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

相关文章

k8s部署MongDB全过程

《k8s部署MongDB全过程》文章介绍了如何在Kubernetes集群中部署MongoDB,包括环境准备、创建Secret、创建服务和Deployment,并通过Robo3T工具测试连接... 目录一、环境准备1.1 环境说明1.2 创建 namespace1.3 创建mongdb账号/密码二、创建Sec

Java中的Opencv简介与开发环境部署方法

《Java中的Opencv简介与开发环境部署方法》OpenCV是一个开源的计算机视觉和图像处理库,提供了丰富的图像处理算法和工具,它支持多种图像处理和计算机视觉算法,可以用于物体识别与跟踪、图像分割与... 目录1.Opencv简介Opencv的应用2.Java使用OpenCV进行图像操作opencv安装j

Python 中 requests 与 aiohttp 在实际项目中的选择策略详解

《Python中requests与aiohttp在实际项目中的选择策略详解》本文主要介绍了Python爬虫开发中常用的两个库requests和aiohttp的使用方法及其区别,通过实际项目案... 目录一、requests 库二、aiohttp 库三、requests 和 aiohttp 的比较四、requ

SpringBoot项目启动后自动加载系统配置的多种实现方式

《SpringBoot项目启动后自动加载系统配置的多种实现方式》:本文主要介绍SpringBoot项目启动后自动加载系统配置的多种实现方式,并通过代码示例讲解的非常详细,对大家的学习或工作有一定的... 目录1. 使用 CommandLineRunner实现方式:2. 使用 ApplicationRunne

将Python应用部署到生产环境的小技巧分享

《将Python应用部署到生产环境的小技巧分享》文章主要讲述了在将Python应用程序部署到生产环境之前,需要进行的准备工作和最佳实践,包括心态调整、代码审查、测试覆盖率提升、配置文件优化、日志记录完... 目录部署前夜:从开发到生产的心理准备与检查清单环境搭建:打造稳固的应用运行平台自动化流水线:让部署像

使用IntelliJ IDEA创建简单的Java Web项目完整步骤

《使用IntelliJIDEA创建简单的JavaWeb项目完整步骤》:本文主要介绍如何使用IntelliJIDEA创建一个简单的JavaWeb项目,实现登录、注册和查看用户列表功能,使用Se... 目录前置准备项目功能实现步骤1. 创建项目2. 配置 Tomcat3. 项目文件结构4. 创建数据库和表5.

Python项目打包部署到服务器的实现

《Python项目打包部署到服务器的实现》本文主要介绍了PyCharm和Ubuntu服务器部署Python项目,包括打包、上传、安装和设置自启动服务的步骤,具有一定的参考价值,感兴趣的可以了解一下... 目录一、准备工作二、项目打包三、部署到服务器四、设置服务自启动一、准备工作开发环境:本文以PyChar

多模块的springboot项目发布指定模块的脚本方式

《多模块的springboot项目发布指定模块的脚本方式》该文章主要介绍了如何在多模块的SpringBoot项目中发布指定模块的脚本,作者原先的脚本会清理并编译所有模块,导致发布时间过长,通过简化脚本... 目录多模块的springboot项目发布指定模块的脚本1、不计成本地全部发布2、指定模块发布总结多模

SpringBoot项目删除Bean或者不加载Bean的问题解决

《SpringBoot项目删除Bean或者不加载Bean的问题解决》文章介绍了在SpringBoot项目中如何使用@ComponentScan注解和自定义过滤器实现不加载某些Bean的方法,本文通过实... 使用@ComponentScan注解中的@ComponentScan.Filter标记不加载。@C

centos7基于keepalived+nginx部署k8s1.26.0高可用集群

《centos7基于keepalived+nginx部署k8s1.26.0高可用集群》Kubernetes是一个开源的容器编排平台,用于自动化地部署、扩展和管理容器化应用程序,在生产环境中,为了确保集... 目录一、初始化(所有节点都执行)二、安装containerd(所有节点都执行)三、安装docker-