Ant+jenkins+jemeter集成

本文介绍如何在Jenkins中集成JMeter进行自动化性能测试,包括配置步骤、构建脚本及生成报告的过程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1、antJenkinsjemeter都配置好

2、Jenkins上下载插件performance

3、Jenkins上新建一个自由风格的项目

4、新建下面如图结构用于jemeter报告文件

如图


其中html用于存放生成的HTML文件,jtl目录用于存放日志文件jtl,script目录用于存放jemeter编译后的文件.jmx文件,build文件自己新建并赋值(名字自取,只要用到的地方保持一致即可,可以通过名字有多个build文件)。

1、build文件的内容如下:

<?xml version="1.0" encoding="UTF-8"?>  

  

<project name="ant-jmeter-test" default="run" basedir=".">  

      

    <tstamp>  

        <format property="time" pattern="yyyyMMddhhmm" />  

    </tstamp>  

    <property name="basedirectory" value="D:\Ant-jemeter" />  

    <!-- 需要改成自己本地的 Jmeter 目录-->    

    <property name="jmeter.home" value="D:\jemeter\apache-jmeter-3.3" />  

    <!-- jmeter生成jtl格式的结果报告的路径-->   

 <property name="jmeter.result.jtl.dir" value="${basedirectory}\resultLog\jtl" />  

    <!-- jmeter生成html格式的结果报告的路径-->  

    <property name="jmeter.result.html.dir" value="${basedirectory}\resultLog\html" />  

    <!-- Name of test (without .jmx) -->  

    <property name="test" value="Test"/>  

    <!-- 生成的报告的前缀-->    

    <property name="ReportName" value="TestReport" />  

    <property name="jmeter.result.jtlName" value="${jmeter.result.jtl.dir}/${test}.jtl" />  

    <property name="jmeter.result.htmlName" value="${jmeter.result.html.dir}/${test}.html" />  

      

    <path id="xslt.classpath">  

        <fileset dir="${jmeter.home}/lib" includes="xalan*.jar"/>  

        <fileset dir="${jmeter.home}/lib" includes="serializer*.jar"/>  

    </path>  

      

    <target name="run">  

        <antcall target="test" />  

        <antcall target="report" />  

    </target>  

      

    <target name="test">  

        <taskdef name="jmeter" classname="org.programmerplanet.ant.taskdefs.jmeter.JMeterTask" />  

      

    <jmeter jmeterhome="${jmeter.home}" resultlog="${jmeter.result.jtlName}">  

             <!-- 声明要运行的脚本。"*.jmx"指包含此目录下的所有jmeter脚本-->  

            <testplans dir="${basedirectory}\script" includes="${test}.jmx" />  

        </jmeter>  

    </target>  

          

    <target name="report">  

<tstamp> <format property="report.datestamp" pattern="yyyy/MM/dd HH:mm" /></tstamp>  

        <xslt classpathref="xslt.classpath"  

              force="true"  

              in="${jmeter.result.jtlName}"  

              out="${jmeter.result.htmlName}"  

              style="${jmeter.home}/extras/jmeter-results-detail-report_21.xsl">  

              <param name="dateReport" expression="${report.datestamp}"/>  

        </xslt>  

        <copy todir="${jmeter.result.html.dir}">  

            <fileset dir="${jmeter.home}/extras">  

                <include name="collapse.png" />  

                <include name="expand.png" />  

            </fileset>  

        </copy>  

    </target>  

      

</project>  

截图如下

6、进入上面新建的Jenkins项目进行配置



命令如下:FOR %%A IN (D:\jemeter\apache-jmeter-3.3\extras\*.*) DO DEL %%A

FOR %%A IN (D:\jemeter\apache-jmeter-3.3\extras\*.*) DO DEL %%A




点击构建即可


<think>嗯,用户想知道如何集成JMeter、Ant、Allure和Jenkins来进行自动化性能测试和生成报告的最佳实践。首先,我需要理清楚每个工具的作用和它们之间的协作流程。 首先,JMeter是用来执行性能测试的,用户需要编写测试脚本并运行。然后,Ant作为构建工具,可以自动化执行JMeter测试,并处理结果文件。接下来,Allure用于生成美观的测试报告,但JMeter默认生成的是.jtl或.xml格式的结果,可能需要转换才能被Allure识别。Jenkins则是持续集成工具,负责整个流程的自动化触发和调度。 接下来,我需要参考用户提供的引用内容。例如,引用[3]提到JMeter保存的结果文件格式需要设置为XML,这可能涉及到配置jmeter.properties文件。引用[2]和[5]提到了使用Ant构建脚本(build.xml)来运行JMeter测试并生成报告,引用[4]提到使用XSL样式表生成报告,但用户现在想用Allure,可能需要额外的步骤转换结果格式。 可能的步骤包括: 1. 配置JMeter以生成适合Allure的报告格式,可能需要插件或转换工具。 2. 编写Ant的build.xml文件,自动化执行JMeter测试,并将结果转换为Allure可识别的格式。 3. 集成Allure到Jenkins,配置Jenkins任务来触发Ant构建,并调用Allure生成报告。 4. 确保各工具之间的路径和配置正确,例如JMeter脚本路径、结果输出路径、Allure报告的生成路径等。 需要注意的是,Allure通常用于单元测试或接口测试,处理性能测试报告可能需要特定适配。可能需要查找是否有JMeter的Allure监听器或插件,或者通过中间步骤将JMeter的结果转换为Allure支持的格式(如JUnit格式)。 此外,引用[5]提到Jenkins中配置AntJMeter的步骤,可能需要参考这些步骤来设置Jenkins的构建任务。同时,确保所有依赖项如JMeter和Ant的环境变量在Jenkins中正确配置。 最后,用户可能希望整个流程自动化,包括测试执行、结果处理和报告生成,所以需要验证每个步骤是否能在Jenkins中无缝衔接,并处理可能出现的错误或日志问题。</think>### 集成JMeter、Ant、Allure与Jenkins的自动化性能测试实践 #### 一、环境配置与工具整合流程 1. **JMeter脚本编写与配置** - 创建性能测试脚本(.jmx文件),设置线程组、取样器等组件,确保测试逻辑正确[^5] - 修改`jmeter.properties`文件,设置输出格式为XML: ```properties jmeter.save.saveservice.output_format=xml[^3] ``` 2. **Ant构建自动化** - 在`build.xml`中定义JMeter执行任务: ```xml <target name="run-jmeter"> <jmeter jmeterhome="${jmeter.home}" testplan="${test.dir}/your_test.jmx" resultlog="${result.dir}/jmeter-results.xml"/> </target> ``` - 添加结果转换任务(需依赖`jmeter-results-report.xsl`样式文件[^4]) 3. **Allure报告集成** - 通过JMeter插件生成Allure兼容格式(需安装`jmeter-allure-plugin`) - 或使用Python脚本将JTL文件转换为Allure支持的JSON格式: ```python import pandas as pd df = pd.read_csv("results.jtl") df.to_json("allure-results/output.json") ``` 4. **Jenkins流水线配置** - 安装Allure插件和Ant插件 - 创建Pipeline脚本: ```groovy pipeline { agent any stages { stage('Checkout') { steps { git 'https://your-repo-url' }} stage('Run Test') { steps { bat 'ant run-jmeter' }} stage('Generate Report') { steps { allure includeProperties: false, jdk: '', results: [[path: 'allure-results']] }} } } ``` #### 二、目录结构示例 ``` ├── ant-jmeter/ │ ├── script/ │ │ ├── build.xml # Ant构建文件 │ │ └── test_scripts/ # JMeter脚本存放位置 │ └── result/ │ ├── html/ # JMeter原始报告[^2] │ ├── jtl/ # 测试结果文件[^1] │ └── allure-results/ # Allure报告数据 ``` #### 三、关键优化点 1. **参数化构建**:通过Jenkins参数设置线程数、持续时间等测试变量 2. **异常处理**:在Ant脚本中添加失败重试机制 3. **资源监控**:集成PerfMon插件收集服务器指标 4. **历史对比**:配置Allure历史趋势图功能 #### 四、验证流程 1. 本地执行`ant run-jmeter`验证脚本正确性 2. 检查`jtl/`目录是否生成结果文件 3. 验证Allure报告是否包含响应时间、错误率等核心指标 4. 触发Jenkins构建后查看控制台输出和报告可视化
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值