关于k8s环境的jenkins集群

k8s下搭建了jenkins集群后,执行任务时会新建pod,任务完成后pod被销毁,架构如下图所示:

897e056082416f650fa110d2ade3a67b.png在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",如下图:

    8fe97ed3fedda722ff907a7d73f7fcc4.png
    • 新建一个Maven配置,如下图,名为mvn-3.6.3,版本选择3.6.3

      68e228cd710ff1debae9a9f50173f55d.png
    • 点击底部的Save按钮保存配置,这样,在pipeline任务中就能跳过名称"mvn-3.6.3"使用此maven工具了;

      关于maven的settings.xml

      局域网内的nexus私有仓库是经常用到的,作用如下:
    1. 缓存中央仓库的jar,这样局域网内的开发者在运行maven工程时,所需jar是从nexus下载的,而不必去中央仓库下载,可节省下载时间;
    2. 自己做的二方库发布到nexus私有仓库,给局域网内的其他人使用;

通常是通过配置maven的settings.xml来访问nexus私有仓库的,因此,jenkins在构建maven项目时也要用到配置好的settings.xml文件,才能访问nexus私有仓库;

  • 如果您想了解更多nexus的细节,请参考文章《》

    设置maven的settings.xml

    这是本文的重点,思路如下:
  1. 把settings.xml做成configmap;
  2. 挂载到执行任务的pod中;
  3. 执行jenkins的pipeline脚本中,执行mvn命令时指定使用挂载的settings.xml文件:

接下来是实现上述思路的操作:

  • 准备好settings.xml文件,里面已配置好nexus私有仓库的信息,主要是server节点和mirror节点,参考下图:

    043dda2c73fbe150eba9b2777b521ab5.png
  • 将settings.xml上传到kubernetes环境,执行以下命令创建名为settings.xml的configmap: ```shell 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,如下图:

    cdd4ded56e9b55bbfd5d9714dd49ae56.png
  • Config Map名称填写settings.xml,挂载路径是/home/jenkins/settings,如下图:

    aa07d928b2184e4f32d7a1c6aabc4f6a.png
  • 点击底部的Save按钮保存设置;

  • 经过了以上设置,执行pipeline任务时,pod的/home/jenkins/settings目录下就会有settings.xml文件,您只需指定使用此文件即可,mvn命令的-s参数就是用来指定settings.xml文件的,下图是一段pipeline脚本,可作为参考:

    ea838e55271f27185f0cf8c3076cb297.png

    设置pod内存和CPU

    执行任务的pod的内存如果太小,可能会导致maven或者gradle编译时报OutOfMemory错误,因此需要设置pod内存:

  • 在Configure System页面,找到Pod Templates的配置,点击下图红框中的Advanced...按钮:

    bab011890cd6962421c69bd7f8317018.png
  • 如下图红框所示,按照实际需求对CPU和内存进行调整,我这里设置了1G的内存:

    b44ef16b1b42e1d2aab973e77d0efddc.png
  • 点击底部的Save按钮保存设置;

    输出构建结果

    mavne工程编译构建成功后,想要得到构建结果可以有多种途径,这里提供一种参考:通过数据卷的方式将构建结果保存到到宿主机

  • 在Configure System页面,找到Pod Templates的配置,如下图,添加卷选择Host Path Volume:

    4a7bc246528eeb5f43fbb166043bce6b.png
  • 如下所示,主机路径填写/usr/local/jenkins_output,挂载路径填写/home/jenkins/jenkins_output,这样就把pod的文件夹映射到宿主机上了

  • 注意:确保宿主机的/home/jenkins/jenkins_output有写权限

经过以上设置,jenkins环境现在可以顺利构建maven项目了,下一篇文章,会挑选一个热门开源项目来实战编译构建。

欢迎关注我的公众号:程序员欣宸

https://github.com/zq2599/blog_demos

Logo

K8S/Kubernetes社区为您提供最前沿的新闻资讯和知识内容

更多推荐