PRC框架-Dubbo
RPC框架
RPC(Remote Procedure Call,远程过程调用)框架是一种允许客户端通过网络调用服务器端程序的技术。以下是常见的RPC框架及其特点:
1. 基于HTTP/REST的RPC框架
-
特点:简单易用,与Web开发无缝集成,适合轻量级服务调用。
-
代表性框架:
-
Spring Boot + RESTful API:基于Spring Boot框架,通过注解和控制器实现RESTful风格的RPC调用。适合Java开发,广泛应用于微服务架构。
-
Flask/Django + RESTful API:基于Python的Flask或Django框架,通过定义路由和视图函数实现RPC调用。适合Python开发,适合轻量级和中等规模的服务。
-
Express.js:基于Node.js的Express框架,通过定义路由和中间件实现RPC调用。适合JavaScript开发,适合构建轻量级的后端服务。
-
2. 基于gRPC的RPC框架
-
特点:
-
基于HTTP/2协议,支持双向通信和流控制。
-
使用Protocol Buffers(Protobuf)作为接口定义语言(IDL),性能高,支持多种语言。
-
提供内建的服务发现、负载均衡和认证机制。
-
-
代表性框架:
-
gRPC:由Google开发,支持多种语言(如Java、Python、C++、Go、Node.js等)。适用于高性能、高并发的微服务架构。
-
gRPC Web:用于在浏览器中调用gRPC服务,通过代理将HTTP/1.1请求转换为HTTP/2请求。
-
3. 基于Thrift的RPC框架
-
特点:
-
由Facebook开发,支持多种语言(如Java、C++、Python、PHP等)。
-
提供丰富的数据类型和接口定义语言(Thrift IDL)。
-
支持多种传输协议(如TCP、HTTP、Framed Transport等)。
-
-
代表性框架:
-
Apache Thrift:适用于大规模分布式系统,性能高,支持多种语言和协议。
-
4. 基于JSON-RPC的RPC框架
-
特点:
-
基于JSON格式的RPC协议,简单易用。
-
适合轻量级服务调用,支持多种语言。
-
-
代表性框架:
-
JSON-RPC 2.0:标准化的JSON-RPC协议,支持错误处理、批处理等特性。
-
Flask-JSONRPC:基于Python Flask框架的JSON-RPC实现。
-
json-rpc-js:基于Node.js的JSON-RPC实现。
-
5. 基于XML-RPC的RPC框架
-
特点:
-
基于XML格式的RPC协议,数据结构丰富。
-
适合与Web服务集成,支持多种语言。
-
-
代表性框架:
-
XML-RPC:标准化的XML-RPC协议,广泛应用于早期的Web服务。
-
Flask-XML-RPC:基于Python Flask框架的XML-RPC实现。
-
6. 基于消息队列的RPC框架
-
特点:
-
基于消息队列(如RabbitMQK、afka等)实现异步RPC调用。
-
适合高并发、分布式系统,支持解耦和负载均衡。
-
-
代表性框架:
-
RabbitMQ:支持AMQP协议,适用于异步RPC调用。
-
Kafka:支持高吞吐量的异步消息传递,适用于分布式系统。
-
7. 其他RPC框架
-
Dubbo:由阿里巴巴开发的高性能RPC框架,支持多种协议(如Dubbo、HTTP、gRPC等),广泛应用于Java微服务架构。
-
Apache Avro:由Apache开发,支持二进制编码的RPC框架,性能高,适合大数据处理。
-
ZeroMQ:轻量级的消息传递库,支持多种模式(如请求-响应、发布-订阅等),适用于分布式系统。
总结
-
轻量级服务:推荐使用基于HTTP/REST的框架(如Spring Boot、Flask)或JSON-RPC框架。
-
高性能、高并发服务:推荐使用gRPC或Thrift框架。
-
异步RPC调用:推荐使用基于消息队列的框架(如RabbitMQ、Kafka)。
-
Java微服务架构:推荐使用Dubbo框架。
根据具体需求选择合适的RPC框架可以提高开发效率和系统性能。
Dubbo
以下是Dubbo常见面试题及其答案解析,结合最新的搜索结果整理如下:
1. 为什么要用Dubbo?
-
Dubbo是一个高性能的RPC框架,支持服务注册与发现、负载均衡、容错、监控等功能。
-
适用于大规模分布式系统,能够简化服务之间的调用。
2. Dubbo的整体架构设计有哪些分层?
-
RPC层:定义了远程调用的接口和实现。
-
Cluster层:封装了集群容错逻辑。
-
Proxy层:生成服务代理。
-
Registry层:封装了服务注册与发现。
-
Config层:封装了配置加载。
3. 默认使用的是什么通信框架,还有别的选择吗?
-
默认使用Netty作为通信框架。
-
其他选择包括Mina。
4. 服务调用是阻塞的吗?
-
默认是阻塞的,但可以通过异步调用实现非阻塞。
5. 一般使用什么注册中心?还有别的选择吗?
-
通常使用Zookeeper作为注册中心。
-
其他选择包括Redis、Consul。
6. 默认使用什么序列化框架,你知道的还有哪些?
-
默认使用Hessian序列化。
-
其他选择包括FastJson、Java自带序列化。
7. 服务提供者能实现失效踢出是什么原理?
-
基于Zookeeper的临时节点原理,当服务提供者下线时,注册中心会自动移除其节点。
8. 如何解决服务调用链过长的问题?
-
可以结合Zipkin实现分布式服务追踪。
9. Dubbo推荐用什么协议?
-
推荐使用Dubbo协议。
10. 同一个服务多个注册的情况下可以直连某一个服务吗?
-
可以通过修改配置实现点对点直连。
11. 画一画服务注册与发现的流程图?
-
服务提供者启动后,向注册中心注册服务;服务消费者启动后,从注册中心订阅服务。
12. Dubbo集群容错有几种方案?
-
包括Failover、Failfast、Failsafe、Failback、Forking。
13. Dubbo服务降级,失败重试怎么做?
-
通过
dubbo:reference中的mock属性设置降级逻辑。
14. Dubbo使用过程中都遇到了些什么问题?
-
常见问题包括网络延迟、超时、服务注册失败、序列化失败等。
15. Dubbo Monitor实现原理?
-
Dubbo Monitor通过收集服务调用的性能数据,提供监控功能。
16. Dubbo用到哪些设计模式?
-
包括工厂模式、代理模式、单例模式、策略模式。
17. Dubbo配置文件是如何加载到Spring中的?
-
通过Spring的
BeanFactory加载配置文件。
18. Dubbo SPI和Java SPI区别?
-
Dubbo SPI是Java SPI的扩展,提供了更灵活的扩展机制。
19. Dubbo支持分布式事务吗?
-
Dubbo本身不直接支持分布式事务,但可以通过集成其他框架(如Seata)实现。
20. Dubbo可以对结果进行缓存吗?
-
可以通过配置实现结果缓存。
21. 服务上线怎么兼容旧版本?
-
可以通过多版本部署实现。
22. Dubbo必须依赖的包有哪些?
-
包括
dubbo、zookeeper、netty等。
23. Dubbo telnet命令能做什么?
-
可以用于远程管理Dubbo服务,如查看服务状态、调用服务。
24. Dubbo支持服务降级吗?
-
支持,通过配置
mock属性实现。
25. Dubbo如何优雅停机?
-
可以通过配置优雅停机参数实现。
26. Dubbo和Dubbox之间的区别?
-
Dubbox是Dubbo的一个分支,增加了对REST协议的支持。
27. Dubbo和Spring Cloud的区别?
-
Dubbo侧重于RPC通信,Spring Cloud侧重于微服务架构。
这些面试题和答案涵盖了Dubbo的核心概念、架构设计、使用场景以及常见问题,是面试中常见的考点。
相关文章:
PRC框架-Dubbo
RPC框架 RPC(Remote Procedure Call,远程过程调用)框架是一种允许客户端通过网络调用服务器端程序的技术。以下是常见的RPC框架及其特点: 1. 基于HTTP/REST的RPC框架 特点:简单易用,与Web开发无缝集成&am…...
智能检测摄像头模块在客流统计中的应用
工作原理 基于视频分析技术:智能检测摄像头模块通过捕捉监控区域内的视频画面,运用图像识别算法对视频中的人体进行检测、跟踪和分析。可以识别出人体的轮廓、姿态等特征,进而区分不同的个体,实现对客流的统计。 基于红外感应技…...
[LLM面试题] 指示微调(Prompt-tuning)与 Prefix-tuning区别
一、提示调整(Prompt Tuning) Prompt Tuning是一种通过改变输入提示语(input prompt)以获得更优模型效果的技术。举个例子,如果我们想将一条英语句子翻译成德语,可以采用多种不同的方式向模型提问,如下图所示…...
【CubeMX+STM32】SD卡 U盘文件系统 USB+FATFS
本篇,将使用CubeMXKeil, 创建一个 USBTF卡存储FatFS 的虚拟U盘读写工程。 目录 一、简述 二、CubeMX 配置 SDIO DMA FatFs USB 三、Keil 编辑代码 四、实验效果 串口助手,实现效果: U盘,识别效果: 一、简述 上…...
在JVM的栈(虚拟机栈)中,除了栈帧(Stack Frame)还有什么?
在JVM的栈(虚拟机栈)中,除了栈帧(Stack Frame),还有其他一些与方法调用相关的重要信息。栈的主要作用是存储方法调用的执行过程中的上下文信息,栈帧是其中最关键的组成部分。 栈的组成 栈帧&am…...
# 解析Excel文件:处理Excel xlsx file not supported错误 [特殊字符]
解析Excel文件:处理Excel xlsx file not supported错误 🧩 嘿,数据分析的小伙伴们!👋 我知道在处理Excel文件的时候,很多人可能会遇到这样一个错误:Excel xlsx file not supported。别担心&…...
图片下载不下来?即便点了另存为也无法下载?两种方法教你百分之百下载下来
前言,我要讲的是网站没有禁鼠标右键,可以右键,也可以打开控制台,图片也不用付费这种。 一、用鼠标按住图片直接往桌面拖动,也可以打开开发者工具,在里面往外拖。 二、这个方法很有意思,在电脑的…...
Unity项目实战-Player玩家控制脚本实现
玩家控制脚本设计思路 1. 代码演变过程 1.1 初始阶段:单一Player类实现 最初的设计可能是一个包含所有功能的Player类: public class Player : MonoBehaviour {private CharacterController controller;private Animator animator;[SerializeField] …...
CP AUTOSAR标准之ICUDriver(AUTOSAR_SWS_ICUDriver)(更新中……)
1 简介和功能概述 该规范指定了AUTOSAR基础软件模块ICU驱动程序的功能、API和配置。 ICU驱动程序是一个使用输入捕获单元(ICU)来解调PWM信号、计数脉冲、测量频率和占空比、生成简单中断和唤醒中断的模块。 ICU驱动程序提供服务 信号边缘通知控制唤醒中断周期信号时间测…...
Python3 ImportError: cannot import name ‘XXX‘ from ‘XXX‘
个人博客地址:Python3 ImportError: cannot import name XXX from XXX | 一张假钞的真实世界 例如如下错误: $ python3 git.py Traceback (most recent call last):File "git.py", line 1, in <module>from git import RepoFile &quo…...
[学习笔记] Kotlin Compose-Multiplatform
Compose-Multiplatform 原文:https://github.com/zimoyin/StudyNotes-master/blob/master/compose-multiplatform/compose.md Compose Multiplatform 是 JetBrains 为桌面平台(macOS,Linux,Windows)和Web编写Kotlin UI…...
【R语言】t检验
t检验(t-test)是用于比较两个样本均值是否存在显著差异的一种统计方法。 t.test()函数的调用格式: t.test(x, yNULL, alternativec("two.sided", "less", "greater"), mu0, pairedFALSE, var.equalFALSE, co…...
flutter ListView Item复用源码解析
Flutter 的 ListView 的 Item 复用机制是其高性能列表渲染的核心,底层实现依赖于 Flutter 的渲染管线、Element 树和 Widget 树的协调机制。以下是 ListView 复用机制的源码级解析,结合关键类和核心逻辑进行分析。 1. ListView 的底层结构 ListView 的复…...
Spring Boot 配置 Mybatis 读写分离
JPA 的读写分离配置不能应用在 Mybatis 上, 所以 Mybatis 要单独处理 为了不影响原有代码, 使用了增加拦截器的方式, 在拦截器里根据 SQL 的 CRUD 来路由到不同的数据源 需要单独增加Mybatis的配置 Beanpublic SqlSessionFactory sqlSessionFactory(DataSource dataSource) t…...
网络初识-
网络的相关概念 一、局域网和广域网 将各种计算机、外部设备等相互连接起来,实现在这个范围内数据通信和资源共享的计算机网络。它的覆盖范围通常在几百米到几公里之内。例如,一个小型企业的办公室,通过交换机将多台电脑连接在一起…...
DNS污染:网络世界的“隐形劫持”与防御
在互联网的底层架构中,DNS(域名系统)如同数字世界的“导航员”,将用户输入的域名翻译成机器可读的IP地址。然而,DNS污染(DNS Poisoning)正像一场无声的“地址篡改”危机,威胁着全球网…...
MQTT(Message Queuing Telemetry Transport)协议(三)
主题是什么 2. TCP 协议封装 tcp.c #include <stdio.h> #include <stdlib.h> #include <string.h> #include <unistd.h> #include <arpa/inet.h> #include <sys/socket.h>// 建立 TCP 连接 int tcp_connect(const char *server_ip, int s…...
多核cpu与时间片多线程的问题
在多核处理器中,每个核心可以独立运行一个线程。操作系统负责管理和调度这些线程,以确保高效利用处理器资源。下面详细解释如何获取时间片以及四个线程如何在四个核心上同时工作。 ### 时间片和调度 #### 1. 时间片(Time Slice)…...
电脑出现蓝屏英文怎么办?查看修复过程
电脑出现蓝屏英文是一种常见的电脑故障,它通常表示电脑遇到了严重的错误,需要停止运行以防止进一步的损坏。电脑蓝屏英文的原因可能有很多,比如硬件故障、驱动程序错误、系统文件损坏、病毒感染等。那么,当电脑出现蓝屏英文时&…...
安卓基础(第一集)
SharedPreferences(本地存储简单数据) 在 Android 中,SharedPreferences 用于存储小型数据。 (1)存储数据 // 获取 SharedPreferences 对象 SharedPreferences sharedPreferences getSharedPreferences("MyPre…...
ubuntu搭建nfs服务centos挂载访问
在Ubuntu上设置NFS服务器 在Ubuntu上,你可以使用apt包管理器来安装NFS服务器。打开终端并运行: sudo apt update sudo apt install nfs-kernel-server创建共享目录 创建一个目录用于共享,例如/shared: sudo mkdir /shared sud…...
23-Oracle 23 ai 区块链表(Blockchain Table)
小伙伴有没有在金融强合规的领域中遇见,必须要保持数据不可变,管理员都无法修改和留痕的要求。比如医疗的电子病历中,影像检查检验结果不可篡改行的,药品追溯过程中数据只可插入无法删除的特性需求;登录日志、修改日志…...
多模态商品数据接口:融合图像、语音与文字的下一代商品详情体验
一、多模态商品数据接口的技术架构 (一)多模态数据融合引擎 跨模态语义对齐 通过Transformer架构实现图像、语音、文字的语义关联。例如,当用户上传一张“蓝色连衣裙”的图片时,接口可自动提取图像中的颜色(RGB值&…...
剑指offer20_链表中环的入口节点
链表中环的入口节点 给定一个链表,若其中包含环,则输出环的入口节点。 若其中不包含环,则输出null。 数据范围 节点 val 值取值范围 [ 1 , 1000 ] [1,1000] [1,1000]。 节点 val 值各不相同。 链表长度 [ 0 , 500 ] [0,500] [0,500]。 …...
【ROS】Nav2源码之nav2_behavior_tree-行为树节点列表
1、行为树节点分类 在 Nav2(Navigation2)的行为树框架中,行为树节点插件按照功能分为 Action(动作节点)、Condition(条件节点)、Control(控制节点) 和 Decorator(装饰节点) 四类。 1.1 动作节点 Action 执行具体的机器人操作或任务,直接与硬件、传感器或外部系统…...
(二)原型模式
原型的功能是将一个已经存在的对象作为源目标,其余对象都是通过这个源目标创建。发挥复制的作用就是原型模式的核心思想。 一、源型模式的定义 原型模式是指第二次创建对象可以通过复制已经存在的原型对象来实现,忽略对象创建过程中的其它细节。 📌 核心特点: 避免重复初…...
2025盘古石杯决赛【手机取证】
前言 第三届盘古石杯国际电子数据取证大赛决赛 最后一题没有解出来,实在找不到,希望有大佬教一下我。 还有就会议时间,我感觉不是图片时间,因为在电脑看到是其他时间用老会议系统开的会。 手机取证 1、分析鸿蒙手机检材&#x…...
【JavaSE】绘图与事件入门学习笔记
-Java绘图坐标体系 坐标体系-介绍 坐标原点位于左上角,以像素为单位。 在Java坐标系中,第一个是x坐标,表示当前位置为水平方向,距离坐标原点x个像素;第二个是y坐标,表示当前位置为垂直方向,距离坐标原点y个像素。 坐标体系-像素 …...
大数据学习(132)-HIve数据分析
🍋🍋大数据学习🍋🍋 🔥系列专栏: 👑哲学语录: 用力所能及,改变世界。 💖如果觉得博主的文章还不错的话,请点赞👍收藏⭐️留言Ǵ…...
Spring Cloud Gateway 中自定义验证码接口返回 404 的排查与解决
Spring Cloud Gateway 中自定义验证码接口返回 404 的排查与解决 问题背景 在一个基于 Spring Cloud Gateway WebFlux 构建的微服务项目中,新增了一个本地验证码接口 /code,使用函数式路由(RouterFunction)和 Hutool 的 Circle…...
