jedis报LinkageError错误:javax/management/MBeanServer

jedis报LinkageError错误:javax/management/MBeanServer


使用jedis客户端时,遇到下面异常信息:

Horrible Exception: java.lang.LinkageError: loading constraint violation: loader "com/ibm/ws/classloader/CompoundClassLoader@6a36fae" previously initiated loading for a different type with name "javax/management/MBeanServer" defined by loader "com/ibm/oti/vm/BootstrapClassLoader@7853887"at java.lang.ClassLoader.defineClassImpl(Native Method)at java.lang.ClassLoader.defineClass(ClassLoader.java:262)at java.security.SecureClassLoader.defineClass(SecureClassLoader.java:69)at com.ibm.ws.classloader.CompoundClassLoader._defineClass(CompoundClassLoader.java:829)at com.ibm.ws.classloader.CompoundClassLoader.localFindClass(CompoundClassLoader.java:744)at com.ibm.ws.classloader.CompoundClassLoader.loadClass(CompoundClassLoader.java:585)at java.lang.ClassLoader.loadClass(ClassLoader.java:627)at org.apache.commons.pool2.impl.BaseGenericObjectPool.jmxRegister(BaseGenericObjectPool.java:947)at org.apache.commons.pool2.impl.BaseGenericObjectPool.<init>(BaseGenericObjectPool.java:132)at org.apache.commons.pool2.impl.GenericObjectPool.<init>(GenericObjectPool.java:107)at redis.clients.util.Pool.initPool(Pool.java:43)at redis.clients.util.Pool.<init>(Pool.java:31)at redis.clients.jedis.JedisPool.<init>(JedisPool.java:80)at redis.clients.jedis.JedisClusterInfoCache.setNodeIfNotExist(JedisClusterInfoCache.java:107)at redis.clients.jedis.JedisClusterInfoCache.discoverClusterNodesAndSlots(JedisClusterInfoCache.java:54)at redis.clients.jedis.JedisClusterConnectionHandler.initializeSlotsCache(JedisClusterConnectionHandler.java:39)at redis.clients.jedis.JedisClusterConnectionHandler.<init>(JedisClusterConnectionHandler.java:28)at redis.clients.jedis.JedisSlotBasedConnectionHandler.<init>(JedisSlotBasedConnectionHandler.java:21)at redis.clients.jedis.JedisSlotBasedConnectionHandler.<init>(JedisSlotBasedConnectionHandler.java:16)at redis.clients.jedis.BinaryJedisCluster.<init>(BinaryJedisCluster.java:39)at redis.clients.jedis.JedisCluster.<init>(JedisCluster.java:45)at redis.clients.jedis.JedisCluster.<init>(JedisCluster.java:32)at com.hc360.redis.util.RedisConnection.createCluster(RedisConnection.java:65)at com.hc360.redis.RedisClusterClient.<clinit>(RedisClusterClient.java:26)at java.lang.J9VMInternals.initializeImpl(Native Method)at java.lang.J9VMInternals.initialize(J9VMInternals.java:233)at com.hc360.my.modules.screens.corcenter.company.morelogin.doBuildTemplate(morelogin.java:104)at com.hc360.my.common.secure.MyLogSecureScreen.doBuildTemplate(MyLogSecureScreen.java:64)at org.apache.turbine.modules.screens.TemplateScreen.doBuild(TemplateScreen.java:100)at org.apache.turbine.modules.Screen.build(Screen.java:57)at org.apache.turbine.modules.ScreenLoader.eval(ScreenLoader.java:107)at org.apache.turbine.modules.layouts.VelocityOnlyLayout.doBuild(VelocityOnlyLayout.java:93)at org.apache.turbine.modules.Layout.build(Layout.java:53)at org.apache.turbine.modules.LayoutLoader.exec(LayoutLoader.java:101)at org.apache.turbine.modules.pages.DefaultPage.doBuild(DefaultPage.java:146)at org.apache.turbine.modules.Page.build(Page.java:53)at org.apache.turbine.modules.PageLoader.exec(PageLoader.java:101)at org.apache.turbine.Turbine.doGet(Turbine.java:799)at javax.servlet.http.HttpServlet.service(HttpServlet.java:575)at javax.servlet.http.HttpServlet.service(HttpServlet.java:668)at com.ibm.ws.webcontainer.servlet.ServletWrapper.service(ServletWrapper.java:1214)at com.ibm.ws.webcontainer.servlet.ServletWrapper.handleRequest(ServletWrapper.java:774)at com.ibm.ws.webcontainer.servlet.ServletWrapper.handleRequest(ServletWrapper.java:456)at com.ibm.ws.webcontainer.servlet.ServletWrapperImpl.handleRequest(ServletWrapperImpl.java:178)at com.ibm.ws.webcontainer.filter.WebAppFilterChain.invokeTarget(WebAppFilterChain.java:125)at com.ibm.ws.webcontainer.filter.WebAppFilterChain.doFilter(WebAppFilterChain.java:92)at com.hc360.waf.filter.WafFilter.doFilter(WafFilter.java:87)at com.ibm.ws.webcontainer.filter.FilterInstanceWrapper.doFilter(FilterInstanceWrapper.java:192)at com.ibm.ws.webcontainer.filter.WebAppFilterChain.doFilter(WebAppFilterChain.java:89)at com.hc360.security.authz.SecurityFilter.doFilter(SecurityFilter.java:161)at com.ibm.ws.webcontainer.filter.FilterInstanceWrapper.doFilter(FilterInstanceWrapper.java:192)at com.ibm.ws.webcontainer.filter.WebAppFilterChain.doFilter(WebAppFilterChain.java:89)at com.hc360.my.common.filter.ScriptFilter.doFilter(ScriptFilter.java:58)at com.ibm.ws.webcontainer.filter.FilterInstanceWrapper.doFilter(FilterInstanceWrapper.java:192)at com.ibm.ws.webcontainer.filter.WebAppFilterChain.doFilter(WebAppFilterChain.java:89)at com.hc360.my.common.filter.InjectRefuseFilter.doFilter(InjectRefuseFilter.java:58)at com.ibm.ws.webcontainer.filter.FilterInstanceWrapper.doFilter(FilterInstanceWrapper.java:192)at com.ibm.ws.webcontainer.filter.WebAppFilterChain.doFilter(WebAppFilterChain.java:89)at com.hc360.mmt.j2ee.conf.PersistenceSessionFilter.doFilter(PersistenceSessionFilter.java:73)at com.ibm.ws.webcontainer.filter.FilterInstanceWrapper.doFilter(FilterInstanceWrapper.java:192)at com.ibm.ws.webcontainer.filter.WebAppFilterChain.doFilter(WebAppFilterChain.java:89)at com.hc360.sso.client.SSOFilter.doFilter(SSOFilter.java:674)at com.ibm.ws.webcontainer.filter.FilterInstanceWrapper.doFilter(FilterInstanceWrapper.java:192)at com.ibm.ws.webcontainer.filter.WebAppFilterChain.doFilter(WebAppFilterChain.java:89)at com.hc360.my.common.filter.CharSetFilter.doFilter(CharSetFilter.java:42)at com.ibm.ws.webcontainer.filter.FilterInstanceWrapper.doFilter(FilterInstanceWrapper.java:192)at com.ibm.ws.webcontainer.filter.WebAppFilterChain.doFilter(WebAppFilterChain.java:89)at com.ibm.ws.webcontainer.filter.WebAppFilterManager.doFilter(WebAppFilterManager.java:926)at com.ibm.ws.webcontainer.filter.WebAppFilterManager.invokeFilters(WebAppFilterManager.java:1023)at com.ibm.ws.webcontainer.webapp.WebApp.handleRequest(WebApp.java:3703)at com.ibm.ws.webcontainer.webapp.WebGroup.handleRequest(WebGroup.java:304)at com.ibm.ws.webcontainer.WebContainer.handleRequest(WebContainer.java:962)at com.ibm.ws.webcontainer.WSWebContainer.handleRequest(WSWebContainer.java:1662)at com.ibm.ws.webcontainer.channel.WCChannelLink.ready(WCChannelLink.java:195)at com.ibm.ws.http.channel.inbound.impl.HttpInboundLink.handleDiscrimination(HttpInboundLink.java:452)at com.ibm.ws.http.channel.inbound.impl.HttpInboundLink.handleNewRequest(HttpInboundLink.java:511)at com.ibm.ws.http.channel.inbound.impl.HttpInboundLink.processRequest(HttpInboundLink.java:305)at com.ibm.ws.http.channel.inbound.impl.HttpICLReadCallback.complete(HttpICLReadCallback.java:83)at com.ibm.ws.tcp.channel.impl.AioReadCompletionListener.futureCompleted(AioReadCompletionListener.java:165)at com.ibm.io.async.AbstractAsyncFuture.invokeCallback(AbstractAsyncFuture.java:217)at com.ibm.io.async.AsyncChannelFuture.fireCompletionActions(AsyncChannelFuture.java:161)at com.ibm.io.async.AsyncFuture.completed(AsyncFuture.java:138)at com.ibm.io.async.ResultHandler.complete(ResultHandler.java:204)at com.ibm.io.async.ResultHandler.runEventProcessingLoop(ResultHandler.java:775)at com.ibm.io.async.ResultHandler$2.run(ResultHandler.java:905)at com.ibm.ws.util.ThreadPool$Worker.run(ThreadPool.java:1659)


工程部署在websphere中,很明显类加载冲突:

Horrible Exception: java.lang.LinkageError: loading constraint violation: loader "com/ibm/ws/classloader/CompoundClassLoader@6a36fae" previously initiated loading for a different type with name "javax/management/MBeanServer" defined by loader "com/ibm/oti/vm/BootstrapClassLoader@7853887"


在工程中搜索javax/management/MBeanServer,发现在jdk的rt.jar包中和jboss-jmx.jar中出现了相同的类;


想不明白为什么jboss-jmx.jar中会出现跟jdk同样的类,但都在使用,也不能添加一个功能而牺牲别的功能;

有一个疑问,以前工程中就存在这个包了,为什么没有报错呢?而现在咋就报了呢?


猜测以前没有使用到该类!


那无疑jedis中使用到了该类javax/management/MBeanServer,显然这个类是jmx的,在使用redis中,我也不需要这个功能,是否可以去掉呢?

查看源码发现,JedisCluster创建实例时,可以传递配置信息,配置信息中可以设置是否使用jmx,只要设为false即可:

GenericObjectPoolConfig copc = new GenericObjectPoolConfig();copc.setJmxEnabled(false);jedisCluster = new JedisCluster(clusterNodes,3000,1000,copc);


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
引用\[1\]:Caused by: java.lang.ClassNotFoundException: redis.clients.jedis.UnifiedJedis at java.net.URLClassLoader$1.run(URLClassLoader.java:372) ~\[na:1.8.0_20\] at java.net.URLClassLoader$1.run(URLClassLoader.java:361) ~\[na:1.8.0_20\] at java.security.AccessController.doPrivileged(Native Method) ~\[na:1.8.0_20\] at java.net.URLClassLoader.findClass(URLClassLoader.java:360) ~\[na:1.8.0_20\] at java.lang.ClassLoader.loadClass(ClassLoader.java:424) ~\[na:1.8.0_20\] at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:308) ~\[na:1.8.0_20\] at java.lang.ClassLoader.loadClass(ClassLoader.java:357) ~\[na:1.8.0_20\] ... 56 common frames omitted 引用\[2\]:只要将redis启动器中的lettuce排除在外,注意版本号不要写,默认会继承父项目的版本号以防jar包冲突。 <!-- redis启动器--> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-redis</artifactId> <exclusions> <exclusion> <groupId>io.lettuce</groupId> <artifactId>lettuce-core</artifactId> </exclusion> </exclusions> </dependency> <!-- jedis连接池--> <dependency> <groupId>redis.clients</groupId> <artifactId>jedis</artifactId> </dependency> 引用\[3\]:在pom中导入jetcache坐标中的redis与springboot版本冲突导致, <dependency> <groupId>com.alicp.jetcache</groupId> <artifactId>jetcache-starter-redis</artifactId> <version>2.7.0.M1</version> <!--这里版本不唯一,也可能是别的版本--> </dependency> 解决方法: 问题:Caused by: java.lang.NoClassDefFoundError: redis/clients/jedis/ConnectionPoolConfig 回答: 这个错误是由于缺少redis.clients.jedis.ConnectionPoolConfig类引起的。根据引用\[1\],可能是由于缺少redis.clients.jedis.UnifiedJedis类导致的。解决这个问题的方法有两种。一种是根据引用\[2\],在项目的pom文件中排除lettuce-core依赖,然后添加jedis依赖。另一种是根据引用\[3\],检查项目中的redis和springboot版本是否冲突,如果有冲突,可以尝试升级或降级其中一个版本以解决冲突。 #### 引用[.reference_title] - *1* *3* [【Spring常见错误java.lang.NoClassDefFoundError: redis/clients/jedis/UnifiedJedis](https://blog.csdn.net/qq_52360069/article/details/125275138)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [springboot整合redis中 出现Caused by: java.lang.NoClassDefFoundError: redis/clients/jedis/util/Pool](https://blog.csdn.net/qq_45059663/article/details/113608498)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值