发布时间:2018-11-23 已阅读:次
jenkins是一个开源软件项目,是基于java开发的一种持续集成工具,用于监控持续重复的工作,旨在提供一个开放易用的软件平台,使软件的持续集成变成可能。
主要用于:
jenkins是龙芯在进行jvm测试时用到的重要工具,在龙芯openjdk的研发过程中,会使用jenkins对相关源码进行周期性的自动编译构建和规模化测试,以验证研发效果和发现产品中的问题。除此之外,还会对社区的代码以及相关第三方库进行周期性的自动构建和自动测试,以监测这些软件的最新代码在龙芯平台上的正确性。
在早期,龙芯jvm的jenkins测试服务是部署在x86服务器上的,随着龙芯openjdk以及相关软硬件产品的多次迭代和不断完善,龙芯平台已逐渐成熟,龙芯jvm组作为龙芯openjdk的第一用户,有必要将自己的产品运用到实践中,及时发现问题。因此,今年下半年龙芯jvm组将整个jenkins自动测试系统从x86平台迁移至龙芯平台,以检验龙芯平台在jenkins这个实际应用中能否经受得起考验。
cpu | os | jdk | |
x86平台 | intel(r) xeon(r) cpu e5506 | centos 6.10 | openjdk 8u181 |
龙芯平台 | 3b3000四路 | loongnix 1.0 | 龙芯openjdk 8 |
由于jenkins是一个java程序,具有跨平台的优点,因此向龙芯平台迁移jenkins简单易行,不存在任何障碍,具体需要下面几个步骤:
就完成了jenkins的启动,启动后jenkins会自动去工作目录寻找相关配置。
接下来以一个龙芯openjdk 8的测试实例,介绍一下jenkins在龙芯平台上的应用。龙芯openjdk 8在jenkins上的测试流程框架如图1所示。
图2中的任务列表包含了龙芯openjdk 8的主要测试,这些项目包含大量测试用例和测试参数,在测试时,这些测试用例会被部署至几十台龙芯节点上进行多参数、长时间的测试,实现大规模的功能、性能和稳定性测试。未来随着机器规模的增加,测试规模也将进一步扩大。
接下来以测试流程中spec jvm98测试集为例说明一个具体测试项目在龙芯上的应用:配置界面如图3所示。
该测试项目可以在上文介绍的周期性测试中被自动触发,也可有针对性地进行手动触发。不管通过哪种触发方式,jenkins会根据相应的参数配置将测试部署至各机器节点上,进行相应的测试并反馈测试结果。
3 查看测试结果为了能够直观、快速、方便地查看所有测试结果,需进行相应的测试结果判定,使每项测试均能正确展示四种结果:测试passed、测试failed、未知错误和测试被终止aborted。
最终,“publish-and-report”项目会对所有测试项目的结果进行收集和汇总,生成测试报告,反馈给相关人员并做存档。
jenkins迁移至龙芯平台已稳定运行数月,从未出现死机、jdk崩溃和异常等现象。
截至撰稿之日,该jenkins系统共包含173个项目,136个插件。用于jenkins测试的机器节点包括数十台龙芯服务器和数十台龙芯主机,还包含docker等环境。测试机器节点的操作系统则包含loongnix、中标、debian、centos等。整套jenkins系统可无缝迁移至龙芯平台,迁移过程中未出现任何问题。
在过去三个半月,该jenkins系统共进行了2158次任务的构建,共进行配置1377次。近一年的jenkins服务器节点和所有节点的日均构建数据图如下所示。
由上图可见,测试任务的数量成逐渐上涨的趋势,尤其是较一年前相比,测试任务数量有了显著的提高。这是由于龙芯jvm测试的不断改进以及不断增加测试强度所致。另一方面,在测试压力相比迁移之前有明显增长的情况下,运行在龙芯平台上的jenkins仍能提供稳定高效的服务,保障产品研发和测试的有效进行。
随着整个龙芯平台软硬件环境的不断完善,在龙芯平台上部署生产环境已经成为可能,龙芯公司已经开展将相关服务向龙芯平台迁移的进程[2]。jenkins作为其中一个例子,迁移至龙芯平台后,在测试任务量相比迁移之前有明显增长的情况下,仍能保持稳定高效运行,可以满足龙芯jvm产品可持续、自动化的构建和规模化的测试,也为龙芯不断完善自己的产品提供了保障。