[DUBBO] No such extension com.alibaba.dubbo.container.Container by name spring  , possible causes:

本文详细解析了Dubbo启动失败的错误现象,指出配置错误是导致问题的主要原因。通过分析日志,发现“dubbo.container=spring”配置项存在空格,导致Spring容器无法正确加载。文章还提供了排查思路和解决方法,对于遇到类似问题的开发者具有较高的参考价值。

问题现象:dubbo启动失败

[2019-12-23 14:48:53 ERROR] [main] (com.alibaba.dubbo.container.Main:86) -  [DUBBO] No such extension com.alibaba.dubbo.container.Container by name spring  , possible causes: 
(1) com.alibaba.dubbo.container.logback.LogbackContainer:
java.lang.IllegalStateException: Failed to load extension class(interface: interface com.alibaba.dubbo.container.Container, class line: com.alibaba.dubbo.container.logback.LogbackContainer) in jar:file:/opt/services/ifc-captcha-dubbo-service/lib/dubbo-2.5.3.jar!/META-INF/dubbo/internal/com.alibaba.dubbo.container.Container, cause: ch/qos/logback/core/Context
java.lang.IllegalStateException: Failed to load extension class(interface: interface com.alibaba.dubbo.container.Container, class line: com.alibaba.dubbo.container.logback.LogbackContainer) in jar:file:/opt/services/ifc-captcha-dubbo-service/lib/dubbo-2.5.3.jar!/META-INF/dubbo/internal/com.alibaba.dubbo.container.Container, cause: ch/qos/logback/core/Context
        at com.alibaba.dubbo.common.extension.ExtensionLoader.loadFile(ExtensionLoader.java:685)
        at com.alibaba.dubbo.common.extension.ExtensionLoader.loadExtensionClasses(ExtensionLoader.java:591)
        at com.alibaba.dubbo.common.extension.ExtensionLoader.getExtensionClasses(ExtensionLoader.java:567)
        at com.alibaba.dubbo.common.extension.ExtensionLoader.getDefaultExtensionName(ExtensionLoader.java:358)
        at com.alibaba.dubbo.container.Main.main(Main.java:50)
Caused by: java.lang.NoClassDefFoundError: ch/qos/logback/core/Context
        at java.lang.Class.forName0(Native Method)
        at java.lang.Class.forName(Class.java:278)
        at com.alibaba.dubbo.common.extension.ExtensionLoader.loadFile(ExtensionLoader.java:627)
        ... 4 more
Caused by: java.lang.ClassNotFoundException: ch.qos.logback.core.Context
        at java.net.URLClassLoader$1.run(URLClassLoader.java:366)
        at java.net.URLClassLoader$1.run(URLClassLoader.java:355)
        at java.security.AccessController.doPrivileged(Native Method)
        at java.net.URLClassLoader.findClass(URLClassLoader.java:354)
        at java.lang.ClassLoader.loadClass(ClassLoader.java:425)
        at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:308)
        at java.lang.ClassLoader.loadClass(ClassLoader.java:358)
        ... 7 more

(2) com.alibaba.dubbo.container.jetty.JettyContainer:
java.lang.IllegalStateException: Failed to load extension class(interface: interface com.alibaba.dubbo.container.Container, class line: com.alibaba.dubbo.container.jetty.JettyContainer) in jar:file:/opt/services/ifc-captcha-dubbo-service/lib/dubbo-2.5.3.jar!/META-INF/dubbo/internal/com.alibaba.dubbo.container.Container, cause: org/mortbay/jetty/Connector
java.lang.IllegalStateException: Failed to load extension class(interface: interface com.alibaba.dubbo.container.Container, class line: com.alibaba.dubbo.container.jetty.JettyContainer) in jar:file:/opt/services/ifc-captcha-dubbo-service/lib/dubbo-2.5.3.jar!/META-INF/dubbo/internal/com.alibaba.dubbo.container.Container, cause: org/mortbay/jetty/Connector
        at com.alibaba.dubbo.common.extension.ExtensionLoader.loadFile(ExtensionLoader.java:685)
        at com.alibaba.dubbo.common.extension.ExtensionLoader.loadExtensionClasses(ExtensionLoader.java:591)
        at com.alibaba.dubbo.common.extension.ExtensionLoader.getExtensionClasses(ExtensionLoader.java:567)
        at com.alibaba.dubbo.common.extension.ExtensionLoader.getDefaultExtensionName(ExtensionLoader.java:358)
        at com.alibaba.dubbo.container.Main.main(Main.java:50)
Caused by: java.lang.NoClassDefFoundError: org/mortbay/jetty/Connector
        at java.lang.Class.forName0(Native Method)
        at java.lang.Class.forName(Class.java:278)
        at com.alibaba.dubbo.common.extension.ExtensionLoader.loadFile(ExtensionLoader.java:627)
        ... 4 more
Caused by: java.lang.ClassNotFoundException: org.mortbay.jetty.Connector
        at java.net.URLClassLoader$1.run(URLClassLoader.java:366)
        at java.net.URLClassLoader$1.run(URLClassLoader.java:355)
        at java.security.AccessController.doPrivileged(Native Method)
        at java.net.URLClassLoader.findClass(URLClassLoader.java:354)
        at java.lang.ClassLoader.loadClass(ClassLoader.java:425)
        at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:308)
        at java.lang.ClassLoader.loadClass(ClassLoader.java:358)
        ... 7 more
, dubbo version: 2.5.3, current host: 127.0.0.1

问题分析:

一开始当jetty的问题处理,一直到排查为什么找不到jetty包,怎么才能加载到jetty包,看下dubbo包

看了启动脚本,也是用srping方式,没有jetty,可能配置的不能找不到spring时默认就用jetty

查证后发现dubbo.container=spring 是配置错了,有空格

其实报错的第一行已经很明确了,DUBBO] No such extension com.alibaba.dubbo.container.Container by name spring  , possible causes: ,对dubbo不太熟绕了很多路

Dubbo 中,如果出现 `No such extension org.apache.dubbo.registry.RegistryFactory by name eureka` 的错误,通常表示 Dubbo 无法找到名为 `eureka` 的注册中心扩展实现。此问题的根源可能涉及多个方面,包括配置错误、依赖缺失或 SPI 文件配置不当等。 ### 可能原因及解决方案 #### 1. **依赖缺失** Dubbo 通过 SPI(Service Provider Interface)机制加载扩展实现。如果使用了 Eureka 注册中心但未正确引入相关依赖,将导致 Dubbo 无法找到该扩展。 - **解决方案**:确保项目中引入了 `dubbo-registry-eureka` 相关依赖。以 Maven 为例: ```xml <dependency> <groupId>org.apache.dubbo</groupId> <artifactId>dubbo-registry-eureka</artifactId> <version>2.7.x</version> <!-- 根据实际版本填写 --> </dependency> ``` #### 2. **SPI 文件配置错误** Dubbo 通过 `META-INF/dubbo/org.apache.dubbo.registry.RegistryFactory` 文件来注册扩展实现。如果该文件缺失或未正确配置 `eureka` 的实现类,将导致无法加载该扩展。 - **解决方案**:检查 `resources/META-INF/dubbo/org.apache.dubbo.registry.RegistryFactory` 文件是否存在,并确认其内容是否包含正确的 Eureka 实现类,例如: ``` eureka=org.apache.dubbo.registry.eureka.EurekaRegistryFactory ``` #### 3. **配置文件中注册中心地址错误** 如果在配置文件中指定了 `eureka` 作为注册中心的名称,但地址格式不正确,也可能导致 Dubbo 无法识别该扩展。 - **解决方案**:确保在 Spring 配置文件中正确配置 Eureka 注册中心地址。例如: ```xml <dubbo:registry address="eureka://localhost:8761" /> ``` 此外,确保 Eureka 服务器已启动并可访问。 #### 4. **版本兼容性问题** 某些 Dubbo 版本可能对 Eureka 注册中心的支持存在兼容性问题,尤其是在使用较旧版本的 Dubbo 时。 - **解决方案**:升级到 Dubbo 的最新稳定版本,确保对 Eureka 注册中心的支持更加完善。同时,确认 Eureka 服务端版本与 Dubbo 客户端兼容。 #### 5. **自定义扩展覆盖默认配置** 如果项目中存在自定义的 `RegistryFactory` 扩展,并且未正确实现 `eureka` 的配置,可能导致 Dubbo 无法加载默认的 Eureka 扩展。 - **解决方案**:检查是否有自定义的 `RegistryFactory` 实现,并确保其不会干扰默认的扩展加载机制。可以尝试移除或注释掉自定义配置,验证是否能正常加载 Eureka 扩展。 #### 6. **类路径问题** 如果项目构建过程中未正确打包依赖,或运行时类路径未包含必要的扩展类,也可能导致 Dubbo 无法找到 `eureka` 扩展。 - **解决方案**:确保构建工具(如 Maven 或 Gradle)正确打包所有依赖,并在运行时类路径中包含 `dubbo-registry-eureka` 及其相关依赖。 --- ### 总结 当 Dubbo 报错 `No such extension org.apache.dubbo.registry.RegistryFactory by name eureka` 时,主要原因可能包括依赖缺失、SPI 文件配置错误、注册中心地址配置错误、版本兼容性问题、自定义扩展干扰或类路径问题。通过检查依赖、SPI 配置、注册中心地址、版本兼容性、自定义扩展及类路径,可以有效解决该问题。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值