kubernetes下jenkins实战maven项目编译构建

简介: 找个热门的开源项目(maven工程),在k8s环境下用jenkins构建

欢迎访问我的GitHub

这里分类和汇总了欣宸的全部原创(含配套源码): https://github.com/zq2599/blog_demos

关于kubernetes环境的jenkins集群

  • 在kubernetes环境部署的jenkins集群,执行任务时会新建pod,任务完成后pod被销毁,架构如下:

在这里插入图片描述

编译构建maven项目

  • 本文是《kubernetes下的jenkins如何设置maven》的续篇,前面已做好了maven相关的设置,今天找一个热门的开源maven项目,创建一个pipeline任务去编译这个maven项目,并且将结果输出到宿主机上;
  • 本文选择了spring-cloud-alibaba用来实战,这是个父子结构的maven工程;

环境信息

  • kubernetes:1.15
  • jenkins:2.190.2
  • maven:3.6.3
  • spring-cloud-alibaba:2.1.1.RELEASE

创建pipeline任务

  • 新建任务,点击下图红框:

在这里插入图片描述

  • 如下,输入任务名字,然后选择流水线

在这里插入图片描述

  • 以下是Pipeline脚本:
pipeline {
 agent {
 label 'my-jenkins-jenkins-slave'
 }
 tools {
 maven 'mvn-3.6.3'
 }
 stages {
 stage('Checkout') {
 steps {
 echo '从GitHub下载spring-cloud-alibaba工程的源码(2.1.1.RELEASE归档包)'
 sh 'wget https://github.com/alibaba/spring-cloud-alibaba/archive/v2.1.1.RELEASE.tar.gz'
 echo '下载结束,解压归档包'
 sh 'tar -zxf v2.1.1.RELEASE.tar.gz'
 }
 }
 stage('Build') {
 steps {
 echo '开始编译构建'
 sh 'cd spring-cloud-alibaba-2.1.1.RELEASE && mvn clean package -U -Dmaven.test.skip=true -Dmaven.javadoc.skip=true -s /home/jenkins/settings/settings.xml'

 }
 }
 stage('Save') {
 steps {
 echo '将构建结果保存到宿主机'
 sh 'cd spring-cloud-alibaba-2.1.1.RELEASE/spring-cloud-alibaba-nacos-discovery/target && cp ./*.jar /home/jenkins/jenkins_output/'
 echo '传送完毕'
 }
 }
 stage('Clean') {
 steps {
 echo '清理Maven工程'
 sh 'cd spring-cloud-alibaba-2.1.1.RELEASE && mvn clean'
 echo '清理完毕'
 }
 }
 }
}
  • 上述脚本有以下几点需要注意:

a. lable等于my-jenkins-jenkins-slave,这个要和Pod Templates设置中的标签列表保持一致,如下图红框所示:
在这里插入图片描述
b. 编译构建的命令是mvn clean package -U -Dmaven.test.skip=true -Dmaven.javadoc.skip=true -s /home/jenkins/settings/settings.xml,这里面使用了指定位置的settings.xml文件,该文件来自configmap的挂载,这样就用上了自定义的settings.xml,里面可以配置局域网的nexus信息;

c. 为了缩短编译构建时间,mvn命令中使用了参数-Dmaven.test.skip=true-Dmaven.javadoc.skip=true,分别用来跳过单元测试和文档生成;

d. 构建结果被复制到/home/jenkins/jenkinsoutput/,这个路径已经被映射到宿主机的/usr/local/jenkinsoutput/目录,因为只是演示,所以这里只复制了一个子工程的构建结果;

e. 清理阶段的mvn clean其实没什么意义,因为pod很快就会被销毁,这里只是个参考作用,如果有远程资源或者数据库相关的清理操作可以在此执行;

  • 点击底部的Save保存;

执行pipeline任务

  • 点击下图红框中的Build Now即可开始执行任务:

在这里插入图片描述

  • 如果局域网内部署了Nexus,并且在settings.xml中做了相关设置,只要Nexus中缓存过相关的jar,整个任务能在几分钟内完成,如下图:

在这里插入图片描述

  • 在任务完成之前,执行命令kubectl describe pod xxxxx -n helm-jenkins,以确定pod是在哪个宿主机上执行的,待任务结束后,去查看此机器的/usr/local/jenkins_output目录,可见构建结果已经复制过来了,如下:

在这里插入图片描述

  • 至此,实战完成,我们在kubernetes下的jenkins环境中,用pipeline任务成功的编译构建了开源项目spring-cloud-alibaba的源码,并取得了构建结果,这样的环境和pipeline只需做一些定制调整,就可以打造成符合自己要求的CI环境了,希望本文能带给您一些参考;

欢迎关注阿里云开发者社区博客:程序员欣宸

学习路上,你不孤单,欣宸原创一路相伴...
相关实践学习
容器服务Serverless版ACK Serverless 快速入门:在线魔方应用部署和监控
通过本实验,您将了解到容器服务Serverless版ACK Serverless 的基本产品能力,即可以实现快速部署一个在线魔方应用,并借助阿里云容器服务成熟的产品生态,实现在线应用的企业级监控,提升应用稳定性。
云原生实践公开课
课程大纲 开篇:如何学习并实践云原生技术 基础篇: 5 步上手 Kubernetes 进阶篇:生产环境下的 K8s 实践 相关的阿里云产品:容器服务 ACK 容器服务 Kubernetes 版(简称 ACK)提供高性能可伸缩的容器应用管理能力,支持企业级容器化应用的全生命周期管理。整合阿里云虚拟化、存储、网络和安全能力,打造云端最佳容器化应用运行环境。 了解产品详情: https://www.aliyun.com/product/kubernetes
相关文章
|
28天前
|
Java Maven
手把手教你搭建Maven项目
手把手教你搭建Maven项目
28 0
|
2月前
|
Java Maven
java修改当前项目的maven仓库地址为国内
修改当前项目的maven仓库地址为国内
|
3月前
|
Dubbo Java 应用服务中间件
微服务框架(十)Maven Archetype制作Dubbo项目原型
  此系列文章将会描述Java框架Spring Boot、服务治理框架Dubbo、应用容器引擎Docker,及使用Spring Boot集成Dubbo、Mybatis等开源框架,其中穿插着Spring Boot中日志切面等技术的实现,然后通过gitlab-CI以持续集成为Docker镜像。   本文为Maven Archetype的制作及使用,使用archetype插件制作Dubbo项目原型
|
3月前
|
前端开发 Java Maven
IEAD MAVEN创建springboot 项目
IEAD MAVEN创建springboot 项目
27 0
|
20天前
|
XML Java Shell
【深入浅出Maven开发实战】「入门教程系列」带你零基础学习和开发使用Maven开发工具实战指南(实战技术总结)(一)
【深入浅出Maven开发实战】「入门教程系列」带你零基础学习和开发使用Maven开发工具实战指南(实战技术总结)
69 1
|
3月前
|
Java API Maven
JFinal5+Jetty2009+IDEA2020+Java8的非Maven-Demo项目
JFinal5+Jetty2009+IDEA2020+Java8的非Maven-Demo项目
22 1
|
22天前
|
Java Maven 开发工具
maven导入项目出现Unable to import maven project: See logs for details
maven导入项目出现Unable to import maven project: See logs for details
11 0
maven导入项目出现Unable to import maven project: See logs for details
|
22天前
|
Java Maven
运行maven项目出现Error:java: JDK isn‘t specified for module ‘XXX‘
运行maven项目出现Error:java: JDK isn‘t specified for module ‘XXX‘
11 0
|
28天前
|
JavaScript Java 关系型数据库
实例!使用Idea创建SSM框架的Maven项目
实例!使用Idea创建SSM框架的Maven项目
31 0
|
30天前
|
jenkins Java 持续交付
详解如何使用Jenkins一键打包部署SpringBoot项目
详解如何使用Jenkins一键打包部署SpringBoot项目
54 0