k8s下的jenkins如何设置maven
关于k8s环境的jenkins集群
k8s下搭建了jenkins集群后,执行任务时会新建pod,任务完成后pod被销毁,架构如下图所示:
在k8s搭建jenkins集群的步骤请参照《》
关于jenkins构建maven
作为java开发者,用jenkins构建maven工程是常见的编译构建方式,当jenkins部署到kubernetes之上后,要做一些设置才能顺利编译构建;
实战简介
本次实战是在k8s的jenkins环境编译构建spring-cloud-alibaba这个开源的maven工程,涉及到的环境信息如下:
- kubernetes:1.15
- jenkins:2.190.2
- maven:3.6.3
- spring-cloud-alibaba:2.1.1.RELEASE
设置maven
如果您已经参考《》一文在kubernetes部署了jenkins,接下来要做的就是设置maven插件:
- 在设置页面进入"Global Tool Configuration",如下图:
- 新建一个Maven配置,如下图,名为mvn-3.6.3,版本选择3.6.3
- 点击底部的Save按钮保存配置,这样,在pipeline任务中就能跳过名称"mvn-3.6.3"使用此maven工具了;
关于maven的settings.xml
局域网内的nexus私有仓库是经常用到的,作用如下:
- 缓存中央仓库的jar,这样局域网内的开发者在运行maven工程时,所需jar是从nexus下载的,而不必去中央仓库下载,可节省下载时间;
- 自己做的二方库发布到nexus私有仓库,给局域网内的其他人使用;
通常是通过配置maven的settings.xml来访问nexus私有仓库的,因此,jenkins在构建maven项目时也要用到配置好的settings.xml文件,才能访问nexus私有仓库;
- 如果您想了解更多nexus的细节,请参考文章《》
设置maven的settings.xml
这是本文的重点,思路如下:
- 把settings.xml做成configmap;
- 挂载到执行任务的pod中;
- 执行jenkins的pipeline脚本中,执行mvn命令时指定使用挂载的settings.xml文件:
接下来是实现上述思路的操作:
- 准备好settings.xml文件,里面已配置好nexus私有仓库的信息,主要是server节点和mirror节点,参考下图:
- 将settings.xml上传到kubernetes环境,执行以下命令创建名为settings.xml的configmap:
kubectl create configmap settings.xml \
--from-file=settings.xml \
-n helm-jenkins
上述命令有以下两点需要注意:
a. from-file参数表示此configmap的内容来源,是当前目录下名为settings.xml的文件;
b. 此configmap的namespace名为helm-jenkins,这是jenkins所在的namespace;
- 在Configure System页面,找到Pod Templates的配置,增加一个Config Map Volume,如下图:
- Config Map名称填写settings.xml,挂载路径是/home/jenkins/settings,如下图:
- 点击底部的Save按钮保存设置;
- 经过了以上设置,执行pipeline任务时,pod的/home/jenkins/settings目录下就会有settings.xml文件,您只需指定使用此文件即可,mvn命令的-s参数就是用来指定settings.xml文件的,下图是一段pipeline脚本,可作为参考:
设置pod内存和CPU
执行任务的pod的内存如果太小,可能会导致maven或者gradle编译时报OutOfMemory错误,因此需要设置pod内存:
- 在Configure System页面,找到Pod Templates的配置,点击下图红框中的Advanced...按钮:
- 如下图红框所示,按照实际需求对CPU和内存进行调整,我这里设置了1G的内存:
- 点击底部的Save按钮保存设置;
输出构建结果
mavne工程编译构建成功后,想要得到构建结果可以有多种途径,这里提供一种参考:通过数据卷的方式将构建结果保存到到宿主机
- 在Configure System页面,找到Pod Templates的配置,如下图,添加卷选择Host Path Volume:
- 如下所示,主机路径填写/usr/local/jenkins_output,挂载路径填写/home/jenkins/jenkins_output,这样就把pod的文件夹映射到宿主机上了
- 注意:确保宿主机的/home/jenkins/jenkins_output有写权限
经过以上设置,jenkins环境现在可以顺利构建maven项目了,下一篇文章,会挑选一个热门开源项目来实战编译构建。
欢迎关注我的公众号:程序员欣宸
https://github.com/zq2599/blog_demos
k8s下的jenkins如何设置maven的更多相关文章
- Linux下的Jenkins+Tomcat+Maven+Git+Shell环境的搭建使用(jenkins自动化部署)【转】
jenkins自动化部署 目标:jenkins上点构建(也可以自动检查代码变化自动构建)>>>项目部署完成. 一.安装jenkins 1.下载jenkins 这里我选择的是war包安 ...
- Linux下的Jenkins+Tomcat+Maven+Git+Shell环境的搭建使用(jenkins自动化部署)
jenkins自动化部署 目标:jenkins上点构建(也可以自动检查代码变化自动构建)>>>项目部署完成. 一.安装jenkins 1.下载jenkins 这里我选择的是war包安 ...
- mac下设置maven环境
在mac系统下设置maven环境. 1.首先通过终端打开 .bash_profile 2.设置maven解压后的路径地址 环境变量设置如下: MAVEN_HOME .PATH 两个变量即可 3. ...
- Linux下的Jenkins+Tomcat+Maven+Gitlab+Shell环境的搭建使用(jenkins自动化部署)
jenkins自动化部署 目标:jenkins上点构建(也可以自动检查代码变化自动构建)>>>项目部署完成. 一.安装jenkins 1.下载jenkins 这里我选择的是war包安 ...
- windows10下设置Maven的本地仓库和阿里云的远程中央仓库
感谢原文作者:测试zhang 原文链接:https://www.jianshu.com/p/1782feee6eff 菜鸟:https://www.runoob.com/maven/ 1.设置Mave ...
- 使用Jenkins配置Git+Maven的自动化构建
Jenkins是一个开源的持续集成工具,应用Jenkins搭建持续集成环境,可以进行自动构建.自动编译和部署,非常方便. 在服务器比较少的情况下,Jenkins的优势并不明显,但是随着项目发展,服务器 ...
- jenkins+docker 持续构建非docker in docker jenkins docker svn maven
工欲善其事必先利其器,为了解脱程序员的,我们程序员本身发明了很多好用的工具,通过各种工具的组合来达到我们想要的结果 本文采用jenkins docker svn maven作为相关工具,项目sprin ...
- Jenkins Jenkins结合GIT Maven持续集成环境配置
Jenkins结合GIT Maven持续集成环境配置 by:授客 QQ:1033553122 安装Git插件 1 安装Git客户端 1 安装JAVA JDK及MAVEN 2 Jenkins JDK ...
- 使用jenkins构建一个maven项目
1.登陆到jenkins首页,创建项目-->选择maven-->输入项目名称-->选择项目类型 2.进入项目配置:{先写一下项目描述和设置下保留的历史构建,然后向下拉} 找到源吗管理 ...
随机推荐
- “网络巨轮”BGP的高级装备(增强配置)
引入 如下图在很多时候,BGP建立对等体的时候,要去建立大量的EBGP和IBGP对等体,IBGP还要全连接,这就给我们带来了大量重复的工作,路由表就会变得很庞大,区域内和区域之间就会很难管理,以下这些 ...
- seo排名顾问不仅仅是关键词排名
http://www.wocaoseo.com/thread-246-1-1.html SEO顾问是什么,应该做什么工作呢,是不是主要做关键词的优化推广呢?做seo顾问入门的人,或者想聘请seo顾问的 ...
- 手写区分PC还是手机移动端
区分首先要了解window.navigator 输出navigator appCodeName: "Mozilla" appName: "Netscape" a ...
- Apache Pulsar 社区周报:08-15 ~ 08-21
关于 Apache Pulsar Apache Pulsar 是 Apache 软件基金会顶级项目,是下一代云原生分布式消息流平台,集消息.存储.轻量化函数式计算为一体,采用计算与存储分离架构设计,支 ...
- Pulsar 联合 TiDB 推出大数据场景数据应用分析解决方案
方案概述 大数据时代,各类应用对消息解决方案的要求不仅仅是数据的流动,而是要在持续增长的服务和应用中传输海量数据,进行智能的处理和分析,帮助业务做出更加精准的决策. Pulsar 与 TiDB 联合解 ...
- NGINX 命令 重启 WINDOWS
最近系统更新比较频繁,web系统老是上新,因此在nginx这边经常需要重启或者刷新,做了一个批命令供参考. 1.鼠标右键-新建-一个.TXT文本文档:在里面输入NGINX重启的命令. 2.输入NGIN ...
- Kubernetes K8S之资源控制器Job和CronJob详解
Kubernetes的资源控制器Job和CronJob详解与示例 主机配置规划 服务器名称(hostname) 系统版本 配置 内网IP 外网IP(模拟) k8s-master CentOS7.7 2 ...
- Nginx 前端项目配置 包含二级目录和接口代理
Nginx是目前用的比较多的一个前端服务器 其优点是配置简单修改一下server就能用 并发性能比较好,具体怎么好就看这个吧 开撸 1.找到nginx (liunx系统,已安装) whereis ng ...
- java-对象引用和对象本身
示意图 应用场景 1.赋值 只有用新的对象本身直接赋值给对应引用,该对象引用的值会改变,因为对象引用指向的对象本身改变了. 2.方法入参 调用方法和被调用方法. 代码 import com.aliba ...
- springboot +jsp项目打包部署到华为云服务器
注:打包之前先保证你的项目本地运行没问题. 一.打包 打包有两种方式,打成jar包和打成war包.因为springboot有内置的服务器,所以选择打成jar包,这样云服务器就不用装tomcat了. 打 ...