我正在尝试使用JedisPool
在 Quarkus 本机模式下运行的应用程序(在 JVM 模式下工作正常)。
我已经禁用了池的 JMX 功能,该功能在本机模式下不可用,如下所示:
JedisPoolConfig jedisConfiguration = new JedisPoolConfig();
jedisConfiguration.setJmxEnabled(false);
jedisPool = new JedisPool(jedisConfiguration, jedisURI);
但是我遇到了以下错误:
2020-04-29 17:35:37,724 INFO [test.StockQuote] (main) java.lang.IllegalArgumentException: Unable to create org.apache.commons.pool2.impl.EvictionPolicy instance of type org.apache.commons.pool2.impl.DefaultEvictionPolicy
at org.apache.commons.pool2.impl.BaseGenericObjectPool.setEvictionPolicyClassName(BaseGenericObjectPool.java:662)
at org.apache.commons.pool2.impl.BaseGenericObjectPool.setEvictionPolicyClassName(BaseGenericObjectPool.java:687)
at org.apache.commons.pool2.impl.BaseGenericObjectPool.setConfig(BaseGenericObjectPool.java:235)
at org.apache.commons.pool2.impl.GenericObjectPool.setConfig(GenericObjectPool.java:302)
at org.apache.commons.pool2.impl.GenericObjectPool.<init>(GenericObjectPool.java:115)
at redis.clients.jedis.util.Pool.initPool(Pool.java:45)
...
Caused by: java.lang.ClassNotFoundException: org.apache.commons.pool2.impl.DefaultEvictionPolicy
at com.oracle.svm.core.hub.ClassForNameSupport.forName(ClassForNameSupport.java:60)
at java.lang.Class.forName(DynamicHub.java:1197)
作为临时解决方案,我切换为创建直接连接而不是使用池,但仍在寻找使用池的可能性。
有什么建议或解决方法吗?
好吧,我又挖了一点,发现了更多关于Class.forName
在这些页面上:对 Substrate VM 的反思 https://github.com/oracle/graal/blob/master/substratevm/REFLECTION.md and Quarkus - 编写本机应用程序的技巧 https://quarkus.io/guides/writing-native-applications-tips并通过找到了解决方案reflection-config.json
文件包含:
[
{
"name" : "org.apache.commons.pool2.impl.DefaultEvictionPolicy",
"allDeclaredConstructors" : true,
"allPublicConstructors" : true,
"allDeclaredMethods" : true,
"allPublicMethods" : true,
"allDeclaredFields" : true,
"allPublicFields" : true
}
]
您还需要将以下行添加到您的application.properties
file:
quarkus.native.additional-build-args =-H:ReflectionConfigurationFiles=reflection-config.json
然后我的应用程序成功运行。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)