Java微服务选型Dubbo V.S SpringCloud(上)

本文涉及的产品
注册配置 MSE Nacos/ZooKeeper,118元/月
服务治理 MSE Sentinel/OpenSergo,Agent数量 不受限
云原生网关 MSE Higress,422元/月
简介: 若业务场景仅一种语言,可选择跟语言绑定的RPC框架如果涉及多个语言平台之间的相互调用,必须选择跨语言平台的RPC框架。支持多语言是RPC框架未来的发展趋势。正是基于此判断,各个RPC框架都提供了Sidecar组件来支持多语言平台之间的RPC调用。

RPC框架主要组成

  • 通信框架
  • 通信协议
  • 序列化和反序列化格式


1 分类

RPC框架主要分为:

1.1 绑定语言平台

1.1.1 Dubbo

国内最早开源的RPC框架,由阿里巴巴公司开发并于2011年末对外开源,仅支持Java

架构

image.png

  • Consumer 服务消费者
  • Provider 服务提供者
  • Registry 注册中心
  • Monitor是监控系统

交互流程

  • Consumer通过Registry获取到Provider节点
  • 再通过Dubbo的客户端SDK与Provider建立连接,并发起调用
  • Provider通过Dubbo的服务端SDK接收到Consumer请求
  • 处理后再把结果返回给Consumer

服务消费者、提供者都需引入Dubbo的SDK才来完成RPC调用,因为Dubbo是用Java实现,所以要求服务消费者、提供者也都必须用Java。

主要实现

  • 默认采用Netty作为通信框架
  • 除了支持私有的Dubbo协议外,还支持RMI、Hession、HTTP、Thrift
  • 支持多种序列化格式,比如Dubbo、Hession、JSON、Kryo、FST


1.1.2 Motan

微博内部使用的RPC框架,于2016年对外开源,仅支持Java。

架构

image.png

与Dubbo类似,都要在Client端(服务消费者)和Server端(服务提供者)引入SDK

  • register
    和注册中心交互,包括注册服务、订阅服务、服务变更通知、服务心跳发送等功能。Server端会在系统初始化时通过register模块注册服务,Client端会在系统初始化时通过register模块订阅到具体提供服务的Server列表,当Server列表发生变更时也由register模块通知Client。
  • protocol
    用来进行RPC服务的描述和RPC服务的配置管理,这一层还可以添加不同功能的filter用来完成统计、并发限制等功能。
  • serialize
    将RPC请求中的参数、结果等对象进行序列化与反序列化,即进行对象与字节流的互相转换,默认使用对Java更友好的Hessian 2进行序列化。
  • transport
    用来进行远程通信,默认使用Netty NIO的TCP长链接方式。
  • cluster
    Client端使用的模块,cluster是一组可用的Server在逻辑上的封装,包含若干可以提供RPC服务的Server,实际请求时会根据不同的高可用与负载均衡策略选择一个可用的Server发起远程调用。


目录
相关文章
|
3月前
|
设计模式 Java 关系型数据库
【Java笔记+踩坑汇总】Java基础+JavaWeb+SSM+SpringBoot+SpringCloud+瑞吉外卖/谷粒商城/学成在线+设计模式+面试题汇总+性能调优/架构设计+源码解析
本文是“Java学习路线”专栏的导航文章,目标是为Java初学者和初中高级工程师提供一套完整的Java学习路线。
497 37
|
3月前
|
缓存 负载均衡 Dubbo
Dubbo技术深度解析及其在Java中的实战应用
Dubbo是一款由阿里巴巴开源的高性能、轻量级的Java分布式服务框架,它致力于提供高性能和透明化的RPC远程服务调用方案,以及SOA服务治理方案。
97 6
|
4月前
|
Java 开发工具 Spring
【Azure Spring Cloud】使用azure-spring-boot-starter-storage来上传文件报错: java.net.UnknownHostException: xxxxxxxx.blob.core.windows.net: Name or service not known
【Azure Spring Cloud】使用azure-spring-boot-starter-storage来上传文件报错: java.net.UnknownHostException: xxxxxxxx.blob.core.windows.net: Name or service not known
|
4月前
|
NoSQL Java Redis
【Azure Spring Cloud】Java Spring Cloud 应用部署到Azure上后,发现大量的 java.lang.NullPointerException: null at io.lettuce.core.protocol.CommandHandler.writeSingleCommand(CommandHandler.java:426) at ... 异常
【Azure Spring Cloud】Java Spring Cloud 应用部署到Azure上后,发现大量的 java.lang.NullPointerException: null at io.lettuce.core.protocol.CommandHandler.writeSingleCommand(CommandHandler.java:426) at ... 异常
|
5月前
|
存储 算法 Java
Java面试之SpringCloud篇
Java面试之SpringCloud篇
87 1
|
5月前
|
消息中间件 负载均衡 Java
Java和Spring Cloud构建分布式系统
Java和Spring Cloud构建分布式系统
|
5月前
|
消息中间件 负载均衡 Java
使用Java和Spring Cloud构建分布式系统
使用Java和Spring Cloud构建分布式系统
|
1月前
|
设计模式 Java API
微服务架构演变与架构设计深度解析
【11月更文挑战第14天】在当今的IT行业中,微服务架构已经成为构建大型、复杂系统的重要范式。本文将从微服务架构的背景、业务场景、功能点、底层原理、实战、设计模式等多个方面进行深度解析,并结合京东电商的案例,探讨微服务架构在实际应用中的实施与效果。
130 6
|
1月前
|
设计模式 Java API
微服务架构演变与架构设计深度解析
【11月更文挑战第14天】在当今的IT行业中,微服务架构已经成为构建大型、复杂系统的重要范式。本文将从微服务架构的背景、业务场景、功能点、底层原理、实战、设计模式等多个方面进行深度解析,并结合京东电商的案例,探讨微服务架构在实际应用中的实施与效果。
51 1
|
20天前
|
Java 开发者 微服务
从单体到微服务:如何借助 Spring Cloud 实现架构转型
**Spring Cloud** 是一套基于 Spring 框架的**微服务架构解决方案**,它提供了一系列的工具和组件,帮助开发者快速构建分布式系统,尤其是微服务架构。
141 68
从单体到微服务:如何借助 Spring Cloud 实现架构转型