设为首页 加入收藏

TOP

Java 动态代理及 RPC 框架介绍(二)
2018-08-06 10:54:45 】 浏览:242
Tags:Java 动态 代理 RPC 框架 介绍
美的。RPC方法的调用和普通的方法并无二异,调用者不需要操心具体的实现,这是抽象提供的威力。
实现上,它将函数调用方和函数的提供方分散在两个不同的进程上,中间使用网络通信来进行数据交互。

动态代理就是实现RPC的技术之一。只要理解了动态代理和RPC,我们很容易发现这样一个事实:
RPC调用其实是对远程另外一台机器进程上的对象的代理。

仔细思考RPC调用的数据流流向,就能梳理出这样的思路:

  1. 调用方调用本地的RPC代理方法,将参数提供给该方法。
  2. 不同的RPC代理方法被转发到一个统一的处理中心,该处理中心知道调用的是那个函数,参数是什么。
  3. 该处理中心将调用的信息封装打包,通过网络发送给另外一个进程。
  4. 另外一个进程接受到调用进程发送过来的数据包。
  5. 该进程根据数据包中记录的RPC调用信息,将调用分发给对应的被代理对象的对应方法去执行。
  6. 返回的话思路类似。

显而易见,第二步,需要使用动态代理将分散的函数调用转发到一个统一的处理中心;第五步,将统一收集来的调用信息分发给具体的函数执行,显然使用反射做到这一点。
有了这个思路,通过利用动态代理,反射,和网络编程技术,实现一个简易版的RPC框架也就不难了。
考虑到本文是介绍动态代理的,关于RPC的细节实现有时间新开一篇博文分析。

4. 最后

总得来说,通过一定的思考,个人觉得动态代理的核心在于:将分散的对对象不同方法的调用转发到一个同一的处理函数中来。

有了这个关键点,很多其它技术的实现需要借助于动态代理的这一个关键点实现,也因此动态代理也有着这么多的应用。

首页 上一页 1 2 下一页 尾页 2/2/2
】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
上一篇Java结合keytool实现非对称加密和.. 下一篇SpringBoot | 第四章 :日志管理

最新文章

热门文章

Hot 文章

Python

C 语言

C++基础

大数据基础

linux编程基础

C/C++面试题目