【Spring Cloud】微服务通信概述

news2024/11/23 19:06:22
SueWakeup

                                                      个人主页:SueWakeup

                                                      系列专栏:学习技术栈

                                                      个性签名:人生乏味啊,我欲令之光怪陆离

本文封面由 凯楠📷 友情赞助播出

 目录

前言

1. Dubbo(Spring Cloud Alibaba)和 Spring Cloud 的适用场景

2.  Dubbo(Spring Cloud Alibaba)实现 RPC 调用

3. Dubbo(Spring Cloud Alibaba)和传统 Dubbo 的区别

4. 处理服务之间同步和异步通信(Spring Cloud Alibaba)

5. 实现服务间的安全通信


前言

什么是微服务通信?

        微服务通信指的是在微服务架构中,应用程序被拆分成多个小型的、独立部署的服务单元,微服务通信通过网络协议帮助不同的微服务之间进行数据传输、调用对方的功能,实现系统的整体业务逻辑。


1. Dubbo(Spring Cloud Alibaba)和 Spring Cloud 的适用场景

场景DubboSpring Cloud
通信协议主要适用 RPC 协议,适合内部高效的服务间同步调用倾向于 RESTful HTTP 协议,适用于跨网络的异构系统集成
性能和延迟

在性能和延迟方面表现更优

适合对性能要求较高的内部服务通信

在通用性和易用性方面更强
生态和集成

专注于服务调用和性能优化

提供更全面的微服务解决方案

如配置管理、服务发现等

社区和支持适用于对性能有特殊要求的场景社区更活跃,与各种云平台的集成更深入

2.  Dubbo(Spring Cloud Alibaba)实现 RPC 调用

  1. 依赖配置:在项目中引入 Dubbo 和 Spring Cloud Alibaba 相关依赖
  2. 服务提供者配置:在服务提供者端配置 Dubbo 的服务暴露相关参数,如接口、版本等
  3. 服务消费者配置:在服务消费者端配置 Dubbo 的服务引用相关参数,如接口、版本等
  4. 注册中心配置:配置适用 Nacos 、ZooKeeper 等作为 Dubbo 的注册中心
  5. 服务调用:通过 Duubo 提供的代理机制实现远程服务的透明调用

3. Dubbo(Spring Cloud Alibaba)和传统 Dubbo 的区别

(Spring Cloud Alibaba)Dubbo传统 Dubbo
集成程度

更深入地集成了 Spring Cloud 生态

提供了与 Spring Cloud 组件的无缝衔接

配置管理

可以利用 Nacos 等配置中心进行配置管理

实现配置的动态更新

服务发现与注册支持适用 Nacos 等服务发现和注册中心通常适用 Zookeeper
熔断与限流可以与 Sentinel 等组件结合,提供熔断和限流功能
云原生支持对云原生环境提供更好的支持,适应容器化和微服务架构


4. 处理服务之间同步和异步通信(Spring Cloud Alibaba)

  1. 同步通信:适用 RESTful 或 Dubbo 等 RPC框架进行同步调用,适用于对实时性要求高的场景
  2. 异步通信:利用消息队列(RocketMQ、RabbitMQ等)进行异步消息传递,适用于耗时操作或解耦服务间的直接依赖
  3. 合适的通信方式:根据业务场景的实时性、可靠性和解耦需求选择合适的通信方式
  4. 服务回调机制:在异步通信中,使用回调机制处理相应结果,确保业务逻辑的连续性
  5. 事务一致性处理:在异步通信中注意事务一致性的问题,利用分布式事务解决方案保证数据的一致性

5. 实现服务间的安全通信

  • HTTPS 配置:在服务间通信中使用 HTTPS 协议加密数据传输
  • 服务认证:通过 OAuth2、JWT 等机制实现服务间的认证
  • 权限控制:利用 Spring Security 或其他安全框架实现细粒度的权限控制
  • API 网关安全:在 API 网关层实施安全策略,如请求限流
  • 数据加密:对敏感数据进行加密处理,确保数据在传输和存储过程中的安全

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

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

相关文章

使用ollama + webui 运行任意大模型

安装ollama https://hub.docker.com/r/ollama/ollama docker run -d -v ~/Documents/work/softs/docker/ollama:/root/.ollama -p 11434:11434 --name ollama ollama/ollama验证安装 # 进入容器docker exec -it ollama bash # 运行大模型 ollama run llama2 # 发送请求&…

【python + Django】Django模板语法 + 请求和响应

前言: 现在现在,我们要开始将变量的值展现在页面上面啦! 要是只会显示静态页面,我们的页面也太难看和死板了, 并且数据库的数据也没法展现在页面上。 但是呢,模板语法学习之后就可以啦!&…

笔记本8代i5和台式机12代i5的性能比较

一、 台式机12代i5 二、笔记本8代i5 在多核性能上差不多是2.4倍,所以跑大一点的Matlab或者别的程序,用台式机,后边实验室能用上超多核服务器另说。

【Flutter】文件选择器(file_picker)的用法

Flutter 没有提供内置的文件选择器,但社区内有人贡献了一个比较完整的解决方案——file_picker。 file_picker 的 API 简洁易用,支持全平台(Android / iOS / Mac / Linux / Windows),是我开发桌面应用时的首选。 这边…

IDEA中快速配置Git

Git介绍: Git下载 idea中配置Git

蓝桥杯单片机快速开发笔记——串口通信

一、原理分析 二、思维导图 三、示例框架 #include <STC15F2K60S2.H> #include "HC573.h"void UartInit(void) //9600bps12.000MHz {SCON 0x50; //8位数据,可变波特率AUXR | 0x01; //串口1选择定时器2为波特率发生器AUXR & 0xFB; //定时器时钟12T模式…

流畅的 Python 第二版(GPT 重译)(六)

第三部分&#xff1a;类和协议 第十一章&#xff1a;一个 Python 风格的对象 使库或框架成为 Pythonic 是为了让 Python 程序员尽可能轻松和自然地学会如何执行任务。 Python 和 JavaScript 框架的创造者 Martijn Faassen。 由于 Python 数据模型&#xff0c;您定义的类型可以…

【Linux】进程通信

目录 一、管道通信 二、共享内存 三、消息队列 一、管道通信 管道是由操作系统维护的一个文件&#xff0c;管道通信的本质就是将管道文件作为临界资源&#xff0c;实现不同进程之间的数据读写&#xff0c;但是管道只允许父子进程或者兄弟进程之间的通信。 管道文件本身是全…

数据结构从入门到精通——堆排序

堆排序 前言一、堆排序的基本思想二、堆排序的特性总结三、堆排序的动图展示四、堆排序的代码实现向上建堆test.c 前言 堆排序是一种利用堆数据结构实现的排序算法。首先&#xff0c;它将待排序的数组构建成一个大顶堆或小顶堆。然后&#xff0c;通过不断将堆顶元素&#xff0…

MC10T1S-10BASE-T1S车载以太网转换器

10BASE-T1S车载以太网转换器 为10BASE-T1S车载以太网转换器&#xff0c;支持Multidrop bus line和Point-to-Point。采用的DB9接口类型&#xff0c;支持PLCA。10BASE-T1S是IEEE 802.3cg标准制定的IEEE汽车以太网的最新标准之一&#xff0c;采用UTP这样的一对无屏蔽的双芯电缆进行…

Uibot (RPA设计软件)财务会计Web应用自动化(批量开票机器人)

Uibot (RPA设计软件&#xff09;Mage AI智能识别&#xff08;发票识别&#xff09;———机器人的小项目友友们可以参考小北的课前材料五博客~ (本博客中会有部分课程ppt截屏,如有侵权请及请及时与小北我取得联系~&#xff09; 紧接着小北的前两篇博客&#xff0c;友友们我们…

webpack5零基础入门-13生产模式

1.生产模式介绍 生产模式是开发完成代码后&#xff0c;我们需要得到代码将来部署上线。 这个模式下我们主要对代码进行优化&#xff0c;让其运行性能更好。 优化主要从两个角度出发: 优化代码运行性能优化代码打包速度 2.生产模式准备 我们分别准备两个配置文件来放不同的…

【C++】为什么vector的地址与首元素地址不同?

文章目录 一、问题发现&#xff1a;二、结果分析三、问题解析 一、问题发现&#xff1a; &vector和&vector[0]得到的两个地址居然不相同&#xff0c;对数组array取变量名地址和取首元素地址的结果是相同的。这是为啥呢&#xff1f; 使用下面代码进行验证&#xff1a;…

流畅的 Python 第二版(GPT 重译)(五)

第九章. 装饰器和闭包 有人对将这个功能命名为“装饰器”的选择提出了一些抱怨。主要的抱怨是该名称与其在 GoF 书中的用法不一致。 名称 decorator 可能更多地归因于其在编译器领域的用法—语法树被遍历并注释。 PEP 318—函数和方法的装饰器 函数装饰器让我们在源代码中“标记…

单片机-- 数电(3)

编码器与译码器 译码 &#xff1a;将二进制代码转化为其他进制的代码 编码 &#xff1a;就是将其他代码转换为二进制码 编码器的类型 1二进制编码器 用n位二进制数码对2的n次方个输入信号进行编码的电路 2二-十进制编码器 将0到9十个十进制数转化为二进制代码的电路 2…

SpringCloud中的@EnableDiscoceryClient和@EnableFeignClients注解的作用解析、RPC远程过程调用

目录 EnableDiscoveryClient 服务发现的核心概念 服务注册中心 EnableDiscoveryClient注解的作用 服务心跳健康检查 使用示例 EnableFeignClients Feign简介 EnableFeignClients注解的作用 RPC&#xff08;Remote Procedure Call&#xff09; 参考链接 Spring Cloud…

C++项目 -- 负载均衡OJ(一)compile_server

C项目 – 负载均衡OJ&#xff08;二&#xff09;compile_server 文章目录 C项目 -- 负载均衡OJ&#xff08;二&#xff09;compile_server一、compile_server设计1.总体服务流程 二、compiler.hpp三、runner.hpp四、compile_run.hpp五、compile_server.cc5.1.编译功能调试&…

Dockerfile Docker Compose(实战总结)

Dockerfile & Docker Compose&#xff08;实战总结&#xff09; Dockerfile Dockerfile 是用来构建Docker镜像文件&#xff0c;是由一条条构建镜像所需的指令构成的脚步。 步骤&#xff1a; 编写Dockerfile 文件docker build 构建镜像docker run 运行镜像docker push 发…

【黄金手指】windows操作系统环境下使用jar命令行解压和打包Springboot项目jar包

一、背景 项目中利用maven将Springboot项目打包成生产环境jar包。名为 prod_2024_1.jar。 需求是 修改配置文件中的某些参数值&#xff0c;并重新发布。 二、解压 jar -xvf .\prod_2024_1.jar释义&#xff1a; 这段命令是用于解压缩名为"prod_2024_1.jar"的Java归…

【QT入门】实现一个简单的图片查看软件

声明&#xff1a;该专栏为本人学习Qt知识点时候的笔记汇总&#xff0c;希望能给初学的朋友们一点帮助(加油&#xff01;) 往期回顾&#xff1a; 【QT入门】qmake和cmake的简单区别-CSDN博客 【QT入门】VS qt和QtCreator项目的相互转换-CSDN博客 【QT入门】Qt架构与三个窗口的区…