1.Java教程:dubbo源码解析-网络通信
2.Dubbo源码:跟着Demo学习基本使用
3.Dubbo调用超时那些事儿
4.我找到了Dubbo源码的源用BUG,同事纷纷说我有点东西
5.dubbo服务管理工具dubbo-admin环境搭建
Java教程:dubbo源码解析-网络通信
在之前的码引内容中,我们探讨了消费者端服务发现与提供者端服务暴露的源用相关内容,同时了解到消费者端通过内置的码引负载均衡算法获取合适的调用invoker进行远程调用。接下来,源用我们聚焦于远程调用过程,码引职教云网课助手源码在哪即网络通信的源用细节。
网络通信位于Remoting模块中,码引支持多种通信协议,源用包括但不限于:dubbo协议、码引rmi协议、源用hessian协议、码引rsync源码分析/post/
我找到了Dubbo源码的源用BUG,同事纷纷说我有点东西
某天,码引运营反馈称,源用执行一次保存操作后,后台出现3条数据,我立刻怀疑可能存在代码问题。为了确保不会误判,我要求暂停操作,保留现场,以便我进行排查。
查看新增代码,tomcat 源码调试发现是同事三歪进行的改动,他将原有的dubbo XML配置方式改为了注解方式。我询问其改动详情,得知他是更改了模块的配置方式。于是,我决定深入研究,找出问题所在。
dubbo配置方式多样,最常见的为XML配置与注解配置。我已初步推测原因,接下来将进行详细的供求平台源码调试过程。
我使用dubbo版本2.6.2进行调试。首先,针对采用@Reference注解条件下的重试次数配置,我发现调用接口时,会跳转到InvokerInvocationHandler的invoke方法。继续跟踪,最终定位到FailoverClusterInvoker的doInvoke方法。在该方法中,我关注到获取配置的retries值,发现其默认值为null,导致最终计算出的真人赛马源码重试次数为3。
采用dubbo:reference标签配置重试次数时,同样在获取属性值后,发现其默认值为0,与注解配置一致,最终计算出的重试次数为1。对比两种配置方式,我总结了以下原因:
在@Reference注解形式下,dubbo会在注入代理对象时,通过自定义驱动器ReferenceAnnotationBeanPostProcessor来注入属性。在标签形式下,虽然也使用了Autowired注解,但dubbo会使用自定义名称空间解析器DubboNamespaceHandler进行解析。
在注解形式下,当配置retries为0时,属性值在注入过程中并未被解析为null,但进入buildReferenceBean时,因nullSafeEquals方法的处理,导致默认值和实际值不一致,最终未保存到map中。而标签形式下,解析器能够正确解析出retries的值为0,避免了后续的问题。
总结发现,采用@Reference注解配置重试次数时,dubbo在注入属性过程中存在逻辑处理上的问题,导致默认值与实际值不一致。此为dubbo的一个逻辑bug。建议在不需要重试时,设置retries为-1,以确保接口的幂等性。需要重试时,设置为1或更大值。
问题解决后,我优化了文件操作,将其改为异步处理,从而缩短了主流程的时间。最终,数据出现3条的状况得以解决。
此问题已得到解决,并在后续dubbo版本2.7.3中修复,确保了在注解配置方式下,nullSafeEquals方法能够正确处理默认值与实际值一致的情况。
dubbo服务管理工具dubbo-admin环境搭建
<dubbo-admin作为dubbo服务的可视化管理工具,它允许我们配置路由、均衡和权重等服务参数。在使用它之前,确保你具备了JDK8和Zookeeper环境。前端开发需要node和npm,后端则需要maven和springroot运行环境。
首先,你可以直接下载预编译的dubbo-admin-0.6.0.jar,其中包含了必要的配置文件application.properties。在下载的压缩文件中找到这个文件,修改其中的服务中心信息,例如Zookeeper的地址。链接:pan.baidu.com/s/Dp_...,提取码:3np5。
如果你希望从源代码自建,首先从Apache GitHub仓库获取dubbo-admin源代码:pm源并重新安装。对于启动时的InetSocketAddress错误,可能需要降级到Java 8版本来解决。