吹得这么牛皮的RPC,到底是个什么鬼?该如何实现呢?

点击上方“java大数据修炼之道”,选择“设为星标

优质文章, 第一时间送达

作者:张丰哲
原文:https://www.jianshu.com/p/29d75a25eeaf

本文经原作者授权转载

# 前言

在实际后台服务开发中,比如订单服务(开发者A负责)需要调用商品服务(开发者B负责),那么开发者B会和A约定调用API,以接口的形式提供给A。通常都是B把API上传到Maven私服,然后B开始写API的实现,A只需要引入API依赖进行开发即可。

吹得这么牛皮的RPC,到底是个什么鬼?该如何实现呢?_第1张图片

订单服务调用商品服务

上图简单的描述了RPC在实际场景中的应用,我们在开发中当然是利用现有的RPC框架来快速实现业务需求,比如百度开源了baidu-rpc,阿里的Dubbo早已声名在外,腾讯自己玩TAF。本篇博客将实现一个迷你版的RPC,探索下RPC底层实现的奥秘!

# 动手实现RPC

商品服务工程

吹得这么牛皮的RPC,到底是个什么鬼?该如何实现呢?_第2张图片

注意,我将商品服务的API以及实现分为Maven的2个模块来开发。这里,我们想给定一个商品ID,查询得到商品对象信息。


商品对象

吹得这么牛皮的RPC,到底是个什么鬼?该如何实现呢?_第3张图片

吹得这么牛皮的RPC,到底是个什么鬼?该如何实现呢?_第4张图片

要注意的是,Product是可以被序列化的,Why?

很显然,订单系统调用商品系统的时候,需要商品系统返回一个商品,必然涉及到发生网络传输,这就涉及对象的序列化和反序列化了。

商品查询API接口

订单系统调用商品服务

吹得这么牛皮的RPC,到底是个什么鬼?该如何实现呢?_第5张图片

在订单系统工程中需要引入商品服务API依赖。

在上图代码中,最重要的就是rpc方法了!


rpc实现方法

吹得这么牛皮的RPC,到底是个什么鬼?该如何实现呢?_第6张图片

第一,我们看到了Proxy.newProxyInstance,很显然在进行动态代理。也即是说,在订单服务调用商品服务的代码中,我们先是通过动态代理返回一个代理的IProductService类型对象,这意味着当代理对象调用queryById方法的时候,会自动调用invoke方法!

第二,我们看看invoke到底做了些什么?

它本质上就是进行Socket通信,那么它需要传递什么信息给到商品服务呢?

我们知道订单系统就是想调用商品服务的某个类的某个方法,然后把这个方法的返回结果传输给订单系统!

想一想,如何调用某个类的某个方法呢?

只要我们能确定这个类的全限定类名、确定方法名、确定方法的参数类型,给定方法需要的具体参数,通过反射就能实现。

商品服务调用后得到的结果,我们序列化写入Socket流中,在订单系统中反序列化得到对象即可。

第三,这里需要思考一个问题:在订单系统中我们只知道商品服务的API,并不知道这背后的API到底是如何实现的,所以我们需要有一个映射,就是商品服务的API到商品服务的实现的一个映射关系,其实这就是所谓的服务的注册!

商品API的具体实现

吹得这么牛皮的RPC,到底是个什么鬼?该如何实现呢?_第7张图片

吹得这么牛皮的RPC,到底是个什么鬼?该如何实现呢?_第8张图片

商品服务

吹得这么牛皮的RPC,到底是个什么鬼?该如何实现呢?_第9张图片

从这里,可以清晰的看到,商品服务读取了订单系统调用商品系统时发送的数据,利用反射机制,进行方法调用,并把调用结果写入Socket输出流。


运行结果

吹得这么牛皮的RPC,到底是个什么鬼?该如何实现呢?_第10张图片

启动商品服务后,通过订单系统发起对商品服务的调用。


有热门推荐????灵魂拷问:你写的SQL一般有几个join ?
30 分钟学会如何使用 ShiroJVM 史上最最最完整深入解析5分钟 教大家搭建免费个人博客太火了,这些牛逼的Java代码技巧,肯定能让你目瞪口呆!
300 行代码带你秒懂 Java 多线程!非常有意思的SQL优化经历:从30248.271s到0.001s
绝对干货: 在Java项目中打印错误日志的正确姿势,排查问题更方便,非常实用!
干货分享:扫码关注下面的公众号后台回复“资源”领取1T编程资源,里面包含各种学习资料。帮助大家更快的学习编程与进阶+资料
想充电就关注Java大数据修炼之道
- end -
关注Java大数据修炼之道每天学习Java技术,你想学的Java知识这里都有!

文章有帮助的话,在看,转发吧。

谢谢支持哟 (*^__^*)

你可能感兴趣的:(吹得这么牛皮的RPC,到底是个什么鬼?该如何实现呢?)