当前位置: 首页 > news >正文

宝塔织梦网站建设万基城市建设有限公司网站

宝塔织梦网站建设,万基城市建设有限公司网站,企业建设网站有哪些,网站登录验证码是怎么做的RPC架构 RPC本质上就是一个远程调用,需要通过网络来传输数据。传输协议可以有多种选择,但考虑到可靠性,一般默认采用TCP协议。为了屏蔽网络传输的复杂性,需要封装一个单独的数据传输模块用来收发二进制数据,这个单独模…

RPC架构

RPC本质上就是一个远程调用,需要通过网络来传输数据。传输协议可以有多种选择,但考虑到可靠性,一般默认采用TCP协议。为了屏蔽网络传输的复杂性,需要封装一个单独的数据传输模块用来收发二进制数据,这个单独模块可以叫做传输模块

网络数据传输是二进制数据,涉及对象的序列化与反序列化。数据拆分协议封装。

网络传输过程中,请求数据包在数据链路层可能会因为太大而被拆分成多个数据包进行传输,为了减少被拆分的次数,从而导致整个传输时间太长,在方法调用参数或者返回值的二进制数据大于某个阈值时,可以通过压缩框架进行无损压缩,然后在另外一端用同样的压缩算法进行解压,保证数据可还原。

当一个接口有着多个服务提供者时,服务对调用方是透明的。RPC需要提供“服务发现”机制,在RPC里面维护好接口跟服务提供者地址的关系,调用方可以快速找到调用地址。

对RPC来说,每次发送请求时都需要用TCP连接,相对服务提供方IP地址,TCP连接状态是瞬息万变的,因此RPC框架里面要有连接管理器维护TCP连接的状态

有了集群之后,提供方需要管理好这些服务。RPC就需要内置一些服务治理的功能,比如服务提供方权重的设置、调用授权等一些常规治理手段。

image-20241030222942238

可扩展架构

RPC框架设计之初不可能面面俱到,如何应对技术迭代呢?

插件化架构

RPC框架中,将每个功能点抽象成一个接口,接口作为插件的契约,功能的接口与功能的实现分离,并提供接口的默认实现。

JDK自带的SPI(Service Provider Interface)服务发现机制,可以动态地为某个接口寻找服务实现。使用SPI机制需要在Classpath下的META-INF/services目录里创建一个以服务接口命名的文件,这个文件里的内容就是这个接口的具体实现类。如下,文件名和内容都是接口和实现类全包名。

image-20240417220139791

然而,JDK自带的SPI机制使用比较少,不能按需加载,ServiceLoader加载某个接口实现类的时候,会遍历全部获取,接口的实现类全部载入并实例化一遍,会造成不必要的浪费,扩展性比较差。

image-20241030224418544

功能点抽象成一个接口,将接口作为插件的契约,功能的接口与功能的实现分离并提供接口的默认实现。可扩展性很好,用户可以方便地通过插件扩展实现自己的功能。无需修改核心功能本身;保持了核心包的精简,依赖外部包少。

http://www.yayakq.cn/news/695721/

相关文章:

  • 做折线图网站佛山十大进出口贸易公司
  • 一帘幽梦紫菱做的网站运城网站建设求职简历
  • 企业网站建设进什么科目核算泉州建站方案
  • 积极做好门户网站建设工作网站地址和网页地址区别
  • 企业建设网站的步骤是什么?wordpress主题简约博客
  • 深圳建设网站seo 手机如何开展一个网络营销活动
  • 企业建设网站公司排名社区门户网站建设方案
  • 太原智能化营销网站制作公司外汇网站源码 asp
  • 做网站要多少的分辨率赣州网站设计较好的公司
  • 正规网站建设推荐美妆网站设计
  • 黑龙江生产建设兵团知识网站网站建设中故障分类和排除方法
  • 信用卡网站模板营销方案现金充值什么意思
  • 文化建设五大工程天津网站优化怎么样
  • 如果搭建网站带你做网站毕设
  • 北京和田合瑞建设有限公司网站一个网站的成本
  • 网站开发的功能需求和模块划分赣州智美互联网科技有限公司
  • 济南营销型网站建设贵吗wordpress首页
  • 个人网站做淘宝客会怎样富阳营销型网站建设
  • 东莞网站建设推广方案免费爱做网站
  • 梅州英文网站建设网站搭建是什么专业
  • 大型网站后台登录地址一般是如何设置的wordpress主题瀑布流
  • 潍坊住房和城乡建设厅网站旅游开发 网站建设
  • 营销培训心得通州优化公司
  • 珠海网站策划摄影网站建立
  • 大连网站建设 选领超科技建设网站的目标客户群
  • 石家庄网站建设销售电话wordpress极简杂志主题
  • 电子兼职网站建设赣州优化公司
  • 网站开发摊销游戏公司网站模板下载
  • 触摸屏网站开发wordpress网站加载慢
  • 网站建设 说明西樵网站设计制作