• K8S环境不同JAVA版本Jenkins编译构建实战

    当前容器化已经非常普及,无论是应用还是运维工具,绝大部分都已经官方支持容器化。而随着容器化的到来,一些新的问题也随之到来。例如:我们如何用不同的JAVA版本来进行项目构建工作。

     

    背景需求

    如果一家公司开发是第三方外包的,往往会面临开发使用的语言不同,同一开发语言的版本不同,而要做到统一开发语言和版本几乎是不可能的。使用不同的开发语言比较容易实现,但是同一开发语言的不同版本还是碰到了问题。

    我遇到的问题是,指定了agent label为oepnjdk-16,但每次运行自动下载了oepnjdk-8,所以想使用不同JAVA版本的agent node节点去做编译工作在K8S环境下变的不那么容易

    这个问题不解决,开发这边就无法使用Jenkins去做编译构建发布。因此,这个问题必须尽快解决。下面我就介绍下我的整个解决问题的过程。

     

    解决问题过程

    一、问题现象

    在Jenkins file中配置为:

    agent { label ‘openjdk16’ }

    //添加一个暂停流水线步骤用于登录到pod中排查,否则启动的agent node用完会自动注销

    stage(“pause-01”){

    steps {

    input “Does the staging environment look ok?”

    }

    }

    运行后打印的环境变量为:

    K8S环境不同JAVA版本Jenkins编译构建实战

    可以从NODE_LABEL看到是openjdk-16,从JAVA_BASE_URL可以看到下载的是openjdk-8

    从K8S登录到agent node执行如下命令:

    # kubectl -n devops get pods

    NAME READY STATUS RESTARTS AGE

    devops-jenkins-jdk8-maven36-jx76q 2/2 Terminating 0 11s

    devops-jenkins-jdk8-maven36-qn6p1 2/2 Terminating 0 21s

    jenkins-0 1/1 Running 0 19d //jenkins主节点

    openjdk-16-hs0w6 2/2 Running 0 1s //单独起的openjdk-16

    # kubectl -n devops exec -it openjdk-16-hs0w6 sh

    kubectl exec [POD] [COMMAND] is DEPRECATED and will be removed in a future version. Use kubectl exec [POD] — [COMMAND] instead.

    Defaulting container name to openjdk-16.

    Use ‘kubectl describe pod/openjdk-16-hs0w6 -n devops’ to see all of the containers in this pod.

    sh-4.2# java -version

    openjdk version “16.0.1” 2021-04-20

    OpenJDK Runtime Environment AdoptOpenJDK-16.0.1+9 (build 16.0.1+9)

    OpenJDK 64-Bit Server VM AdoptOpenJDK-16.0.1+9 (build 16.0.1+9, mixed mode, sharing)

    我们可以看到内置的java版本确实是openjdk-16的。

    二、查找原因

    首先我先看看是不是在我的agent oepnjdk-16 Node上执行的。我做了如下操作:

    • 在Jenkins file中任意流水线步骤添加如下命令

    sh “mkdir aaa”

    • 运行查看是否在运行的根目录下有该文件夹经确认存在该文件夹

    既然是在agent上执行的,根据综合情况判断是jenkins默认使用openjdk-8来构建跟着maven版本走,并且根据下载地址可以确认版本。

    三、解决过程

    单独在配置中指定版本:

    • 在Jenkins控制台全局配置中添加:
    K8S环境不同JAVA版本Jenkins编译构建实战
    • 在jenkins file中指定该版本工具,并在流水线中打印下版本信息

    agent { label ‘openjdk16’ }

    tools {

    jdk ‘oepnjdk-16’

    }

    sh “java -version”

    运行结果如下:

    K8S环境不同JAVA版本Jenkins编译构建实战

    至此问题得以解决。

    总结

    所有的问题首先需要定位,然后基于它的运行原理去分析可能的原因。问题就很容易被解决。针对该问题后续如果有其它版本只需在全局配置增加并在jenkins file中指定即可。

    好处是可以在一个agent镜像下运行不同版本的jdk,坏处是每次都要下载jdk,所以建议把下载的jdk包放在内网,下载地址使用内网地址。如果要运行其它开发语言的不同版本解决方法也是一样的。

    云管理服务专家新钛云服 秦鸣原创

    «
    »
以专业成就每一位客户,让企业IT只为效果和安全买单

以专业成就每一位客户,让企业IT只为效果和安全买单