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的通讯协议,或许可以在某方面提升性能,还没实现过。

目录
相关文章
|
1天前
|
缓存 运维 监控
探索微服务架构中的API网关模式
在微服务架构的海洋中,API网关是连接客户端与众多微服务群岛之间的桥梁。本文将深入探讨API网关的设计原则、核心功能以及在现代软件架构中的关键作用,同时分析其在实际应用中的效益和面临的挑战。
|
1天前
|
存储 消息中间件 API
“论微服务架构及其应用”写作框架,软考高级,系统架构设计师
论微服务架构及其应用近年来,随着互联网行业的迅猛发展,公司或组织业务的不断扩张,需求的快速变化以及用户量的不断增加,传统的单块(Monolithic)软件架构面临着越来越多的挑战,已逐渐无法适应互联网时代对软件的要求。在这一背景下,微服务架构模式(MicroserviceArchitecturePattern)逐渐流行,它强调将单一业务功能开发成微服务的形式,每个微服务运行在一个进程中;采用HTTP等通用协议和轻量级API实现微服务之间的协作与通信。这些微服务可以使用不同的开发语言以及不同数据存储技术,能够通过自动化部署工具独立发布,并保持最低限制的集中式管理。
|
1天前
|
架构师 API 持续交付
探索微服务架构的演进与挑战
【6月更文挑战第24天】在软件开发领域,微服务架构作为一种灵活、可扩展的设计模式,已经引领了多年的技术潮流。本文将深入探讨微服务架构从兴起到成熟的发展路径,揭示其在现代应用中面临的主要挑战,并提供针对性的解决策略。通过分析微服务的设计理念、实践案例和未来趋势,我们旨在为开发者和架构师提供一份实用的指南,帮助他们在构建和维护复杂系统时做出明智的决策。
|
1天前
|
运维 负载均衡 Cloud Native
云原生架构下的微服务治理实践
【6月更文挑战第24天】在云原生的浪潮下,微服务治理成为确保系统弹性、可维护性和可观测性的关键。本文通过深入分析微服务治理的核心要素与挑战,结合前沿技术和工具,提出一套实用的微服务治理策略,旨在帮助开发者和架构师构建更加稳定、高效且易于管理的分布式系统。
|
2天前
|
监控 Java 微服务
从单体到微服务:Java架构演进之路
从单体到微服务:Java架构演进之路
|
1天前
|
监控 Java API
淘客返利平台的微服务架构实现
淘客返利平台的微服务架构实现
|
1天前
|
自然语言处理 负载均衡 Java
Java中的微服务架构实现方法*
Java中的微服务架构实现方法*
|
1天前
|
NoSQL Java 数据库
优化基于阿里云的微服务架构下的数据库访问性能
在应对大型电商项目中数据库访问性能瓶颈问题时,团队通过阿里云工具分析发现高QPS、慢查询和不合理数据交互是关键。优化措施包括:1) 索引优化,针对慢查询添加或调整索引;2) 开启读写分离,使用RDS读写分离功能和DRDS进行水平拆分;3) 引入Redis缓存热点数据,减少直接数据库访问;4) 服务化数据访问,降低跨服务数据库调用;5) 使用Sentinel进行限流和熔断,保护数据库资源。这些改进显著提升了系统响应速度和用户体验。
|
1月前
|
负载均衡 Dubbo Java
Dubbo 3.x:探索阿里巴巴的开源RPC框架新技术
随着微服务架构的兴起,远程过程调用(RPC)框架成为了关键组件。Dubbo,作为阿里巴巴的开源RPC框架,已经演进到了3.x版本,带来了许多新特性和技术改进。本文将探讨Dubbo 3.x中的一些最新技术,包括服务注册与发现、负载均衡、服务治理等,并通过代码示例展示其使用方式。
132 9
|
1月前
|
设计模式 负载均衡 网络协议
【分布式技术专题】「分布式技术架构」实践见真知,手把手教你如何实现一个属于自己的RPC框架(架构技术引导篇)
【分布式技术专题】「分布式技术架构」实践见真知,手把手教你如何实现一个属于自己的RPC框架(架构技术引导篇)
83 0

热门文章

最新文章