- 1、本文档共16页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
RPC原理及RPC实例分析课案
RPC原理及RPC实例分析
第一部分
在学校期间大家都写过不少程序,比如写个hello world服务类,然后本地调用下,如下所示。这些程序的特点是服务消费方和服务提供方是本地调用关系。
[java] view plain copy print?
public class Test {
public static void main(String[] args) {
HelloWorldService helloWorldService = new HelloWorldServiceImpl();
helloWorldService.sayHello(test);
}
}
而一旦踏入公司尤其是大型互联网公司就会发现,公司的系统都由成千上万大大小小的服务组成,各服务部署在不同的机器上,由不同的团队负责。
这时就会遇到两个问题:
要搭建一个新服务,免不了需要依赖他人的服务,而现在他人的服务都在远端,怎么调用?
其它团队要使用我们的新服务,我们的服务该怎么发布以便他人调用?下文将对这两个问题展开探讨。
1. 如何调用他人的远程服务?
由于各服务部署在不同机器,服务间的调用免不了网络通信过程,服务消费方每调用一个服务都要写一坨网络通信相关的代码,不仅复杂而且极易出错。
如果有一种方式能让我们像调用本地服务一样调用远程服务,而让调用者对网络通信这些细节透明,那么将大大提高生产力,比如服务消费方在执行helloWorldService.sayHello(“test”)时,实质上调用的是远端的服务。这种方式其实就是RPC(Remote Procedure Call Protocol),在各大互联网公司中被广泛使用,如阿里巴巴的hsf、dubbo(开源)、Facebook的thrift(开源)、Google grpc(开源)、Twitter的finagle(开源)等。
要让网络通信细节对使用者透明,我们需要对通信细节进行封装,我们先看下一个RPC调用的流程涉及到哪些通信细节:
服务消费方(client)调用以本地调用方式调用服务;
client stub接收到调用后负责将方法、参数等组装成能够进行网络传输的消息体;
client stub找到服务地址,并将消息发送到服务端;
server stub收到消息后进行解码;
server stub根据解码结果调用本地的服务;
本地服务执行并将结果返回给server stub;
server stub将返回结果打包成消息并发送至消费方;
client stub接收到消息,并进行解码;
服务消费方得到最终结果。
RPC的目标就是要2~8这些步骤都封装起来,让用户对这些细节透明。
1.1 怎么做到透明化远程服务调用?
怎么封装通信细节才能让用户像以本地调用方式调用远程服务呢?对Java来说就是使用代理!java代理有两种方式:
jdk 动态代理
字节码生成
尽管字节码生成方式实现的代理更为强大和高效,但代码维护不易,大部分公司实现RPC框架时还是选择动态代理方式。
下面简单介绍下动态代理怎么实现我们的需求。我们需要实现RPCProxyClient代理类,代理类的invoke方法中封装了与远端服务通信的细节,消费方首先从RPCProxyClient获得服务提供方的接口,当执行helloWorldService.sayHello(“test”)方法时就会调用invoke方法。
[java] view plain copy print?
public class RPCProxyClient implements java.lang.reflect.InvocationHandler{
private Object obj;
public RPCProxyClient(Object obj){
this.obj=obj;
}
/**
* 得到被代理对象;
*/
public static Object getProxy(Object obj){
return java.lang.reflect.Proxy.newProxyInstance(obj.getClass().getClassLoader(),
obj.getClass().getInterfaces(), new RPCProxyClient(obj));
}
/**
* 调用此方法执行
*/
public Object invoke(Object pr
您可能关注的文档
- RFID之M1卡数据分析.doc
- 制作电子小报.ppt
- 判读等高线地形图.ppt
- 刮板输送机48学时.pptx
- 制作规范.ppt
- 制作漂亮精致日历图标的PS教程(上).docx
- RFID在图书管理系统中的应用.docx
- revit入门Word排版调整版,向内容原著致敬课案.doc
- 制冷压缩机第一章课件.ppt
- 制冷原理与装置-制冷剂与载冷剂课件.ppt
- 玻璃棉项目风险评估报告.docx
- Unit 6 How do you feel Part A Let's talk Let's learn大单元整体说课稿(表格式)-2024-2025学年人教PEP版英语六年级上册.docx
- 《烙饼》(说课稿)-2023-2024学年四年级下册数学北师大版.docx
- 红外光学石英玻璃项目安全风险评价报告.docx
- 24 京剧趣谈(Word说课稿)2024-2025学年六年级语文上册同步备课(统编版).docx
- 2025年高考物理复习十五:带电粒子在交变电、磁场中的运动(含解析).pdf
- 2022年初级电工作业考试题库及答案.pdf
- 生活用橡胶制品:塑胶盒项目安全风险评价报告.docx
- 供配电测控保护装置项目安全风险评价报告.docx
- 2022年5月全国《法律职业资格考试》试卷二甄题同步测试题含答案及解析.pdf
文档评论(0)