0

我正在寻找一个 jmeter 图形侦听器,它将输出 SamplerRequest 对象的子结果。我还没有找到一个,我非常渴望得到它。

4

2 回答 2

1

老问题,我知道。

不幸的是,似乎没有 JMeter 图表侦听器可以绘制附加到 SampleResult 的子结果的结果。刚刚遇到同样的问题,我选择自己写。

脚步:

  1. 将以下类编译为 jar。
  2. 将 jar 放在 jMeter 的 lib/ext 文件夹中。
  3. 打开您的测试计划,浏览菜单以正常添加侦听器,选择“SubResult Distributed Response Graph”
  4. 运行你的测试计划。

课程:

下面的类将提供一个响应时间分布图,它只会绘制子结果。

public class SubResultDistributedResponseTimeListener extends DistributionGraphVisualizer {

private static final Logger LOG = LoggingManager.getLoggerForClass();

@Override
public void add(final SampleResult res) {
    final List<SampleResult> subResults = Arrays.asList(res.getSubResults());
    final SubResultDistributedResponseTimeListener inst = this;

    JMeterUtils.runSafe(new Runnable() {
        public void run() {
            for (SampleResult r : subResults) {
                long time = r.getEndTime() - r.getStartTime();
                LOG.info("Adding result; start: " + r.getStartTime() + " end: " + r.getEndTime() + " duration: " + time);
                SamplingStatCalculator model = inst.getCustomModel();
                if (model != null) {
                    model.addSample(r);
                    inst.updateGui(model.getCurrentSample());
                }
            }
        }
    });

}

// we need this because DistributionGraphVisualizer has a private field 'model' which
// deals with updating the screen. Watch out for SecurityManager problems with 
// accessing private fields.
public SamplingStatCalculator getCustomModel() {
    try {
        Field f = DistributionGraphVisualizer.class.getDeclaredField("model");
        f.setAccessible(true);
        return (SamplingStatCalculator) f.get(this);
    } catch (NoSuchFieldException e) {
        e.printStackTrace();
    } catch (SecurityException e) {
        e.printStackTrace();
    }  catch (IllegalArgumentException e) {
        e.printStackTrace();
    } catch (IllegalAccessException e) {
        e.printStackTrace();
    }
    return null;
}

@Override
public String getName() {
    return "SubResult Distributed Response Graph";
}

@Override
public String getStaticLabel() {
    return this.getName();
}

@Override
public String getLabelResource() { // add this Listeners name to the right click context menu.
    return this.getName();
}

注意,难看的 catch 块是因为我必须在 Java 1.5 中编译。

如果他们愿意,我将把它留给读者来扩展不同的图表侦听器。

于 2014-11-21T14:15:52.467 回答
0

我知道的唯一选择是每秒点击次数图,它绘制结果和子结果,但仅来自事务控制器,而不是嵌入式资源。你可以要求作者实现一个新的图表......

于 2011-12-11T08:28:18.303 回答