【Spring Cloud】微服务通信概述

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.mzph.cn/news/759551.shtml

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

相关文章

Python利用pygame实现飞机大战游戏

文章目录: 一:运行效果 1.演示 2.思路和功能 二:代码 文件架构 Demo 必备知识:python图形化编程pygame游戏模块 一:运行效果 1.演示 效果图◕‿◕✌✌✌ Python利用pygame实现飞机大战游戏运行演示 参考&#x…

AMPQ和rabbitMQ

RabbitMQ 的 Channel、Connection、Queue 和 Exchange 都是按照 AMQP(Advanced Message Queuing Protocol)标准实现的。 AMPQ的网络部分 AMQP没有使用HTTP,使用TCP自己实现了应用层协议。 AMQP实现了自己特有的网络帧格式。 一个Connection…

[网鼎杯 2020 朱雀组]Think Java

[网鼎杯 2020 朱雀组]Think Java swagger [[swagger]] 首先下载源码,查看之后发现 查找swagger资料,或者扫描,得到:swagger-ui.html swagger-ui 提供了一个可视化的UI页面展示描述文件。接口的调用方、测试、项目经理等都可以…

[激光原理与应用-76]:光束指向性与影响因素

目录 一、光束指向性 1.1 概述 2.2 光束指向性与光斑大小的区别 2.3 光束指向性与时间的关系 二、激光器的光束指向性的测量方法 2.1 概述 2.2 计算方法 三、激光器中影响光束指向性的因素 一、光束指向性 1.1 概述 光束指向性是指光束传播方向的特性,也可…

【Linux】进程通信

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

刷题DAY29 | LeetCode 491-递增子序列 46-全排列 47-全排列 II

491 递增子序列(medium) 给你一个整数数组 nums ,找出并返回所有该数组中不同的递增子序列,递增子序列中 至少有两个元素 。你可以按 任意顺序 返回答案。 数组中可能含有重复元素,如出现两个整数相等,也…

开放签开源电子签章白皮书-简版

开放签开源电子签章白皮书-简版 一、摘要: 开放签电子签章团队源自于电子合同SaaS公司,立志于通过开源、开放的模式,结合团队十多年的行业经验,将电子签章产品更简单、更低门槛的推广到各行各业中。让电子签章应用更简单&#x…

Fetch、Axios 和 jQuery(Ajax) 三种常用的网络请求技术

Fetch、Axios 和 jQuery(Ajax) 是三种常用的网络请求技术,它们各自有着不同的特点和优势。本文将对这三种技术进行详细的介绍和比较,以帮助开发者更好地选择和使用合适的网络请求技术。 一、Fetch Fetch(浏览器自带) 是一种现代的网络请求 API&#xff…

Vue3组件的注册

组件是Vue.js中的一个重要概念,它是一种抽象,是一个可以复用的Vue.js实例。它拥有独一无二的组件名称,可以扩展HTML元素,以组件名称的方式作为自定义的HTML标签。 在大多数系统网页中,网页都包含header、body、footer…

Debezium vs OGG vs Tapdata:如何实时同步 Oracle 数据到 Kafka 消息队列?

随着信息时代的蓬勃发展,企业对实时数据处理的需求逐渐成为推动业务创新和发展的重要驱动力。在这个快速变化的环境中,许多企业选择将 Oracle 数据库同步到 Kafka,以满足日益增长的实时数据处理需求。本文将深入探讨这一趋势的背后原因&#…

数学建模(熵权法 python代码 例子)

目录 介绍: 模板: 例子:择偶 极小型指标转化为极大型(正向化): 中间型指标转为极大型(正向化): 区间型指标转为极大型(正向化)&#xff1a…

基于BusyBox的imx6ull移植sqlite3到ARM板子上

1.官网下载源码 https://www.sqlite.org/download.html 下载源码解压到本地的linux环境下 2.解压并创建install文件夹 3.使用命令行配置 在解压的文件夹下打开终端,然后输入以下内容,其中arm-linux-gnueabihf是自己的交叉编译器【自己替换】 ./config…

PyTorch 深度学习(GPT 重译)(三)

六、使用神经网络拟合数据 本章内容包括 与线性模型相比,非线性激活函数是关键区别 使用 PyTorch 的nn模块 使用神经网络解决线性拟合问题 到目前为止,我们已经仔细研究了线性模型如何学习以及如何在 PyTorch 中实现这一点。我们专注于一个非常简单…

拷贝他人maven仓库jar包到自己本地仓库,加载maven依然提示无法下载对应依赖

所遇问题: 拷贝他人maven仓库jar包到自己本地maven仓库repository下的对应依赖位置,重新加载idea的maven依然提示无法下载对应依赖。 解决办法: 在maven->repository找到对应报错依赖路径,删除xxx.repositories 和 xxx.lastU…

【视频图像取证篇】模糊图像增强技术之去噪声类滤波场景应用小结

【视频图像取证篇】模糊图像增强技术之去噪声类滤波场景应用小结 模糊图像增强技术之去噪声类滤波场景应用小结—【蘇小沐】 文章目录 【视频图像取证篇】模糊图像增强技术之去噪声类滤波场景应用小结(一)去噪声类滤波器1、去块滤波器(Deblo…

32.768K晶振X1A000141000300适用于无人驾驶汽车电子设备

科技的发展带动电子元器件的发展电子元器件-“晶振”为现代的科技带来了巨大的贡献,用小小的身体发挥着大大的能量。 近两年无人驾驶汽车热度很高,不少汽车巨头都已入局。但这项技术的难度不小,相信在未来几年里,无人驾驶汽车这项…

软考高级:软件架构风格-独立构件风格概念和例题

作者:明明如月学长, CSDN 博客专家,大厂高级 Java 工程师,《性能优化方法论》作者、《解锁大厂思维:剖析《阿里巴巴Java开发手册》》、《再学经典:《Effective Java》独家解析》专栏作者。 热门文章推荐&am…

MySQL 索引的分类和优化

​ 优质博文:IT-BLOG-CN 索引是什么 : MySQL 官方对索引的定义:索引(Index)是帮助 MySQL 高效获取数据的数据结构。可以得到索引的本质:索引是数据结构。索引的目的在于提高查询效率。可以简单理解为&#…

力扣爆刷第101天之hot100五连刷91-95

力扣爆刷第101天之hot100五连刷91-95 文章目录 力扣爆刷第101天之hot100五连刷91-95一、62. 不同路径二、64. 最小路径和三、5. 最长回文子串四、1143. 最长公共子序列五、72. 编辑距离 一、62. 不同路径 题目链接:https://leetcode.cn/problems/unique-paths/desc…

实现防抖函数并支持第一次立刻执行(vue3 + ts环境演示)

1、先看一效果: 2、实现思路: 使用定时器setTimeout和闭包实现常规防抖功能;增加immediate字段控制第一次是否执行一次函数(true or false);增加一个flag标识,在第一次执行时,将标…