spring-cloud-alibaba-dubbo踩坑记
在https://start.aliyun.com/bootstrap.html下载了示例程序,用的版本如下:
spring-boot:2.3.7.RELEASE
spring-cloud-alibaba:2.2.2.RELEASE
spring-cloud-alibaba-dubbo:2.2.2.RELEASE
发现有很多坑:
【No provider available from registry localhost:9090 for service】
使用默认的dubbo.registry.address配置,会一直报这个错误,看github的讨论,这个一直以来都有兼容性问题,现在也还未很好的解决。
但可以通过以下配置进行处理:
- dubbo.registry.address=nacos://127.0.0.1:8848
- dubbo.registry.group=dubbo
- dubbo.config-center.group=dubbo
但这样的配置,nacos会多出一些service:
而且必须是服务提供者先启动,不然服务消费者就会报错启动不了。
后期我尝试使用dubbo-admin 配置nacos,可以看到服务列表,但却看不到元数据,尝试了各种办法也未解决。
- admin.registry.address=nacos://127.0.0.1:8848?group=dubbo&namespace=public
- admin.config-center=nacos://127.0.0.1:8848?group=dubbo
- admin.metadata-report.address=nacos://127.0.0.1:8848?group=dubbo
最后是换了nacos版本解决了,之前用的是2.0.3,用最新的2.1.0就显示元数据了。
但dubbo-admin启动后,服务提供者跟服务消费者一直会报如下错误:
java.lang.IllegalArgumentException: Service not found:com.alibaba.cloud.dubbo.service.DubboMetadataService, getMetadataInfo。
这个或许是spring-cloud-alibaba-dubbo跟dubbo-admin不兼容的原因,因为spring-cloud-alibaba-dubbo是将DubboMetadataService作为服务信息,
但dubbo-admin是将MetadataService作为服务信息,,dubbo-admin调用远程的DubboMetadataService时候报错,因为DubboMetadataService没有getMetadataInfo方法。
另外版本对应也很重要,spring-cloud-alibaba-dubbo使用的dubbo版本是2.7.8(MetadataService没有getMetadataInfo方法),dubbo-admin使用的是dubbo版本是3.0.2.1(MetadataService有getMetadataInfo方法)!
最后看到了这样一个帖子,说是spring-cloud-alibaba-dubbo还有一些问题,希望从spring-cloud-alibaba移除,期待后续能处理好。
https://github.com/alibaba/spring-cloud-alibaba/issues/2398
目前最新版的spring-cloud-alibaba已经spring-cloud-alibaba-dubbo移除了,所以想继续使用dubbo服务的,可以使用spring boot跟原生dubbo。
可以参考【例子中,dubbo的版本我用的是3.0.9】:
https://github.com/apache/dubbo/tree/3.0/dubbo-demo/dubbo-demo-spring-boot
https://github.com/nacos-group/nacos-examples/tree/master/nacos-spring-boot-example
在过程中发现这样一个有趣的问题,就是单纯的服务消费者工程【没有暴露服务】未作为一个服务注册到nacos。
如果是服务提供者,不仅仅会把服务注册到nacos,也会把工程作为一个服务注册到nacos。
这里看了源码才知道,在ServiceInstanceHostPortCustomizer的customize方法中,如果有工程中有暴露服务,会设置工程服务实例的端口以及host信息,
在AbstractServiceDiscovery类的register方法中就有判断是否一个有效【设置了host跟端口】的服务实例,是的话就会把工程作为一个服务注册到nacos。
所以这也就解释了为什么单纯的服务消费者不会注册到nacos,以为它没有暴露服务,就不会设置工程实例的端口以及host信息,就不是一个有效的服务,所以不会进行注册。
也可以解释为什么dubbo-admin需要暴露一个MockService服务,这样可以把dubbo-admin工程也作为一个服务注册到nacos,dubbo-admin使用的dubbo版本是3.0.2.1,
可以看DubboBootstrap类的doStart()方法,也是根据是否有暴露服务来决定是否将工程作为一个服务注册到nacos,跟demo例子的版本【3.0.9】不一样,但是道理一样。
spring-cloud-alibaba-dubbo踩坑记的更多相关文章
- Spring Cloud Alibaba系列之分布式服务组件Dubbo
本博客的例子代码可以在github找到下载链接:代码下载 SpringBoot.SpringCloud Alibaba系列博客专栏:链接 1.分布式理论 1.1.分布式基本定义 <分布式系统原理 ...
- Spring Cloud Alibaba到底坑不坑?
之前我发过一篇<说说我为什么看好Spring Cloud Alibaba>,然后这两天有网友给我转了这篇文章<坑爹项目spring-cloud-alibaba,我们也来一个>, ...
- Spring Cloud Alibaba
Spring Cloud Alibaba Dubbo Dubbo Dubbo 系列 [Dubbo 系列总结] [Dubbo 系列(01)最简使用姿态] [Dubbo 系列(02)整体架构] Dubbo ...
- 厉害了,Spring Cloud Alibaba 发布 GA 版本!
? 小马哥 & Josh Long ? 喜欢写一首诗一般的代码,更喜欢和你共同 code review,英雄的相惜,犹如时间沉淀下来的对话,历久方弥新. 相见如故,@杭州. 4 月 18 日, ...
- Spring Cloud Alibaba发布第二个版本,Spring 发来贺电
还是熟悉的面孔,还是熟悉的味道,不同的是,这次的配方升级了. 今年10月底,Spring Cloud联合创始人Spencer Gibb在Spring官网的博客页面宣布:阿里巴巴开源 Spring Cl ...
- Spring 社区的唯一一个国产开源项目 - Spring Cloud Alibaba 毕业了
阿里妹导读:一年多前,Java 界最近发生了一件大事,阿里开源 Spring Cloud Alibaba,并推出首个预览版.Spring Cloud 本身是一套微服务规范,并不是一个拿来即可用的框架, ...
- Spring Cloud Alibaba生态探索:Dubbo、Nacos及Sentinel的完美结合
@ 目录 背景 一.项目框架 1.1 采用IDEA和Maven多模块进行项目搭建 1.2 模块管理及版本管理 二.微服务公共接口 2.1 定义一个公共接口Api 2.2 pom.xml 2.3 Goo ...
- 记一次 Spring 事务配置踩坑记
记一次 Spring 事务配置踩坑记 问题描述:(SpringBoot + MyBatisPlus) 业务逻辑伪代码如下.理论上,插入数据 t1 后,xxService.getXxx() 方法的查询条 ...
- Spring @Transactional踩坑记
@Transactional踩坑记 总述 Spring在1.2引入@Transactional注解, 该注解的引入使得我们可以简单地通过在方法或者类上添加@Transactional注解,实现事务 ...
- Spring Cloud与Dubbo的完美融合之手「Spring Cloud Alibaba」
很早以前,在刚开始搞Spring Cloud基础教程的时候,写过这样一篇文章:<微服务架构的基础框架选择:Spring Cloud还是Dubbo?>,可能不少读者也都看过.之后也就一直有关 ...
随机推荐
- TypeError: 'int' object is not subscriptable 报错
Python中报错TypeError: 'int' object is not subscriptable 原因:整形数据中加了下标索引 例如 #python utf-8 a = 10 b = a[0 ...
- ModuleNotFoundError:No module named 'past' 问题及解决方法
训练YOLOX时报错 ModuleNotFoundError:No module named 'past' 解决方法 使用pip安装对应的package:future pip install futu ...
- calico 关闭SNAT
calico 关闭SNAT 默认情况下,calico 访问集群外网络是通过 SNAT 成宿主机 ip 方式,在一些金融客户环境中为了能实现防火墙规则,需要直接针对 POD ip 进行进行规则配置,所以 ...
- LP1-4:功能图分析方法(白盒测试)
- System.IO.FileNotFoundException: Could not load file or assembly 'System.IO.Compression.FileSystem系统找不到指定的文件
错误:System.IO.FileNotFoundException: Could not load file or assembly 'System.IO.Compression.FileSyste ...
- 单元测试成神之路——Golang篇
这位大佬写的太好了 https://zhangyuyu.github.io/golang-unit-test/
- (app笔记)如何执行monkey命令测试稳定性
1.monkeyMonkey 就是SDK中附带的一个工具,向系统发送伪随机的用户事件流,为了测试软件的稳定性.健壮性,验证app是否出现ANR or Crush 操作: 2. adb devices ...
- 076_Master Detail 与Lookup
- 【layui】下拉控件dropdown 简单的使用
官方网站地址: http://test.microanswer.cn/page/dropdown.html 1.代码 layui.use(['index', 'table', 'form', 'dro ...
- Neuropsychological Assessment 5th
书本详情 Neuropsychological Assessment作者: Muriel Deutsch Lezak / Diane B. Howieson / Erin D. Bigler / Da ...