Dubbo介绍及使用
🍓 简介:java系列技术分享(👉持续更新中…🔥)
🍓 初衷:一起学习、一起进步、坚持不懈
🍓 如果文章内容有误与您的想法不一致,欢迎大家在评论区指正🙏
🍓 希望这篇文章对你有所帮助,欢迎点赞 👍 收藏 ⭐留言 📝🍓 更多文章请点击
文章目录
- 一、Dubbo简介
- 二、Dubbo入门
- 2.1 Dubbo的基础架构
- 2.2 搭建Nacos 和 DubboAdmin
- 2.3 服务提供者
- 2.4 服务消费者
- 2.5 抽取公共接口
- 2.6 对象序列化
- 三、高级特性
- 3.1 Dubbo启动检查
- 3.2 多版本
- 3.3 超时与重试
- 3.4 负载均衡
- 四、SpringCloud整合Dubbo`
- 4.1 服务提供者
- 4.2 服务消费者

一、Dubbo简介
Dubbo官网:https://cn.dubbo.apache.org
- Dubbo是阿里巴巴推出的一个高性能、可扩展、可靠的
RPC框架 - 基于Dubbo进行远程调用
- Dubboo基于TCP(传输层)协议,效率更高,可以替换Feign,提升高并发压力
二、Dubbo入门
2.1 Dubbo的基础架构

2.2 搭建Nacos 和 DubboAdmin
Nacos安装查看:Docker如何安装Nacos
dubbo-admin安装
- DubboAdmin是阿里巴巴管理提供的管理控制台,可以实现服务查询,详情展示,服务测试等功能,可以更好的帮助开发人员对服务进行管理和监控
#1、下载代码: git clone https://github.com/apache/dubbo-admin.git #2、在 dubbo-admin-server/src/main/resources/application.properties中指定注册中心地址 #3、构建 mvn clean package -D maven.test.skip=true #4、启动 mvn --projects dubbo-admin-server spring-boot:run #或者 cd dubbo-admin-distribution/target; java -jar dubbo-admin-0.1.jar #5、访问 http://localhost:8080
2.3 服务提供者
-
引入依赖<!--dubbo的起步依赖--><dependency><groupId>org.apache.dubbo</groupId><artifactId>dubbo-spring-boot-starter</artifactId><version>2.7.8</version></dependency><dependency><groupId>org.apache.dubbo</groupId><artifactId>dubbo-registry-nacos</artifactId><version>2.7.8</version></dependency> -
需要远程调用的接口添加
@DubboService注解 -
添加配置
dubbo:protocol:name: dubbo #协议port: 20881 #端口从20880开始registry:address: nacos://127.0.0.1:8848scan:base-packages: com.use.service #@DubboService注解所在包
2.4 服务消费者
因为在DubboAdmin使用的接口全类名,所以调用接口服务提供者和消费者包名必须一致
引入依赖<!--dubbo的起步依赖--><dependency><groupId>org.apache.dubbo</groupId><artifactId>dubbo-spring-boot-starter</artifactId><version>2.7.8</version></dependency><dependency><groupId>org.apache.dubbo</groupId><artifactId>dubbo-registry-nacos</artifactId><version>2.7.8</version></dependency>- 需要远程调用注入的Bean添加
@DubboReference注解 - 添加配置
dubbo:registry:address: nacos://127.0.0.1:8848
2.5 抽取公共接口
服务提供者和消费者调用接口包名必须一致,为了保证双方接口一致,则抽取公共接口模块
在提供者和消费者中引入公共接口模块依赖,实现复用
2.6 对象序列化
-
如果要传输对象, 对象必须实现序列化接口
implements Serializable -
因为:RPC通信,采用二进制数据格式,所以需要进行序列化处理。
三、高级特性
3.1 Dubbo启动检查
如果先启动服务消费者,@DubboReference引入远程服务时,因为提供者还没有启动,所以找不到提供者,则会抛出异常
在消费者添加如下配置即可:
dubbo:registry:address: nacos://127.0.0.1:8848consumer:check: false #关闭启动检查
3.2 多版本
- 暴露服务时,指定服务版本
@DubboService(version = "2.0.0") - 消费者引入服务时,指定引用的服务版本
@DubboReference(version = "2.0.0")
3.3 超时与重试
- Dubbo默认超时时间:
1000毫秒 - 调用远程服务时,如果发生网络异常或者其他异常,Dubbo会进行重试,重试次数
默认是3次,可以通过配置进行修改。 - 重试机制会发送多次请求,可能会带来问题,例如保存会触发多次,
- 第一种(只针对该注解引入的服务)
@DubboReference(retries = 0)- 第二种(全局生效)
dubbo:registry:address: nacos://127.0.0.1:8848consumer:check: false #关闭启动检查retries: 0 # 重试次数为0
3.4 负载均衡
- Random(随机):将请求
按权重随机分配给不同的服务节点。 - Round Robin(轮询):将请求
按权重轮训到不同的服务节点上。 - Least Active:将请求按
最少活跃调用数,相同的活跃数随机。 - ConsistentHash:
一致性hash,相同参数的请求总是发到同一提供者。
在服务消费者端:
@DubboReference(loadbalance= "random")
四、SpringCloud整合Dubbo`
SpringCloud整合Dubbo只需要在nacos中查看即可,不需要在DubboAdmin中查看
4.1 服务提供者
- 引入依赖
<!--nacos注册中心的依赖--> <dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId> </dependency><!--springcloud alibaba dubbo依赖 --> <dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-starter-dubbo</artifactId> </dependency> - 需要远程调用的接口添加
@DubboService注解 - 添加配置
注意区别spring:application:name: consumer-servicecloud:nacos:discovery:server-addr: localhost:8848#配置dubbo,注册中心,暴露的端口和协议,dubbo注解的包扫描 dubbo:protocol:name: dubboport: 20881registry:address: spring-cloud://localhost #使用SpringCloud中的注册中心scan:base-packages: com.use.service #dubbo中包扫描
4.2 服务消费者
引入依赖<!--nacos注册中心的依赖--><dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId></dependency><!--springcloud alibaba dubbo依赖 --><dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-starter-dubbo</artifactId></dependency>- 需要远程调用注入的Bean添加
@DubboReference注解 - 添加配置
spring:application:name: provider-servicecloud:nacos:discovery:server-addr: localhost:8848#配置dubbo,注册中心,暴露的端口和协议,dubbo注解的包扫描 dubbo:registry:address: spring-cloud://localhost #使用SpringCloud中的注册中心 consumer:check: false #关闭启动检查retries: 0 # 重试设置为0
![]()

相关文章:
Dubbo介绍及使用
🍓 简介:java系列技术分享(👉持续更新中…🔥) 🍓 初衷:一起学习、一起进步、坚持不懈 🍓 如果文章内容有误与您的想法不一致,欢迎大家在评论区指正🙏 🍓 希望这篇文章对你有所帮助,欢…...
初阶C语言-分支和循环语句(下)
“花会沿途盛开,以后的路也是。” 今天我们一起来继续学完分支语句和循环语句。 分支和循环 3.循环语句3.4 do...while()循环3.4.1 do语句的用法 3.5关于循环的一些练习3.6 goto语句 3.循环语句 3.4 do…while()循环 3.4.1 do语句的用法 do循环语句;//当循环语句…...
pytorch工具——pytorch中的autograd
目录 关于torch.tensor关于tensor的操作关于梯度gradients 关于torch.tensor 关于tensor的操作 x1torch.ones(3,3) xtorch.ones(2,2,requires_gradTrue) print(x1,\n,x)yx2 print(y) print(x.grad_fn) print(y.grad_fn)zy*y*3 outz.mean() print(z,out)注意 atorch.randn(2,…...
Linux--进程池
1.一个父进程生成五个子进程且分别建立与子进程管道 ①用for循环,结束条件为<5 ②father父进程每次都要离开for循环,生成下一个子进程和管道 2.#include <cassert>和#include <assert.h>的区别 assert.h 是 C 标准库的头文件ÿ…...
SpringCloudAlibaba微服务实战系列(四)Sentinel熔断降级、异常fallback、block细致处理
SpringCloudAlibaba Sentinel降级和熔断 接着上篇文章的内容,在Sentinel中如何进行降级和熔断呢? 熔断降级规则 降级规则 在Sentinel中降级主要有三个策略:RT、异常比例、异常数,也是针对某个资源的设置。而在1.8.0版本后RT改为…...
WebDAV之π-Disk派盘+ WinSCP
WinSCP是一个免费的开源文件传输应用程序,它使用文件传输协议,安全外壳文件传输协议和安全复制协议来进行纯文件或安全文件传输。该应用程序旨在与Windows一起使用,并支持常见的Windows桌面功能,例如拖放文件,跳转列表…...
Python案例分析|使用Python图像处理库Pillow处理图像文件
本案例通过使用Python图像处理库Pillow,帮助大家进一步了解Python的基本概念:模块、对象、方法和函数的使用 使用Python语言解决实际问题时,往往需要使用由第三方开发的开源Python软件库。 本案例使用图像处理库Pillow中的模块、对象来处理…...
音视频——压缩原理
H264视频压缩算法现在无疑是所有视频压缩技术中使用最广泛, 最流行的。随着 x264/openh264以及ffmpeg等开源库的推出,大多数使用者无需再对H264的细节做过多的研究,这大降低了人们使用H264的成本。 但为了用好H264,我们还是要对…...
微服务 云原生:搭建 K8S 集群
为节约时间和成本,仅供学习使用,直接在两台虚拟机上模拟 K8S 集群搭建 踩坑之旅 系统环境:CentOS-7-x86_64-Minimal-2009 镜像,为方便起见,直接在 root 账户下操作,现实情况最好不要这样做。 基础准备 关…...
C++中的数学问题---进制转换
二进制转十六进制 string binToHex(string bin){string hex"";if(bin.size()%4!0){for(int i0;i<(4-bin.size()%4);i){bin"0"bin;}}for(int i0;i<bin.size();i4){string tmpbin.substr(i,4);bitset<4>b(tmp);hexb.to_ulong()<10?char(b.t…...
开发一个RISC-V上的操作系统(三)—— 串口驱动程序(UART)
目录 文章传送门 一、什么是串口 二、本项目串口的FPGA实现 三、串口驱动程序的编写 四、上板测试 文章传送门 开发一个RISC-V上的操作系统(一)—— 环境搭建_riscv开发环境_Patarw_Li的博客-CSDN博客 开发一个RISC-V上的操作系统(二&…...
nuxt项目部署,npm run build 和npm run generate的区别
每日鸡汤:每个你想要学习的瞬间都是未来的你向自己求救 非服务端渲染的项目,比如普通的vite vue项目,我们在部署生产环境的时候,只需要两步 运行 npm run build 然后得到了一个 dist 文件夹将这个dist文件夹部署到一个静态服务器…...
数据仓库设计理论
数据仓库设计理论 一、数据仓库基本概念 1.1、数据仓库介绍 数据仓库是一个用于集成、存储和分析大量结构化和非结构化数据的中心化数据存储系统。它旨在支持企业的决策制定和业务分析活动。 1.2、基本特征 主题导向:数据仓库围绕特定的主题或业务领域进行建模…...
数据接口有哪些?(数据接口有哪几种)
数据接口是指不同应用程序或系统之间交换数据的通信界面。在现代信息化社会中,数据接口扮演着极为重要的角色,它们使得不同平台之间能够相互连接和交流,从而实现数据共享和应用集成。 数据接口的种类繁多,常见的有以下几种&#…...
华为云CodeArts产品体验的心得体会及想法
文章目录 前言CodeArts 的产品优势一站式软件开发生产线研发安全Built-In华为多年研发实践能力及规范外溢高质高效敏捷交付 功能特性说明体验感受问题描述完结 前言 华为云作为一家全球领先的云计算服务提供商,致力于为企业和个人用户提供高效、安全、可靠的云服务。…...
下载安装:SQLite+SQLiteStudio+VS
目录 1、SQLite 1.1、下载SQLite 1.2、配置SQLite的环境变量 2、SQLite Studio 2.1、下载SQLite Studio 2.2、安装SQLite Studio 3、Visual Studio 3.1、下载Visual Studio 3.2、安装Visual Studio 1、SQLite 1.1、下载SQLite SQLite官网:SQLite Downl…...
nginx路由
一般我们经常在访问网站时,通常会遇到输入某个页面的网址时,出现路由的转发,重定向等。可能访问的是一个网址,出来的时候就显示的是另外的地址。这是由于使用了nginx的缘故,保护了网址的安全性 (1…...
MobPush Android SDK 厂商推送限制
概述 厂商推送限制 每个厂商通道都有对应的厂商配额和 QPS 限制,当请求超过限制且已配置厂商回执时,MobPush会采取以下措施: 当开发者推送请求超过厂商配额时,MobPush将通过自有通道进行消息下发。当开发者推送请求超过厂商 QP…...
计算机网络 day7 扫描IP脚本 - 路由器 - ping某网址的过程
目录 network 和 NetworkManager关系: 实验:编写一个扫描脚本,知道本局域网里哪些ip在使用,哪些没有使用? 使用的ip对应的mac地址都要显示出来 计算机程序执行的两种不同方式: shell语言编写扫描脚本 …...
gitee 配置ssh 公钥(私钥)
步骤1:添加/生成SSH公钥,码云提供了基于SSH协议的Git服务,在使用SSH协议访问项目仓库之前,需要先配置好账户/项目的SSH公钥。 绑定账户邮箱: git config --global user.name "Your Name" git config --glob…...
Blazor开发中的高效筛选技术:MudBlazor数据表格优化指南
Blazor开发中的高效筛选技术:MudBlazor数据表格优化指南 【免费下载链接】MudBlazor Blazor Component Library based on Material design with an emphasis on ease of use. Mainly written in C# with Javascript kept to a bare minimum it empowers .NET develo…...
UNet全维度改进模型库重磅发布
突破边界,赋能工业质检:UNet全维度改进模型库重磅发布 在工业缺陷检测领域,分割精度与效率的平衡始终是技术落地的核心命题。我们倾力打造**「UNet全维度改进模型库」,以37项原创性结构创新为引擎,深度融合注意力机制…...
水晶排课 13.9.0.5:专注学校教务排课场景,集智能自动排课、灵活课表调整、多维度视图与便捷输出于一体,高效解决排课冲突,适用于中小学各类教务管理需求。
大家好,我是大飞哥。在学校教务管理中,排课是一项繁琐又容易出错的工作 —— 既要兼顾教师课时、班级需求,又要避免冲突,这款水晶排课 13.9.0.5就是专门解决这些问题的工具,它是一款专业高效的教务排课软件,…...
从Python调包侠到量化研究员:我的3年转型踩坑实录与学习路线图
从Python调包侠到量化研究员:我的3年转型踩坑实录与学习路线图 三年前,我还是一名只会用Python调包的数据工程师,每天的工作就是清洗数据、跑模型、生成报表。直到某次聚会上,一位在私募基金做量化的朋友随口提了句"我们组去…...
浏览器自动化利器:OpenClaw控制Qwen3.5-4B-Claude填表单
浏览器自动化利器:OpenClaw控制Qwen3.5-4B-Claude填表单 1. 为什么需要浏览器自动化助手 在日常工作中,我们经常需要重复填写各种网页表单。从简单的注册页面到复杂的多步骤申请表,这些机械性操作不仅耗时耗力,还容易出错。作为…...
Matlab图表标注全攻略:希腊字母、线型与标记符号的灵活运用
Matlab图表标注全攻略:希腊字母、线型与标记符号的灵活运用 科研图表是数据可视化的核心载体,而Matlab作为工程与科学计算领域的标杆工具,其绘图系统的精细控制能力往往被低估。许多研究者止步于默认图表样式,却不知只需掌握几个关…...
突破模态壁垒:Audio Flamingo 3如何重塑音频AI开发范式
突破模态壁垒:Audio Flamingo 3如何重塑音频AI开发范式 【免费下载链接】audio-flamingo-3 项目地址: https://ai.gitcode.com/hf_mirrors/nvidia/audio-flamingo-3 问题象限:音频智能的三重技术困境 当前音频AI领域正面临着制约行业发展的三大…...
OpenClaw进阶配置:GLM-4.7-Flash模型参数调优实战
OpenClaw进阶配置:GLM-4.7-Flash模型参数调优实战 1. 为什么需要关注模型参数调优 去年冬天,当我第一次用OpenClaw自动整理全年会议纪要时,发现AI助手生成的摘要总带着奇怪的"官方腔调"——明明只是内部讨论,输出却像…...
从零构建 eNSP 小型校园网络毕业设计:架构解析与避坑指南
最近在帮学弟学妹们看网络相关的毕业设计,发现很多同学在用华为 eNSP 搭建小型校园网络时,思路容易混乱。要么是拓扑图画得一团麻,分不清层次;要么是配置完 VLAN 后,不同网段的电脑死活 ping 不通;还有的干…...
Cherry Studio容器化部署实战指南:从环境搭建到生产运维
Cherry Studio容器化部署实战指南:从环境搭建到生产运维 【免费下载链接】cherry-studio 🍒 Cherry Studio is a desktop client that supports for multiple LLM providers. Support deepseek-r1 项目地址: https://gitcode.com/GitHub_Trending/ch/c…...

