RPC微服务架构:RPC个人浅析(绝对干货)

本文涉及的产品
云原生网关 MSE Higress,422元/月
服务治理 MSE Sentinel/OpenSergo,Agent数量 不受限
注册配置 MSE Nacos/ZooKeeper,118元/月
简介: RPC微服务架构:RPC个人浅析(绝对干货)

什么是RPC?


RPC(Remote Procedure Call Protocol)远程过程调用:

我们有生产者服务器和消费者服务器,分别部署着不同的应用a、b。当我们想通过消费者服务器来调用生产者服务器的应用上提供的函数或方法时,由于这些应用不在同一个内存空间,不能够直接调用,这就需要通过借助网络来传输数据请求。就比如我们在自己的机器上写一个程序,别人是无法直接调用的,这个时候就需要通过远程服务调用,RPC应运而生了!

微服务架构是一种将单应用程序作为一套小型服务开发的方法。(因此我们可以知道,一般的小型企业是用不到微服务的)


百科官方解答


RPC是一种通过网络从远程计算机程序上请求服务,而不需要了解底层网络技术的协议。RPC协议假定某些传输协议的存在,如TCP或UDP,为通信程序之间携带信息数据。在OSI网络通信模型中,RPC跨越了传输层和应用层。RPC使得开发包括网络分布式多程序在内的应用程序更加容易。

RPC采用客户机/服务器模式。请求程序就是一个客户机,而服务提供程序就是一个服务器。首先,客户机调用进程发送一个有进程参数的调用信息到服务进程,然后等待应答信息。在服务器端,进程保持睡眠状态直到调用信息到达为止。当一个调用信息到达,服务器获得进程参数,计算结果,发送答复信息,然后等待下一个调用信息,最后,客户端调用进程接收答复信息,获得进程结果,然后调用执行继续进行。


RPC解决了什么问题?


偏技术的问题:


1.通讯问题 : 客户端和服务器端通过TCP协议进行数据的传输。

2.寻址问题 : 服务器之间的应用如何调用,如何查找到对应应用所在的IP和端口。


优点:

1.解耦:把每个系统拆分开部署在不同的服务器上。

2.避免重复开发:避免对一个系统的重复开发,当有需要的时候可以直接调用

3.方便维护


RPC具体工作流程是怎么样的?(纯个人理解,待大佬指正)


RPC需要有三方:生产者、消费者和中央管理中心。 生产者即服务提供方,消费者即服务请求方,中央管理中心(下面简称中央)是充当一个中间人的身份,可以理解为我们的房屋中介。

当生产者想要使用微服务的时候, 需要先去中央注册身份,包括IP、端口号、包括哪些类或方法等信息都需要提供给中央做记录;同时,中央会根据自己的加密规则,生成一个密钥来唯一标志该生产者。

同理,当消费者想要使用微服务的时候, 也需要先去中央注册身份,包括IP、端口号、想要访问的方法等信息都需要提供给中央做记录;同时中央根据消费者提供的信息会给消费者提供一定的权限,并根据权限来判断该消费者可以去调用哪些生产者,也会对应生成密钥。

当消费者完成注册后,通过拿到的权限,来获取对应生产者的IP、端口号和密钥等信息,并将这些信息存放在本地缓存。

当消费者发送请求时,消费者会从本地缓存读取有效数据信息,如携带着对应生产者的密钥,通过HTTP、TCP等协议进行数据传输(这里传输用到了流操作、序列化和反序列化技术,暂时不做讲解,可出门右拐进入百度),生产者接收到请求后,进行反射代理, 首先来比对密钥是否正确,正确则进行真正的请求处理工作。

到这里,一个正常简易的RPC流程算是走完了。

但是就怕意外啊,RPC还有一些保障性的工作


心跳机制: 为防止生产者服务器突发心脏病宕机,或者某天心情不好闹小情绪导致发生异常而无法使用,我们强制规定生产者需要每隔几秒(可根据具体业务自行设计)向中央发送一次心跳,来证明生产者一切健康。如果说生产者一次没有发送心跳,中央可以原谅它的小调皮,但是如果连续三次都未发送心跳,中央就会主动标记该生产者有异常,同步到消费者缓存中进行信息的更新,并对该生产者服务器进行普通生病检查,同时触发报警机制来提醒正在改bug的程序猿来为其医治。

同步机制: 当生产者服务器有新增服务器、生产者服务器减少或更换服务器的情况,中央会将生产者的信息同步到消费者缓存。

反馈与检查机制: 由于心跳机制和同步机制没有即时性,那么很多时候,生产者服务器发生问题,往往是消费者先发现,当消费者连接生产者时,一次连接不成功,尝试重连,多次连接不成功后,会从本地缓存寻找其他可用生产者服务器信息进行数据的请求,同时会把连接失败的生产者服务器信息反馈上报给中央,说明该生产者服务器偷懒不工作;中央收到反馈后,立刻去检查该生产者服务器的异常原因并尝试触发报警机制。

这样一个大体上的RPC思想算是出来了,文字不易理解,可参考下图:


20190924010534530.png


RPC中有哪些方面可以提升性能优化?


1.缓存: 缓存技术有很多种,进程缓存有jdk自带的ConcurrentHashMap缓存、功能比较丰富的Ehcache缓存等;分布式缓存有Redis和Tair等。依据我们业务需要来选择合适的缓存可以很好的提升性能。


2.数据传输流的操作: Netty作为高性能的NIO通信框架,在很多RPC框架中都有它的身影。我们也采用它当做通信服务器。

3.序列化和反序列化:

百科介绍:


序列化

(Serialization)是将对象的状态信息转换为可以存储或传输的形式的过程。在序列化期间,对象将其当前状态写入到临时或持久性存储区。以后,可以通过从存储区中读取或反序列化对象的状态,重新创建该对象。


目前互联网公司广泛使用Protobuf、Thrift、Avro等成熟的序列化解决方案来搭建RPC框架,这些都是久经考验的解决方案。当然具体使用哪种序列化还是要结合我们的业务来开展的。

4.通讯协议: 不同的通讯协议的在不同的数据结构和不同数据量时的传输性能都有所不同,也要我们看实际情况来定。我有一个想法是设计一个仿Tomcat的通讯协议,或许可以在某方面提升性能,还没实现过。

目录
相关文章
|
10天前
|
弹性计算 API 持续交付
后端服务架构的微服务化转型
本文旨在探讨后端服务从单体架构向微服务架构转型的过程,分析微服务架构的优势和面临的挑战。文章首先介绍单体架构的局限性,然后详细阐述微服务架构的核心概念及其在现代软件开发中的应用。通过对比两种架构,指出微服务化转型的必要性和实施策略。最后,讨论了微服务架构实施过程中可能遇到的问题及解决方案。
|
20天前
|
Cloud Native Devops 云计算
云计算的未来:云原生架构与微服务的革命####
【10月更文挑战第21天】 随着企业数字化转型的加速,云原生技术正迅速成为IT行业的新宠。本文深入探讨了云原生架构的核心理念、关键技术如容器化和微服务的优势,以及如何通过这些技术实现高效、灵活且可扩展的现代应用开发。我们将揭示云原生如何重塑软件开发流程,提升业务敏捷性,并探索其对企业IT架构的深远影响。 ####
33 3
|
10天前
|
Java 开发者 微服务
从单体到微服务:如何借助 Spring Cloud 实现架构转型
**Spring Cloud** 是一套基于 Spring 框架的**微服务架构解决方案**,它提供了一系列的工具和组件,帮助开发者快速构建分布式系统,尤其是微服务架构。
108 68
从单体到微服务:如何借助 Spring Cloud 实现架构转型
|
9天前
|
运维 监控 持续交付
微服务架构解析:跨越传统架构的技术革命
微服务架构(Microservices Architecture)是一种软件架构风格,它将一个大型的单体应用拆分为多个小而独立的服务,每个服务都可以独立开发、部署和扩展。
96 36
微服务架构解析:跨越传统架构的技术革命
|
12天前
|
设计模式 负载均衡 监控
探索微服务架构下的API网关设计
在微服务的大潮中,API网关如同一座桥梁,连接着服务的提供者与消费者。本文将深入探讨API网关的核心功能、设计原则及实现策略,旨在为读者揭示如何构建一个高效、可靠的API网关。通过分析API网关在微服务架构中的作用和挑战,我们将了解到,一个优秀的API网关不仅要处理服务路由、负载均衡、认证授权等基础问题,还需考虑如何提升系统的可扩展性、安全性和可维护性。文章最后将提供实用的代码示例,帮助读者更好地理解和应用API网关的设计概念。
40 8
|
17天前
|
消息中间件 运维 Kubernetes
后端架构演进:从单体到微服务####
本文将探讨后端架构的演变过程,重点分析从传统的单体架构向现代微服务架构的转变。通过实际案例和理论解析,揭示这一转变背后的技术驱动力、挑战及最佳实践。文章还将讨论在采用微服务架构时需考虑的关键因素,包括服务划分、通信机制、数据管理以及部署策略,旨在为读者提供一个全面的架构转型视角。 ####
30 1
|
19天前
|
弹性计算 运维 开发者
后端架构优化:微服务与容器化的协同进化
在现代软件开发中,后端架构的优化是提高系统性能和可维护性的关键。本文探讨了微服务架构与容器化技术如何相辅相成,共同推动后端系统的高效运行。通过分析两者的优势和挑战,我们提出了一系列最佳实践策略,旨在帮助开发者构建更加灵活、可扩展的后端服务。
|
19天前
|
消息中间件 运维 Cloud Native
云原生架构下的微服务优化策略####
本文深入探讨了云原生环境下微服务架构的优化路径,针对服务拆分、通信效率、资源管理及自动化运维等核心环节提出了具体的优化策略。通过案例分析与最佳实践分享,旨在为开发者提供一套系统性的解决方案,以应对日益复杂的业务需求和快速变化的技术挑战,助力企业在云端实现更高效、更稳定的服务部署与运营。 ####
|
9天前
|
Cloud Native API 持续交付
云原生架构下的微服务治理策略与实践####
本文旨在探讨云原生环境下微服务架构的治理策略,通过分析当前面临的挑战,提出一系列实用的解决方案。我们将深入讨论如何利用容器化、服务网格(Service Mesh)等先进技术手段,提升微服务系统的可管理性、可扩展性和容错能力。此外,还将分享一些来自一线项目的经验教训,帮助读者更好地理解和应用这些理论到实际工作中去。 ####
19 0
|
17天前
|
负载均衡 Java 持续交付
深入解析微服务架构中的服务发现与负载均衡
深入解析微服务架构中的服务发现与负载均衡
41 0