微服务实战系列之Dubbo(上)

前言

随着一年一度冬至的到来,2023的步伐也将远去。而博主的系列文章,也将从今天起,越来越聚焦如何构建微服务“内核”上。前序系列文章几乎囊括了微服务的方方面面,无论使用什么框架、组件或工具,皆可拿来用之。

那么,今天博主将推出微服务开发框架系列文章,欢迎各位盆友继续跟着博主的步伐,快乐徜徉于微服务的世界。Let’s Go!

本期主题,博主将带着各位盆友,聚焦在经典的RPC框架:Dubbo,一个盛行于互联网平台的宠儿。

在这里插入图片描述

一、读懂RPC

我们提到Dubbo,那不得不提RPC(远程过程调用,Remote Procedure Call缩写)。首先了解一下什么是RPC

RPC是一个通信协议,允许客户端通过网络调用非本地的服务,即像调用本地服务一样,调用一个“远程”的网络服务。一般用于构建分布式平台,实现跨网络访问通信。

1. 主要特点
  • 经典3跨
    无需关注“远程”服务如何实现,支持3跨(跨网络、跨平台、跨语言)。只要一个Client,根据RPC通信规范,即可叩开一个Remote Server的大门。此乃经典的C/S程序架构模式。
  • 服务可重用性
    既然满足3跨,那可了不起了。随时随地,任你“驰骋”。只要Server有,统统皆拿走。此刻,博主不禁暗然自喜中…
2. 核心组件

我们已知RPC是一个通信过程的协议,如使用它,必须遵循相应的“制度”,否则,乱了“江湖规矩”。满足RPC调用,必须具备以下四个模块:

模块名称模块简介
Client一个客户端,可发起远程调用的程序,一般称之为“消费者”
Client Stub一个客户端的请求存根,记录调用的服务信息,实现请求信息“编码”和服务端返回信息的“解码”
Server一个服务端,可提供服务的正在运行的程序,一般称之为“生产者”
Server Stub一个服务端的响应存根,记录接收的客户端信息,实现客户端数据“解码”;发起服务调用并向Client Stub返回经过“编码”的信息。

具体交互流程图,示意如下,请参考:

在这里插入图片描述

3. 关键技术

我们可能知道或至少了解,通信的基本原理:
在这里插入图片描述

首先需要通信的双方,其次需要一个通信的媒介或载体,最后是信息内容。当然该过程存在一定的干扰项(比如平台、网络、语言等等),因此一定程度上存在可能“失真”的风险。

那么RPC既然是一个通信协议,那也基本遵循该原理,核心技术包括:

–序列化和反序列化(Sequence)
将对象转换为二进制或逆向转换,即实现RPC过程中的编码解码的过程。
–动态代理(Proxy)

动态代理是一种在运行时创建代理类的机制,动态代理可以在不修改源代码的情况下,在运行时为某个接口动态生成实现类,并且可以拦截接口中的方法调用,从而实现一些特殊的功能.。

比如AOP、日志、注解等皆使用了动态代理技术实现。而在RPC中,主要用它完成调用过程的核心处理逻辑(2个Stub皆采用该技术),包括封装请求信息、发起调用和返回响应信息等传输过程实现。

到此为止,我想各位盆友已对RPC有了深刻的认识和了解。那么接下来,博主顺势而为,继续带着大家走进人见人爱的Dubbo

二、走进Dubbo

Apache Dubbo is a high-performance, Java-based open-source RPC framework.

翻译成大白话:Dubbo是一个基于JAVA高性能开源RPC框架。

1. 架构图

在这里插入图片描述
通过Dubbo架构图(来自官网)观察,是不是很很高效很经典?一个标准的端到端的服务框架。

组件名称组件含义
Consumer服务消费者,用于使用服务
Provider服务提供者,也叫生产者,用于提供服务
ZooKeeper用于满足Dubbo服务治理的工具,称之为服务注册中心

当然,Dubbo 在微服务应用开发框架之上抽象了一套 RPC 服务定义、暴露、调用与治理的编程范式,所以实际上它的服务能力包含了服务治理内容,可参考下图(来自官网):
在这里插入图片描述

2. 关键特性

- Transparent interface based RPC
提供基于RPC的透明接口
- Intelligent load balancing
提供智能的负载均衡策略
- Automatic service registration and discovery
提供自动的服务注册和发现能力
- High extensibility
提供较高的扩展能力
- Runtime traffic routing
提供运行时的服务管理和路由能力
- Visualized service governance
提供可视化服务治理能力

3. 交互原理

通过1、2两方面总结,Dubbo可以说深刻体现了什么是发布、什么是订阅,进而探究为实现高性能分布式系统,Dubbo到底是如何工作的。

在这里插入图片描述

关键步骤:

3.1 注册服务

服务提供者Provider在启动时,向注册中心发布自己的服务。

3.2 订阅服务

服务消费者Consumer在启动时,从注册中心订阅自己的服务。

3.3 调用服务

订阅完成后,即可通过业务接口,进行服务调用。

3.4 服务治理

包括服务调用、服务运维、服务限流、熔断等。


结语

作为支持分布式开发的高性能JAVA框架,Dubbo显然具备很高的使用价值。不仅推动了微服务一时兴起的潮流,也帮助使用者快速构建自己微服务体系提供了很好的参考坐标

好了,本期主题到此结束,欢迎订阅与交流!


历史回顾

  • 微服务实战系列之ZooKeeper(实践篇)
  • 微服务实战系列之ZooKeeper(下)
  • 微服务实战系列之ZooKeeper(中)
  • 微服务实战系列之ZooKeeper(上)
  • 微服务实战系列之MQ
  • 微服务实战系列之通信
  • 微服务实战系列之J2Cache
  • 微服务实战系列之Cache(技巧篇)
  • 微服务实战系列之MemCache
  • 微服务实战系列之EhCache
  • 微服务实战系列之Redis
  • 微服务实战系列之Cache
  • 微服务实战系列之Nginx(技巧篇)
  • 微服务实战系列之Nginx
  • 微服务实战系列之Feign
  • 微服务实战系列之Sentinel
  • 微服务实战系列之Token
  • 微服务实战系列之Nacos
  • 微服务实战系列之Gateway
  • 微服务实战系列之加密RSA
  • 微服务实战系列之签名Sign

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/357345.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

多线程图解

关于多线程一直是我们学习iOS的一个重点,不仅是面试中经常被问到的问题,而且我们开发过程过程中经常会用到的技术,下面是一张关于多线程的图解,希望可以帮助大家学习多线程的开发。 转载于:https://www.cnblogs.com/lyy-5518/p/53…

spring作业_Spring和石英:多作业计划服务

spring作业作业调度对于应用程序来说是如此重要。 尤其是在大型项目中,处理大量工作可能是一个问题。 Spring和Quartz为解决该问题带来了巨大的好处。 本文展示了如何通过使用Spring和Quartz轻松地计划多个作业。 二手技术: JDK 1.6.0_21 春天3.1.1 石…

react常用知识点总结

1、什么是jsx JSX是JavaScript的扩展语法,这种<></>标签的写法就是 JSX。JSX 编写的组件通过预处理器 babel 解析后,再交给 React 库渲染到指定父容器下,形成最终html页面,供浏览器解析和显示。 JSX会被babel编译为&#xff1a;React.createElement()&#xff0c…

前端导入导出文件

一、导出 1、返回值是url&#xff1a;创建个a标签即可 printRecord(params).then((response) > {if (response.success) {let a document.createElement(a);//创建a标签//从新页面打开&#xff0c;下载的话不需要这个&#xff0c;打开一个图片需要从新页面打开a.setAttrib…

vue进阶

1、vue-cli 使用 在开发中&#xff0c;需要打包的东西不止是js、css、html。还有更多的东西要处理&#xff0c;这些插件和加载器如果我们一一去添加就会比较麻烦&#xff0c;vue官方提供了一个快速搭建vue项目的脚手架&#xff0c;使用它能快速的构建一个web工程模板。 官网&…

Diff 算法核心原理

什么是虚拟DOM 讲Diff算法前&#xff0c;我先给大家讲一讲什么是虚拟DOM吧。这有利于后面大家对Diff算法的理解加深。 虚拟DOM是一个对象&#xff0c;一个什么样的对象呢&#xff1f;一个用来表示真实DOM的对象&#xff0c;要记住这句话。我举个例子&#xff0c;请看以下真实…

python 列表 字典 读写文件:pickle模块的基本使用

建议大家使用cPickle&#xff0c;速度更快&#xff01;&#xff01;&#xff01; python数据持久存储&#xff1a;pickle模块的基本使用&#xff08;转载&#xff09; 作者: pzxbc出处: http://pzxbc.cnblogs.com/本文版权归作者和博客园共有&#xff0c;欢迎转载&#xff0c;但…

first-child、first-of-type等属性的差别

1、xxx:first-child 伪类 xxx作为第一个子元素 //p元素作为第一个子元素的都会变色 p:first-child { background:yellow; } //p作为父元素的 第一个子元素。不要求第一个元素的类型 p>:first-child {background:yellow; }//p作为父元素的 第一个子元素。要求第一个元素的类…

我的Serverless实战——引领云计算的下一个十年

前言&#xff1a;如今&#xff0c;越来越多的大厂企业开始大规模使用Serverless&#xff0c;处于变革中的开发者&#xff0c;大多已从观望状态转向尝试阶段&#xff0c;越来越多Serverless落地场景被解锁。作为基础研发底座&#xff0c;越来越多企业开始接受Serverless&#xf…

各种边距clientWidth、offsetWidth、scrollWidth、clientLeft、getBoundingClientRect详解

1、clientWidth、offsetWidth、scrollWidth <!DOCTYPE html> <html><head><meta charset"utf-8" /><style>#box1 {padding: 50px;position: static;}#box {border: 1px solid red;overflow: scroll;height: 200px;width: 500px;}#con…

花了两天时间用html+css+js做了一个网页版坦克大战游戏

大家好&#xff0c;我是孙叫兽&#xff0c;本期内容给大家分享如何用htmlcssjavaScript去做一个简易网页版坦克游戏。 目录 坦克游戏玩法及介绍 项目结构 源码地址&#xff1a; 坦克游戏玩法及介绍 我们先来看一下首页。 打开这个首页很简单&#xff0c;基本是上面这个样子&…

设置文字多行显示溢出显示省略号

#news_text { border: 1px solid red; width: 200px; word-break: break-all; text-overflow: ellipsis; display: -webkit-box; -webkit-box-orient: vertical; -webkit-line-clamp: 2; /*这里可以设置文本显示的行数*/ overflow: hidden; }<div id"news_text"&g…

vue项目有几个接口content Download时间特别长的解决办法

做的可视化地图项目&#xff0c;有几个接口加载比较慢&#xff0c;大概16S左右&#xff0c;第一次加载接近一分钟&#xff0c;这谁能受得了。 对比了正式环境和测试环境&#xff0c;这个接口数据量一样&#xff0c;就是在测试服务器比较慢&#xff0c;排除滚动插件及其它的影响…

Jmeter调试工具---HTTP Mirror Server

转自&#xff1a;http://www.cnblogs.com/puresoul/p/4907655.html 一、HTTP Mirror Server的作用&#xff1a; 它可以在本地临时搭建一个HTTP服务器&#xff0c;该服务器把接收到的请求原样返回&#xff0c;这样就可以看到发送出的请求的具体内容&#xff0c;以供调试。 二、…

520 单身福利|女朋友又找我要礼物

大家好&#xff0c;我是孙叫兽&#xff0c;520快到了&#xff0c;给大家分享一下单身福利&#xff01;时间过得真快&#xff0c;一转眼又到了 520&#xff0c;有对象的程序员又激动又扎心的节日&#xff0c;其实吧&#xff0c;程序员对这种节日又期待又焦灼&#xff0c;为什么呢…

pit和systick_PIT和TestNG突变测试简介

pit和systick变异测试是一种技术&#xff0c;它可以发现测试未涵盖代码的哪些部分。 它类似于代码覆盖范围 &#xff0c;但变异测试不限于在测试期间执行给定行的事实。 这个想法是修改生产代码&#xff08;引入突变&#xff09;&#xff0c;这应该改变其行为&#xff08;产生不…

使用vue-seamless-scroll自动滚动插件复制出来的数据点击事件无效的解决办法

引言&#xff1a;做可视化地图项目&#xff0c;使用vue-seamless-scroll实现表格数据自动滚动&#xff0c;有个bug就是复制出来的数据点击事件失效。这个插件底层的实现是cope的形式&#xff0c; 无限滚动原理&#xff1a;无限滚动的原理就是把之前的遍历的内容复制一份&#x…

最短路的几种算法及其优化(模板)

一.Dijkstra 算法 dijkstra算法适用于边权为正的情况&#xff0c;求单源最短路&#xff0c;适用于有向图和无向图 模板伪代码&#xff1a; 清除所有点的标号 设d[0]0&#xff0c;其余d[i]INF&#xff1b; 循环n次{ 在所有未标记的节点中&#xff0c;寻找d[i]最小的点x 给x做标记…

极客青年说,北京沙龙

大家好&#xff0c;我是孙叫兽&#xff0c;本期内容给大家分享infoq写作平台在北京站的沙龙主题。主要流程如下&#xff1a;早上起来&#xff0c;吃了点饭&#xff0c;然后就去北京望京悠乐汇的A1202,这次是个轰趴馆&#xff0c;比较适合年轻的程序员放松。去的稍微早了点&…

vue点击弹窗自动触发点击事件的解决办法

业务场景&#xff1a;使用vue element ui 的el-dialog&#xff0c;点击弹窗之后&#xff0c;默认加载第一个按钮的数据进行初始化。 div 指令&#xff1a; // 自动触发点击事件directives:{trigger:{inserted(el,binging){// console.log("自动触发事件")el.click()}…