springboot整合JMH基准测试, 以及错误JMH had finished, but forked VM did not exit, 解决办法

首先, 需要引入jmh的包:


		
			org.openjdk.jmh
			jmh-core
			1.21
			test
		

		
		
			org.openjdk.jmh
			jmh-generator-annprocess
			1.21
			test
		

创建测试类

package cn.ygl.demo.jmh;

import cn.ygl.demo.DemoApplication;
import cn.ygl.demo.service.JSONService;
import cn.ygl.demo.service.impl.FastJsonService;

import cn.ygl.demo.service.impl.GsonService;
import com.alibaba.fastjson.JSONObject;
import org.junit.Test;
import org.openjdk.jmh.annotations.*;
import org.openjdk.jmh.runner.Runner;
import org.openjdk.jmh.runner.RunnerException;
import org.openjdk.jmh.runner.options.Options;
import org.openjdk.jmh.runner.options.OptionsBuilder;
import org.springframework.boot.SpringApplication;
import org.springframework.context.ConfigurableApplicationContext;

import java.util.UUID;


@State(value = Scope.Thread)
public class JMHTests {

    private String reqStr;
    private ConfigurableApplicationContext context;
    private JSONService fastjsonService;
    private JSONService gsonService;

    @Test
    public void test() throws RunnerException {
        Options options = new OptionsBuilder().include(JMHTests.class.getSimpleName())
                .warmupIterations(2).measurementIterations(2).forks(1).build();
        new Runner(options).run();
    }

    @Setup
    public void init()  {
        JSONObject object = new JSONObject();
        object.put("requestId", UUID.randomUUID().toString());
        object.put("requestName", "test");
        object.put("requestData", "122345");
        object.put("requestType", "POST");
        reqStr = object.toString();
        System.err.println("init....");
        context = SpringApplication.run(DemoApplication.class);

        fastjsonService = context.getBean(FastJsonService.class);
        gsonService = context.getBean(GsonService.class);
    }

    @TearDown
    public void finish(){
        context.close();
    }

    @Benchmark
    public void testGson(){
        gsonService.getRequestId(reqStr);
    }

    @Benchmark
    public void testFastJSON(){
        fastjsonService.getRequestId(reqStr);
    }
}

@Setup默认是初始化一次的

注意, finish方法要记得关闭context, 否则会报错误JMH had finished, but forked VM did not exit, are there stray running threads? Waiting 24 seconds more... , 这是因为内嵌的tomcat线程没结束导致的(网上有些教程并没有添加这个@TearDown方法, 我不知道为什么他们不报错, 我的会报错, 不知道还有没有其他人也这样)

这样跑基准测试的时候就不会报错了, 结果如下:

下面贴上引入的俩个bean代码

@Service
@Qualifier("fastjson")
public class FastJsonService implements JSONService {
    @Override
    public String getRequestId(String str) {
        return ((JSONObject)JSONObject.parse(str)).getString("requestId");
    }
}

 

@Service
@Qualifier("gson")
public class GsonService implements JSONService {

    @Override
    public String getRequestId(String str) {
        return new Gson().fromJson(str, ReqData.class).getRequestId();
    }
}

 

你可能感兴趣的:(java)