帮忙做快站旅游网站,微信公众平台网页制作,wordpress填写qq自动评论,核酸结果查询一、为什么要有RPC#xff1a; HTTP协议的接口#xff0c;在接口不多、系统与系统交互较少的情况下#xff0c;解决信息孤岛初期常使用的一种通信手段#xff1b;优点就是简单、直接、开发方便#xff0c;利用现成的HTTP协议进行传输。 但是#xff0c;如果是一个大型的网…一、为什么要有RPC HTTP协议的接口在接口不多、系统与系统交互较少的情况下解决信息孤岛初期常使用的一种通信手段优点就是简单、直接、开发方便利用现成的HTTP协议进行传输。 但是如果是一个大型的网站内部子系统较多、接口非常多的情况下RPC框架的好处就显示出来了首先就是长链接不必每次通信都要像HTTP一样去3次握手减少了网络开销其次RPC框架一般都有注册中心有丰富的监控管理发布、下线接口、动态扩展等对调用方来说是无感知、统一化的操作。还有就是安全性。 RPC一般配合Netty框架、Spring自定义注解来编写轻量级框架其实Netty内部是封装了Socket较新的JDK的IO一般是NIO即非阻塞IO在高并发网站中RPC的优势会很明显。 二、什么是RPC RPCRemote Procedure Call Protocol远程过程调用协议它是一种通过网络从远程计算机程序上请求服务而不需要了解底层网络技术的协议。简言之RPC使得程序能够像访问本地系统资源一样去访问远端系统资源。 比较关键的一些方面包括通讯协议、序列化、资源接口描述、服务框架、性能、语言支持等。 三、PRC架构组件
一个基本的RPC架构至少包含4个组件
1. 客户端Client服务调用方服务消费者。2. 客户端存根Client Stub存放服务端地址信息将客户端的请求参数数据信息打包成网络消息再通过网络传输发送给服务端。3. 服务端存根Server Stub接收客户端发送过来的请求消息并进行解包然后再调用本地服务进行处理。4). 服务端Server:服务的真正提供者。
具体调用过程 1. 服务消费者client客户端通过调用本地服务的方式调用需要消费的服务2. 客户端存根client stub接收到调用请求后负责将方法、入参等信息序列化组装成能够进行网络传输的消息体3. 客户端存根client stub找到远程的服务地址并且将消息通过网络发送给服务端4. 服务端存根server stub收到消息后进行解码反序列化操作5. 服务端存根server stub根据解码结果调用本地的服务进行相关处理6. 本地服务执行具体业务逻辑7. 将处理结果返回给服务端存根server stub8. 服务端存根server stub将返回结果重新打包成消息序列化并通过网络发送至消费方9. 客户端存根client stub接收到消息并进行解码反序列化10. 服务消费方得到终结果 RPC框架的实现目标是将图中2-10步2-9步完好地封装起来也就是把调用、编码/解码的过程给封装起来让用户感觉上像调用本地服务一样的调用远程服务。 四、RPC和SOA、SOAP、REST的区别
1. REST 它是HTTP协议的一种直接应用默认基于JSON作为传输格式使用简单、学习成本低、效率高但是安全性较低。
2. SOAP SOAP是一种数据交换协议规范是一种轻量的、简单的、基于XML的协议的规范。SOAP是一个重量级的协议基于XML、SOAP在安全方面是通过使用XML-Security和XML-Signature两个规范组成了WS-SecurityWS-Security实现了安全控制当前已经得到了各个厂商的支持 。
优点易用、灵活、跨语言、跨平台。
3. SOA 面向服务架构它可以根据需求通过网络对松散耦合的粗粒度应用组件进行分布式部署、组合和使用。服务层是SOA的基础可以直接被应用调用从而有效控制系统中与软件代理交互的人为依赖性。 SOA是一种粗粒度、松耦合服务架构服务之间通过简单、精确定义接口进行通讯不涉及底层编程接口和通讯模型。SOA可以看作是B/S模型、XML标准通用标记语言的子集/Web Service技术之后的自然延伸。 4. REST和SOAP、RPC有何区别呢? 没什么太大区别他们的本质都是提供可支持分布式的基础服务 大的区别在于他们各自的的特点所带来的不同应用场景。 五、RPC框架需要解决的问题
1. 如何确定客户端和服务端之间的通信协议2. 如何更高效地进行网络通信3. 服务端提供的服务如何暴露给客户端4. 客户端如何发现这些暴露的服务5. 如何更高效地对请求对象和响应结果进行序列化和反序列化操作 六、RPC的实现基础
1. 需要有非常高效的网络通信比如一般选择Netty作为网络通信框架2. 需要有比较高效的序列化框架比如谷歌的Protobuf序列化框架3. 可靠的寻址方式主要是提供服务的发现比如可以使用Zookeeper来注册服务等等4. 如果是带会话状态的RPC调用还需要有会话和状态保持的功能 七、RPC使用了哪些关键技术
1. 动态代理 在生成Client Stub客户端存根和Server Stub服务端存根是需要用到Java动态代理技术可以使用JDK提供的原生的动态代理机制也可以使用开源的CGLib代理Javassist字节码生成技术。
2. 序列化和反序列化 在网络中所有的数据都将会被转化为字节进行传送所以为了能够使参数对象在网络中进行传输需要对这些参数进行序列化和反序列化操作。 目前比较高效的开源序列化框架如Kryo、FastJson和Protobuf等。
3. 网络通信模型 出于并发性能的考虑传统的阻塞式 IO 显然不太合适因此我们需要异步的IO即 NIO。Java 提供了 NIO 的解决方案Java 7 也提供了更优秀的 NIO.2 支持。可以选择Netty或者MINA来解决NIO数据传输的问题。
4. 服务注册中心: 可选Redis、Zookeeper、Consul 、Etcd。一般使用ZooKeeper提供服务注册与发现功能解决单点故障以及分布式部署的问题(注册中心)。 八、主流RPC框架有哪些
1. RMI 利用java.rmi包实现基于Java远程方法协议(Java Remote Method Protocol) 和java的原生序列化。
2. Hessian 是一个轻量级的remoting onhttp工具使用简单的方法提供了RMI的功能。 基于HTTP协议采用二进制编解码。
3. protobuf-rpc-pro 它是一个Java类库提供了基于Google的Protocol Buffers 协议的远程方法调用的框架。基于Netty底层的NIO技术。支持TCP重用/keep-alive、SSL加密、RPC 调用取消操作、嵌入式日志等功能。
4. Thrift 它是一种可伸缩的跨语言服务的软件框架。它拥有功能强大的代码生成引擎无缝地支持C C#JavaPython和PHP和Ruby。thrift允许你定义一个描述文件描述数据类型和服务接口。依据该文件编译器方便地生成RPC客户端和服务器通信代码。 初由facebook开发用做系统内多个语言之间的RPC通信2007年由facebook贡献到Apache基金 现在是Aapache下的opensource之一 。支持多种语言之间的RPC方式的通信php语言client可以构造一个对象调用相应的服务方法来调用java语言的服务跨越语言的C/S RPC调用。底层通讯基于SOCKET。
5. Avro 出自Hadoop之父Doug Cutting在Thrift已经相当流行的情况下推出Avro的目标不仅是提供一套类似Thrift的通讯中间件更是要建立一个新的标准性的云计算的数据交换和存储的Protocol。支持HTTPTCP两种协议。
6. Dubbo Dubbo是阿里开源的一个高性能优秀的服务框架使得应用可通过高。性能的RPC实现服务的输出和输入功能可以和Spring框架无缝集成。 九、RPC的实现原理架构图 PRC的基本原理图请大家一定记住两台服务器A、B一个应用部署在A服务器上想要调用B服务器上应用提供的/方法由于不在一个内存空间不能直接调用需要通过网络来表达调用的语义和传达调用的数据。 比如说A服务器想调用B服务器上的一个方法User getUserByName(String userName)
1. 建立通信 首先要解决通讯的问题即A机器想要调用B机器首先得建立起通信连接。 主要是通过在客户端和服务器之间建立TCP连接远程过程调用的所有交换的数据都在这个连接里传输。连接可以是按需连接调用结束后就断掉也可以是长连接多个远程过程调用共享同一个连接。 通常这个连接可以是按需连接需要调用的时候就先建立连接调用结束后就立马断掉也可以是长连接客户端和服务器建立起连接之后保持长期持有不管此时有无数据包的发送可以配合心跳检测机制定期检测建立的连接是否存活有效多个远程过程调用共享同一个连接。
2. 服务寻址 要解决寻址的问题就是解决A服务器上的应用怎么告诉底层的RPC框架如何连接到B服务器如主机或IP地址以及特定的端口方法的名称名称是什么。 通常情况下我们需要提供B机器主机名或IP地址以及特定的端口然后指定调用的方法名称以及入参出参等信息这样才能完成服务的一个调用。可靠的寻址方式主要是提供服务的发现是RPC的实现基石比如可以采用Redis或者Zookeeper来注册服务等等。 2.1 从服务提供者的角度看 当服务提供者启动时需要将自己提供的服务注册到指定的注册中心以便服务消费者能够通过服务注册中心进行查找。当服务提供者由于各种原因致使提供的服务停止时需要向注册中心注销停止的服务。服务的提供者需要定期向服务注册中心发送心跳检测服务注册中心如果一段时间未收到来自服务提供者的心跳后认为该服务提供者已经停止服务则将该服务从注册中心上去掉。
2.2 从调用者的角度看 服务的调用者启动的时根据自己订阅的服务向服务注册中心查找服务提供者的地址等信息。当服务调用者消费的服务上线或者下线时注册中心会告知该服务的调用者。服务调用者下线的时候则取消订阅。
3. 网络传输
3.1 序列化 当A机器上的应用发起一个RPC调用时调用方法和其入参等信息需要通过底层的网络协议如TCP传输到B机器由于网络协议是基于二进制的所有我们传输的参数数据都需要先进行序列化Serialize或者编组marshal成二进制的形式才能在网络中进行传输。然后通过寻址操作和网络传输将序列化或者编组之后的二进制数据发送给B机器。
3.2 反序列化 当B机器接收到A机器的应用发来的请求之后又需要对接收到的参数等信息进行反序列化操作序列化的逆操作即将二进制信息恢复为内存中的表达方式然后再找到对应的方法寻址的一部分进行本地调用一般是通过生成代理Proxy去调用通常会有JDK动态代理、CGLIB动态代理、Javassist生成字节码技术等之后得到调用的返回值。
4. 服务调用 B机器进行本地调用通过代理Proxy和反射调用之后得到了返回值此时还需要再把返回值发送回A机器同样也需要经过序列化操作然后再经过网络传输将二进制数据发送回A机器而当A机器接收到这些返回值之后则再次进行反序列化操作恢复为内存中的表达方式 后再交给A机器上的应用进行相关处理一般是业务逻辑处理操作。
5. 总结 通常经过以上四个步骤之后一次完整的RPC调用算是完成了另外可能因为网络抖动等原因需要重试等。