Java分布式:RPC(远程过程调用)
Java分布式:RPC(远程过程调用)
引入RPC
比如我们有一个查询的接口IDBQuery,以及其实现类DBQueryImp,如果我们执行IDBQuery查询方法,只需要new一个DBQueryImp然后调用request方法即可,这就是本地函数调用,因为在同一个地址空间或者同一块内存,通过方法栈和参数栈就可以实现。
现在,基于高性能和高可靠等因素的考虑,你决定将系统改造为分布式应用,将很多可以共享的功能都单独拎出来,一个应用部署在A服务器上,一个应用部署在B服务器上,部署在A服务器上的应用如果想调用B服务器上提供的函数/方法,由于不在一个内存空间,不能直接调用,需要通过网络来表达调用的语义和传导调用的数据。
示意图如下