WSO2 java.lang.ClassNotFoundException:javax.jms.JMSContext

Posted

技术标签:

【中文标题】WSO2 java.lang.ClassNotFoundException:javax.jms.JMSContext【英文标题】:WSO2 java.lang.ClassNotFoundException: javax.jms.JMSContext 【发布时间】:2022-01-22 15:04:45 【问题描述】:

在我们公司,我们使用 WSO2 EI V6.4。 我使用此guide 进行了配置并连接到 azure 服务总线,一切正常

现在我们必须使用EI 6.4的最后一个补丁版本,当我进行相同的配置时,我得到了这个错误

java.lang.NoClassDefFoundError: javax/jms/JMSContext
        at org.apache.qpid.jms.jndi.JmsInitialContextFactory.getConnectionFactoryDefaults(JmsInitialContextFactory.java:202)
        at org.apache.qpid.jms.jndi.JmsInitialContextFactory.createConnectionFactories(JmsInitialContextFactory.java:133)
        at org.apache.qpid.jms.jndi.JmsInitialContextFactory.getInitialContext(JmsInitialContextFactory.java:103)
        at javax.naming.spi.NamingManager.getInitialContext(NamingManager.java:684)
        at javax.naming.InitialContext.getDefaultInitCtx(InitialContext.java:313)
        at javax.naming.InitialContext.init(InitialContext.java:244)
        at javax.naming.InitialContext.<init>(InitialContext.java:216)
        at org.apache.axis2.transport.jms.JMSConnectionFactory.initJMSConnectionFactory(JMSConnectionFactory.java:176)
        at org.apache.axis2.transport.jms.JMSConnectionFactory.<init>(JMSConnectionFactory.java:154)
        at org.apache.axis2.transport.jms.JMSConnectionFactoryManager.loadConnectionFactoryDefinitions(JMSConnectionFactoryManager.java:89)
        at org.apache.axis2.transport.jms.JMSConnectionFactoryManager.<init>(JMSConnectionFactoryManager.java:76)
        at org.apache.axis2.transport.jms.JMSListener.doInit(JMSListener.java:70)
        at org.apache.axis2.transport.base.AbstractTransportListenerEx.init(AbstractTransportListenerEx.java:62)
        at org.apache.axis2.engine.ListenerManager.init(ListenerManager.java:84)
        at org.wso2.carbon.core.init.CarbonServerManager.initializeCarbon(CarbonServerManager.java:412)
        at org.wso2.carbon.core.init.CarbonServerManager.start(CarbonServerManager.java:220)
        at org.wso2.carbon.core.internal.CarbonCoreServiceComponent.activate(CarbonCoreServiceComponent.java:105)
        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.eclipse.equinox.internal.ds.model.ServiceComponent.activate(ServiceComponent.java:260)
        at org.eclipse.equinox.internal.ds.model.ServiceComponentProp.activate(ServiceComponentProp.java:146)
        at org.eclipse.equinox.internal.ds.model.ServiceComponentProp.build(ServiceComponentProp.java:345)
        at org.eclipse.equinox.internal.ds.InstanceProcess.buildComponent(InstanceProcess.java:620)
        at org.eclipse.equinox.internal.ds.InstanceProcess.buildComponents(InstanceProcess.java:197)
        at org.eclipse.equinox.internal.ds.Resolver.getEligible(Resolver.java:343)
        at org.eclipse.equinox.internal.ds.SCRManager.serviceChanged(SCRManager.java:222)
        at org.eclipse.osgi.internal.serviceregistry.FilteredServiceListener.serviceChanged(FilteredServiceListener.java:107)
        at org.eclipse.osgi.framework.internal.core.BundleContextImpl.dispatchEvent(BundleContextImpl.java:861)
        at org.eclipse.osgi.framework.eventmgr.EventManager.dispatchEvent(EventManager.java:230)
        at org.eclipse.osgi.framework.eventmgr.ListenerQueue.dispatchEventSynchronous(ListenerQueue.java:148)
        at org.eclipse.osgi.internal.serviceregistry.ServiceRegistry.publishServiceEventPrivileged(ServiceRegistry.java:819)
        at org.eclipse.osgi.internal.serviceregistry.ServiceRegistry.publishServiceEvent(ServiceRegistry.java:771)
        at org.eclipse.osgi.internal.serviceregistry.ServiceRegistrationImpl.register(ServiceRegistrationImpl.java:130)
        at org.eclipse.osgi.internal.serviceregistry.ServiceRegistry.registerService(ServiceRegistry.java:214)
        at org.eclipse.osgi.framework.internal.core.BundleContextImpl.registerService(BundleContextImpl.java:433)
        at org.eclipse.equinox.http.servlet.internal.Activator.registerHttpService(Activator.java:81)
        at org.eclipse.equinox.http.servlet.internal.Activator.addProxyServlet(Activator.java:60)
        at org.eclipse.equinox.http.servlet.internal.ProxyServlet.init(ProxyServlet.java:40)
        at org.wso2.carbon.tomcat.ext.servlet.DelegationServlet.init(DelegationServlet.java:38)
        at org.apache.catalina.core.StandardWrapper.initServlet(StandardWrapper.java:1240)
        at org.apache.catalina.core.StandardWrapper.loadServlet(StandardWrapper.java:1184)
        at org.apache.catalina.core.StandardWrapper.load(StandardWrapper.java:1078)
        at org.apache.catalina.core.StandardContext.loadOnStartup(StandardContext.java:5380)
        at org.apache.catalina.core.StandardContext.startInternal(StandardContext.java:5680)
        at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:183)
        at org.apache.catalina.core.ContainerBase$StartChild.call(ContainerBase.java:1689)
        at org.apache.catalina.core.ContainerBase$StartChild.call(ContainerBase.java:1679)
        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.ClassNotFoundException: javax.jms.JMSContext cannot be found by qpid_jms_client_0.32.0_1.0.0
        at org.eclipse.osgi.internal.loader.BundleLoader.findClassInternal(BundleLoader.java:455)
        at org.eclipse.osgi.internal.loader.BundleLoader.findClass(BundleLoader.java:421)
        at org.eclipse.osgi.internal.loader.BundleLoader.findClass(BundleLoader.java:412)
        at org.eclipse.osgi.internal.baseadaptor.DefaultClassLoader.loadClass(DefaultClassLoader.java:107)
        at java.lang.ClassLoader.loadClass(ClassLoader.java:351)
        ... 53 more

我尝试调试 osgi 包以了解问题,我看到他尝试使用包 org.eclipse.osgi_3.9.1.v20130814-1242 [0] 而不是包 org.apache.geronimo.specs.geronimo-jms_2.0_spec_1.0.0.alpha-2 [139]

osgi> p javax.jms
javax.jms; version="0.0.0"<org.eclipse.osgi_3.9.1.v20130814-1242 [0]>
  hapi_2.1.0.wso2v1 [75] imports
  openjpa-all_2.2.2.wso2v1 [130] imports
  org.eclipse.core.expressions_3.4.500.v20130515-1343 [144] imports
  org.eclipse.core.runtime_3.9.0.v20130326-1255 [146] imports
  org.wso2.carbon.event.core_4.6.49 [263] imports
  org.wso2.carbon.logging_4.4.36 [338] imports
  org.wso2.ei.samples_6.4.0 [579] imports
  qpid_jms_client_0.32.0_1.0.0 [590] imports
  smooks_1.5.1.wso2v4 [604] imports
  spring.framework_3.2.9.wso2v1 [608] imports
  synapse-core_2.1.7.wso2v80_29 [612] imports
  synapse-samples_2.1.7.wso2v80 [616] imports
  tomcat_7.0.85.wso2v1 [620] imports
javax.jms; version="0.0.0"<geronimo_jms_1.1_spec_1.1.0.wso2v1_1.0.0 [68]>
javax.jms; version="2.0.0"<org.apache.geronimo.specs.geronimo-jms_2.0_spec_1.0.0.alpha-2 [139]>
  axis2-transport-jms_2.0.0.wso2v30_3 [20] imports


osgi> b 590
qpid_jms_client_0.32.0_1.0.0 [590]
  Id=590, Status=ACTIVE      Data Root=/home/bertrand/DEV/wso2/wso2ei-6.4.0/wso2/components/default/configuration/org.eclipse.osgi/bundles/590/data
  "No registered services."
  No services in use.
  Exported packages
    org.apache.qpid.jms; version="0.0.0"[exported]
    org.apache.qpid.jms.exceptions; version="0.0.0"[exported]
    org.apache.qpid.jms.jndi; version="0.0.0"[exported]
    org.apache.qpid.jms.message; version="0.0.0"[exported]
    org.apache.qpid.jms.message.facade; version="0.0.0"[exported]
    org.apache.qpid.jms.meta; version="0.0.0"[exported]
    org.apache.qpid.jms.policy; version="0.0.0"[exported]
    org.apache.qpid.jms.provider; version="0.0.0"[exported]
    org.apache.qpid.jms.provider.amqp; version="0.0.0"[exported]
    org.apache.qpid.jms.provider.amqp.builders; version="0.0.0"[exported]
    org.apache.qpid.jms.provider.amqp.filters; version="0.0.0"[exported]
    org.apache.qpid.jms.provider.amqp.message; version="0.0.0"[exported]
    org.apache.qpid.jms.provider.failover; version="0.0.0"[exported]
    org.apache.qpid.jms.sasl; version="0.0.0"[exported]
    org.apache.qpid.jms.selector; version="0.0.0"[exported]
    org.apache.qpid.jms.selector.filter; version="0.0.0"[exported]
    org.apache.qpid.jms.selector.parser; version="0.0.0"[exported]
    org.apache.qpid.jms.transports; version="0.0.0"[exported]
    org.apache.qpid.jms.transports.netty; version="0.0.0"[exported]
    org.apache.qpid.jms.util; version="0.0.0"[exported]
  Imported packages
    javax.naming.spi; version="0.0.0"<org.eclipse.osgi_3.9.1.v20130814-1242 [0]>
    javax.jms; version="0.0.0"<org.eclipse.osgi_3.9.1.v20130814-1242 [0]>
    javax.naming; version="0.0.0"<org.eclipse.osgi_3.9.1.v20130814-1242 [0]>
  No fragment bundles
  Named class space
    qpid_jms_client_0.32.0; bundle-version="1.0.0"[provided]
  No required bundles

是否可以强制你使用 bundle 68?

谢谢

【问题讨论】:

尝试在你的 bundle 清单中强制 version="2.0.0" 可能会有所帮助。 qpid lib 已经在 manifest 中配置了这个版本,但是如果我把它放在 lib 目录中,WSO2 并不关心 manifest。如果我将 lib 放在 dropins 目录 wso2 中,请阅读清单,但我得到一个在 org.apache.qpid.jms.jndi.JmsInitialContextFactory 上找不到的类 【参考方案1】:

我遇到过类似的问题并使用了qpid-jms-client-0.11.1 的版本,这对我有用。我从this Maven repository得到它

【讨论】:

我做了第一次测试,它似乎有效。此版本的 qpid 至少需要 1.1 版本,而不是 2.0。我会做更多的测试来验证这个解决方案。谢谢 它的工作谢谢你【参考方案2】:

在 WSO2 的支持下,我得到了另一个解决方案。

    使用qpid版本qpid-jms-client-0.32.0.jar$WSO2_HOME/lib 中删除库geronimo-jms_1.1_spec-1.1.0.wso2v1.jar$WSO2_HOME/dropins 中删除库geronimo-jms_1.1_spec-1.1.0.wso2v1.jar 确保javax.jms 行不在文件$WSO2_HOME/conf/etc/launch.ini

【讨论】:

以上是关于WSO2 java.lang.ClassNotFoundException:javax.jms.JMSContext的主要内容,如果未能解决你的问题,请参考以下文章

WSO2 : 设置 WSO2 服务器

WSO2使用另一个WSO2作为身份提供者

WSO2:如何在 wso2 中集成 APIM 和 IS

Dockerized WSO2身份服务器

使用 WSO2 身份服务器通过 JWT 保护 WSO2 微服务

使用 WSO2 Identity Server 和 WSO2 API Manager 保护后端