【想进大厂还不会阅读源码】ShenYu源码-支持motan协议

相信大家碰到源码时经常无从下手🙃,不知道从哪开始阅读,面对大量代码晕头转向,索性就读不下去了,又浪费了一次提升自己的机会😭。

我认为有一种方法 ,可以解决大家的困扰!那就是通过阅读某一次开源的【PR】、【ISSUE】,从这个入口出发去阅读源码!!

至此,我们发现自己开始从大量堆砌的源码中脱离开来😀。豁然开朗,柳暗花明又一村。

ShenYu是一个异步的,高性能的,跨语言的,响应式的 API 网关。有关ShenYu的介绍可以戳这

一、前瞻

OK,开始我们今天的PR阅读,PR提交如下图。

翻译过来,意思就是:原来的插件只支持motan2协议 ,并且是硬编码的。本次修改使MotanRpcExt 得到增强以支持motan协议。同时支持根据客户端注册的RPC协议自动匹配。

简单来说就是增强motan插件

我们可以通过以上的线索来思考我们本次的阅读线索:

  1. 贡献者是做了什么实现了增强motan插件
  2. 这个motan的插件的功能是什么

二、探索

对于线索2,我们可以看下ShenYu项目的模块。

ShenYu既然是一个网关,它必须要调用到微服务节点 ,而上图中有各个微服务开源中间件的集成:grpc、dubbo等。可以知道motan插件的功能,就是提供给ShenYu网关一个支持调用motan微服务节点的功能。

那我们继续线索1的探索。

整体看下本次的所有提交,可以分为两部分 ,负责监听微服务节点消息的监听端 、调用微服务节点的调用端

那我们先看看调用端修改了什么?

java 复制代码
// 旧代码
try {
    responseFuture = (ResponseFuture) commonClient.asyncCall(metaData.getMethodName(), params, Object.class);
} catch (Throwable e) {
    LOG.error("Exception caught in MotanProxyService#genericInvoker.", e);
    return null;
}

// 新代码
try {
    Request request = MotanClientUtil.buildRequest(reference.getServiceInterface(), metaData.getMethodName(), metaData.getParameterTypes(), params, null);
    responseFuture = (ResponseFuture)commonClient.asyncCall(request, Object.class);
} catch (Throwable e) {
    LOG.error("Exception caught in MotanProxyService#genericInvoker.", e);
    return null;
}

很明显,新代码新增了几个入参reference.getServiceInterface()metaData.getParameterTypes(),推测是为了支持motan协议的作用,这一部分我们发现收获的东西不多,那先看看监听端。

监听端做了以下修改。和调用端同样,新增了入参

我们很好奇,支持一个新的协议这么简单吗,只是新增了几个入参?

其实可以思考下,本次PR提交贡献的新motan协议和旧的motan2协议,两者本质上都是motan协议 。而前者相比旧协议motan2,需要在旧协议的基础上新增以上的入参以支持其功能。

这也解答了上文我们思考的线索1:

贡献者是做了什么实现了增强motan插件

好了,今天的分享就到这了。大家能否感受到通过PR这种方式来阅读源码的乐趣呢

博主的GitHub也有一些读者感兴趣的知识可以学习😍,GitHub地址戳这

创作不易,不妨点赞、收藏、关注支持一下,各位的支持就是我创作的最大动力❤️

相关推荐
会讲英语的码农2 小时前
php基础
开发语言·后端·php
SoFlu软件机器人5 小时前
飞算 JavaAI 与 Spring Boot:如何实现微服务开发效率翻倍?
spring boot·后端·微服务
jack_xu7 小时前
经典大厂面试题——缓存穿透、缓存击穿、缓存雪崩
java·redis·后端
Xiaoyu Wang8 小时前
Go协程的调用与原理
开发语言·后端·golang
OpenLoong 开源社区8 小时前
技术视界 | 开源新视野: 人形机器人技术崛起,开源社区驱动创新
机器人·开源
爱发飙的蜗牛9 小时前
springboot--web开发请求参数接收注解
java·spring boot·后端
橘猫云计算机设计9 小时前
springboot-基于Web企业短信息发送系统(源码+lw+部署文档+讲解),源码可白嫖!
java·前端·数据库·spring boot·后端·小程序·毕业设计
程序猿chen9 小时前
JVM考古现场(二十五):逆熵者·时间晶体的永恒之战(进阶篇)
java·jvm·git·后端·程序人生·java-ee·改行学it
细心的莽夫10 小时前
Elasticsearch复习笔记
java·大数据·spring boot·笔记·后端·elasticsearch·docker
程序员阿鹏10 小时前
实现SpringBoot底层机制【Tomcat启动分析+Spring容器初始化+Tomcat 如何关联 Spring容器】
java·spring boot·后端·spring·docker·tomcat·intellij-idea