gradle - java.lang.NoClassDefFoundError:javaslang/collection/LinkedHashMap,同时使用jmh对基准 Spring 数据应用程序进行基准测试

标签 gradle spring-data jmh

我有spring data JPA应用程序,我想使用jmh对应用程序进行基准测试。

我正在使用gradle构建工具,并为此使用gradle-jmh-plugin

我的github仓库是here

我想对要进行基准测试的create Person实体进行基准测试,并且基准测试代码为here

每当我使用gradle :aerospike-benchmark-demo:jmh --stacktrace命令运行此基准测试时,总是会遇到以下异常。

10:01:40.688 [com.aerospike.benchmark.AerospikeCreateBenchMarkDemo.createPerson-jmh-worker-1] DEBUG org.springframework.beans.factory.support.DefaultListableBeanFactory - Retrieved dependent beans for bean 'aerospikeClient': [aerospikeTemplate]
10:01:40.688 [com.aerospike.benchmark.AerospikeCreateBenchMarkDemo.createPerson-jmh-worker-1] DEBUG org.springframework.beans.factory.support.DisposableBeanAdapter - Invoking destroy method 'close' on bean with name 'aerospikeClient'
org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'personRepository': Invocation of init method failed; nested exception is java.lang.NoClassDefFoundError: javaslang/collection/LinkedHashMap
    at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.initializeBean(AbstractAutowireCapableBeanFactory.java:1628)
    at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:555)
    at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:483)
    at org.springframework.beans.factory.support.AbstractBeanFactory$1.getObject(AbstractBeanFactory.java:306)
    at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:230)
    at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:302)
    at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:197)
    at org.springframework.beans.factory.support.DefaultListableBeanFactory.preInstantiateSingletons(DefaultListableBeanFactory.java:742)
    at org.springframework.context.support.AbstractApplicationContext.finishBeanFactoryInitialization(AbstractApplicationContext.java:867)
    at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:543)
    at org.springframework.context.annotation.AnnotationConfigApplicationContext.<init>(AnnotationConfigApplicationContext.java:84)
    at com.aerospike.benchmark.AerospikeCreateBenchMarkDemo.createPerson(AerospikeCreateBenchMarkDemo.java:62)
    at com.aerospike.benchmark.generated.AerospikeCreateBenchMarkDemo_createPerson_jmhTest.createPerson_avgt_jmhStub(AerospikeCreateBenchMarkDemo_createPerson_jmhTest.java:402)
    at com.aerospike.benchmark.generated.AerospikeCreateBenchMarkDemo_createPerson_jmhTest.createPerson_AverageTime(AerospikeCreateBenchMarkDemo_createPerson_jmhTest.java:306)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.lang.reflect.Method.invoke(Method.java:498)
    at org.openjdk.jmh.runner.BenchmarkHandler$BenchmarkTask.call(BenchmarkHandler.java:453)
    at org.openjdk.jmh.runner.BenchmarkHandler$BenchmarkTask.call(BenchmarkHandler.java:437)
    at java.util.concurrent.FutureTask.run(FutureTask.java:266)
    at java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:511)
    at java.util.concurrent.FutureTask.run(FutureTask.java:266)
    at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1149)
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:624)
    at java.lang.Thread.run(Thread.java:748)
Caused by: java.lang.NoClassDefFoundError: javaslang/collection/LinkedHashMap
    at org.springframework.data.repository.util.JavaslangCollections$FromJavaConverter.<clinit>(JavaslangCollections.java:143)
    at org.springframework.data.repository.util.QueryExecutionConverters.registerConvertersIn(QueryExecutionConverters.java:206)
    at org.springframework.data.repository.core.support.QueryExecutionResultHandler.<init>(QueryExecutionResultHandler.java:44)
    at org.springframework.data.repository.core.support.RepositoryFactorySupport$QueryExecutorMethodInterceptor.<init>(RepositoryFactorySupport.java:409)
    at org.springframework.data.repository.core.support.RepositoryFactorySupport.getRepository(RepositoryFactorySupport.java:221)
    at org.springframework.data.repository.core.support.RepositoryFactoryBeanSupport.initAndReturn(RepositoryFactoryBeanSupport.java:277)
    at org.springframework.data.repository.core.support.RepositoryFactoryBeanSupport.afterPropertiesSet(RepositoryFactoryBeanSupport.java:263)
    at org.springframework.data.aerospike.repository.support.AerospikeRepositoryFactoryBean.afterPropertiesSet(AerospikeRepositoryFactoryBean.java:63)
    at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.invokeInitMethods(AbstractAutowireCapableBeanFactory.java:1687)
    at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.initializeBean(AbstractAutowireCapableBeanFactory.java:1624)
    ... 25 more
Caused by: java.lang.ClassNotFoundException: javaslang.collection.LinkedHashMap
    at java.net.URLClassLoader.findClass(URLClassLoader.java:381)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:424)
    at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:335)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:357)
    ... 35 more

我不确定如何将AerospikeConfig和PersonRepository自动连接到Benchmarking类。

最佳答案

似乎您缺乏javaslang依赖性。用
compile group: 'com.javaslang', name: 'javaslang', version: '2.0.0-RC4'
添加到aerospike-demo / build.gradle,它运行并至少显示一些数字。

关于gradle - java.lang.NoClassDefFoundError:javaslang/collection/LinkedHashMap,同时使用jmh对基准 Spring 数据应用程序进行基准测试,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47796558/

相关文章:

java - 了解避免死代码消除后果

android-studio - Android Gradle同步失败问题Android Studio 3.1.4和Gradle 4.4

android - 如何查看Android Studio中Gradle任务执行的CLI命令?

java - 实体需要什么状态才能触发【更新】操作?

Spring 数据: relationships between 2 different data sources

redis - 如何在从属模式下在 Cloudfoundry 上配置 Redis 实例?

带有 gradle 4.x 的 Grails 3.3.x 不起作用?

android - 构建过程中包括自定义特定于 active 香料的gradle任务

java - 从性能测量中排除方法调用

java - JMH Sample 和 SingleShot 之间的区别