🚀 优质资源分享 🚀
学习路线指引(点击解锁) | 知识定位 | 人群定位 |
---|---|---|
🧡 Python实战微信订餐小程序 🧡 | 进阶级 | 本课程是python flask+微信小程序的完美结合,从项目搭建到腾讯云部署上线,打造一个全栈订餐系统。 |
💛Python量化交易实战💛 | 入门级 | 手把手带你打造一个易扩展、更安全、效率更高的量化交易系统 |
hello,大家好呀,我是小楼。
最近一个技术群有同学at我,问我是否熟悉Dubbo,这我熟啊~
他说遇到了一个Dubbo异步调用的问题,怀疑是个BUG,提到BUG我可就不困了,说不定可以水,哦不…写一篇文章。
问题复现
遇到问题,尤其不是自己遇到的,必须要复现出来才好排查,截一个当时的聊天记录:
他的问题原话是:
今天发现一个问题 有一个dubbo接口返回类型是boolean, 把接口从同步改成异步 server 端返回true 消费端却返回false,把boolean改成Boolean就能正常返回结果 有碰到过这个问题吗
注意几个重点:
- 接口返回类型是boolean
- 同步改为异步调用返回的boolean和预期不符合
- boolean基本类型改成包装类型Boolean就能正常返回
听到这个描述,我的第一反应是这个返回结果定义为boolean肯定有问题!
《Java开发手册》中就强调了RPC接口返回最好不要使用基本类型,而要使用包装类型:
但这个是业务编码规范,如果RPC框架不能使用boolean作为返回值,岂不是个BUG?而且他强调了是同步改为异步调用才出现这种情况,说明同步没问题,有可能是异步调用的锅。
于是我顺口问了Dubbo的版本,说不定是某个版本的BUG。得到回复,是2.7.4版本的Dubbo。
于是我拉了个工程准备复现这个问题。
哎