微服务实战系列之通信

前言

掰个指头数一数,博主的“微服务实战系列”从无到有,从零走到了十五。如果比作时钟,刚好走过了一刻度。

当初为什么要做这个系列,博主想了又想,私以为作为当下软件领域的几个“hot spot”之一,又乘着春天(Spring)之东风,微服务的种子已然深埋于每个程序猿/媛的心中。而在实际工作/学习中,有太多基础理论、技能必须掌握。

微服务不仅仅是一个名词,更是一个动词,一个体系化的服务设计思路。我们说服务的本质是在做数据交换,所谓“以数易数”。早期人类也正是通过以物换物的方式,促成最早也最简单的的合作模型。

感叹至此,言归正传,书接上文,继续带着各位盆友,大话微服务

在这里插入图片描述

上图是一个简易型微服务交互设计框架,我们以它作为今天的起点,开始新的旅程,GO~


  • 微服务实战系列之J2Cache
  • 微服务实战系列之Cache(技巧篇)
  • 微服务实战系列之MemCache
  • 微服务实战系列之EhCache
  • 微服务实战系列之Redis
  • 微服务实战系列之Cache
  • 微服务实战系列之Nginx(技巧篇)
  • 微服务实战系列之Nginx
  • 微服务实战系列之Feign
  • 微服务实战系列之Sentinel
  • 微服务实战系列之Token
  • 微服务实战系列之Nacos
  • 微服务实战系列之Gateway
  • 微服务实战系列之加密RSA
  • 微服务实战系列之签名Sign

Q:如何建立通信

提到通信方式,博主立刻可以想到:“书信、邮件、短信”等媒介。
古代信息不发达,通信工具缺乏,山高路远,幸亏有了造纸术,才有笔墨纵横的天地。今天我们就先谈谈两个人是如何建立通信的。

1. 打电话

在这里插入图片描述

作为最直接了当,便捷有效,可随时掌握对方情况的通信手段,打电话自然是首选。你可以通过各路感官亲切的察觉到对方的“一举一动”,从而获取有价值的信息,以达成自己的预期目标。此刻,如果对方接了,心表甚慰,可以愉快的开始对话;如果对方没接(不管有意无意),你怎么办? 坐着傻等也不是办法啊,果断寻找新思路。

2. 发短信

在这里插入图片描述
电话打不通,发个短信呗,迟早会看吧? 显然想得有点美了,万一还不回复呢? 这不“已读不回”“诅咒”就来了。如果两个人是熟人也就罢了,万一不是熟人,那真是干着急没办法呀。幸亏我们是聪明一族,从容地找到了新方法。

3. 群发

在这里插入图片描述
在某些情况下,我们可以使用短信“轰炸”对方。可以选择单轰,也可以群炸(O(∩_∩)O哈哈~)。
当然博主并不推荐蛮干,不然“事前有多痛快,事后有多懊悔”。当你需要简单、快捷、有效的传递所思所想所念之时,群发是一个不错的选择。不必关心每个人是否回复,只关心有多少人回复就足够了。

但是此刻对方的心里会怎么样? 当然略显无奈,心里暗暗揣度:我遇到了什么**。既然有了反抗的想法,那自然要有所行动。

4. 订阅

在这里插入图片描述
如果实在躲不了逃不了,那就订阅呗,何必自寻烦恼。事先约定好何时何地通信不就行了嘛,从此你好我好大家好,生活日子甜美如初。

综上,博主为各位盆友介绍了两个人如何建立通信的形式和过程。因为如此平常,自然易于理解,博主不再展开。

接下来,继续思考一个问题,请将目光锁定博主,继续跟着走。

Q:如何正确的通信

既然两个人成功建立了联系,那该如何保障通信成功呢?有什么正确的方式可循?答案当然是有的。

1. 同步(Sync)

什么是同步? 刚才其实已经举例了,打电话呀,你打我接,不说bye不能挂。

同步:一个人发出一个指令时,必须等待对方反馈,否则“坐等”

这就好比服务器都冒烟了,你还在那傻傻的等,但等也有等的好处啊!你去商超买菜,去公园排队等等,其实都在兢兢业业干一件事,正是“事倍功倍”
在这里插入图片描述

2. 异步(Async)

兢兢业业的是同步,难道异步就不是了?那怎么可能。异步的骄傲我们来慢慢体会。

异步:一个人发出一个指令后,可以接着发出第二个指令。当然可以是对同一个人发,也可以对多个人发。

好嘛,这不正是群发么?“咱不管对不对,先追求快不快”。当然如此一意孤行,那难免招来仇恨。所以怎么做到既对又快,才是幸福甜蜜的真谛。

在这里插入图片描述

关于同步或异步的通信机制,博主已经大致介绍了。简单一句话:“爱我所用,选我所喜”

Q:如何选择通信工具

掌握了如何正确的通信,那是不是该找工具了,比如手机、邮箱,皆是工具。回到我们的微服务中,又是什么呢?请转移视线,回到博主的第一张微服务图(service),凡箭头指向,皆是通信的两端。

比如Feign,比如Rpc,比如Resful,均是基于同步的请求/响应模式。
比如点对点(Point to Point, P2P)和发布-订阅(Publish and Subscribe, Pub-Sub),均是基于异步的通信模式。

博主私以为,无论同步或异步,取决于业务场景的条件和要求,没有正确与否之说。通信是消息传递的媒介和手段,消息是数据的载体和容器。微服务又是基于通信完成的,一链一点,点点相依。
在这里插入图片描述


结语

今天博主带着各位盆友,对微服务之间如何通信进行了简单的介绍。当你在实际工作中,遇到同步/异步的选择题时,或许用得上。RemoteService作为微服务界的高频词汇和主角,选择合适的工具驾驭它,是一门重要的功课。

本期内容,暂时到此结束,欢迎分享、指导、交流!

在这里插入图片描述

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

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

相关文章

机器学习---Adaboost算法

1. Adaboost算法介绍 Adaboost是一种迭代算法,其核心思想是针对同一个训练集训练不同的分类器(弱分类器),然 后把这些弱分类器集合起来,构成一个更强的最终分类器(强分类器)。Adaboost算法本身…

《地理信息系统原理》笔记/期末复习资料(10. 空间数据挖掘与空间决策支持系统)

目录 10. 空间数据挖掘与空间决策支持系统 10.1. 空间数据挖掘 10.1.1. 空间数据挖掘的概念 10.1.2. 空间数据挖掘的方法与过程 10.1.3. 空间数据挖掘的应用 10.2. 空间决策支持系统 10.2.1. 空间决策支持系统的概念 10.2.2. 空间决策支持系统的结构 10.2.3. 空间决策…

理解排序算法:冒泡排序、选择排序与归并排序

简介: 在计算机科学中,排序算法是基础且重要的概念。本文将介绍三种常见的排序方法:冒泡排序、选择排序和归并排序。我们将探讨它们的工作原理、特点和适用场景,以帮助读者更好地理解和选择合适的排序方法。 冒泡排序 冒泡排序是…

【面试经典150 | 二叉树】从前序与中序遍历序列构造二叉树

文章目录 写在前面Tag题目来源题目解读解题思路方法一:递归 写在最后 写在前面 本专栏专注于分析与讲解【面试经典150】算法,两到三天更新一篇文章,欢迎催更…… 专栏内容以分析题目为主,并附带一些对于本题涉及到的数据结构等内容…

QT作业4

实现一个闹钟&#xff0c;当输入时间后&#xff0c;点击启动到达时间后循环播报三遍&#xff0c;便签内容 头文件&#xff1a; #ifndef WIDGET_H #define WIDGET_H#include <QWidget> #include <QTextToSpeech> //文本转语言类 #include <QTimerEvent> //定…

Android : BottomNavigation底部导航_简单应用

示例图&#xff1a; 1.先创建底部导航需要的图片 res → New → Vector Asset 创建三个矢量图 图片1 baseline_home.xml <vector android:height"24dp" android:tint"#000000"android:viewportHeight"24" android:viewportWidth"24…

Axure电商产品移动端交互原型,移动端高保真Axure原型图(RP源文件手机app界面UI设计模板)

本作品是一套 Axure8 高保真移动端电商APP产品原型模板&#xff0c;包含了用户中心、会员成长、优惠券、积分、互动社区、运营推广、内容推荐、商品展示、订单流程、订单管理、售后及服务等完整的电商体系功能架构和业务流程。 本模板由一百三十多个界面上千个交互元件及事件组…

基于Qt的蓝牙Bluetooth在ubuntu实现模拟

​# 前言 Qt 官方提供了蓝牙的相关类和 API 函数,也提供了相关的例程给我们参考。笔者根据 Qt官方的例程编写出适合我们 Ubuntu 和 gec6818开发板的例程。注意 Windows 上不能使用 Qt 的蓝牙例程,因为底层需要有 BlueZ协议栈,而 Windows 没有。Windows 可能需要去移植。笔者…

数据挖掘目标(Kaggle Titanic 生存测试)

import numpy as np import pandas as pd import matplotlib.pyplot as plt import seaborn as sns1.数据导入 In [2]: train_data pd.read_csv(r../老师文件/train.csv) test_data pd.read_csv(r../老师文件/test.csv) labels pd.read_csv(r../老师文件/label.csv)[Su…

HTML中常用表单元素使用(详解!)

Hi i,m JinXiang ⭐ 前言 ⭐ 本篇文章主要介绍HTML中常用表单元素使用以及部分理论知识 &#x1f349;欢迎点赞 &#x1f44d; 收藏 ⭐留言评论 &#x1f4dd;私信必回哟&#x1f601; &#x1f349;博主收将持续更新学习记录获&#xff0c;友友们有任何问题可以在评论区留言 …

CentOS 7 源码部署 Nginx

文章目录 1. 概述2. 部署示例2.1 下载和解压 Nginx 源码2.2 安装编译依赖包2.3 编译和安装2.4 启动 Nginx2.5 配置防火墙2.6 设置 Nginx 为系统服务2.7 配置访问 3. 扩展知识 1. 概述 Nginx 是一款高性能的开源 Web 服务器软件&#xff0c;广泛应用于互联网领域。本篇博客将介…

【Matlab】如何将二阶线性微分方程进行Laplace变换得到传递函数

二阶线性微分方程进行Laplace变换 前言正文代码实现 前言 二阶线性微分方程: 一个二阶线性微分方程通常可以写成如下形式: y ′ ′ ( t ) p ( t ) y ′ ( t ) q ( t ) y ( t ) f ( t ) y^{\prime \prime}(t)p(t) y^{\prime}(t)q(t) y(t)f(t) y′′(t)p(t)y′(t)q(t)y(t)f(…

selenium自动化(中)

显式等待与隐式等待 简介 在实际工作中等待机制可以保证代码的稳定性&#xff0c;保证代码不会受网速、电脑性能等条件的约束。 等待就是当运行代码时&#xff0c;如果页面的渲染速度跟不上代码的运行速度&#xff0c;就需要人为的去限制代码执行的速度。 在做 Web 自动化时…

ArkUI组件

目录 一、概述 声明式UI 应用模型 二、常用组件 1、Image&#xff1a;图片展示组件 示例 配置控制授权申请 2、Text&#xff1a;文本显示组件 示例 3、TextInput&#xff1a;文本输入组件 示例 4、Button&#xff1a;按钮组件 5、Slider&#xff1a;滑动条组件 …

【vue实战项目】通用管理系统:信息列表,信息的编辑和删除

本文为博主的vue实战小项目系列中的第七篇&#xff0c;很适合后端或者才入门的小伙伴看&#xff0c;一个前端项目从0到1的保姆级教学。前面的内容&#xff1a; 【vue实战项目】通用管理系统&#xff1a;登录页-CSDN博客 【vue实战项目】通用管理系统&#xff1a;封装token操作…

19、命令模式(Command Pattern,不常用)

命令模式&#xff0c;将一个请求封装为一个对象&#xff08;命令&#xff09;&#xff0c;使发出请求的责任和执行请求的责任分割开&#xff0c;有效降低系统的耦合度。这样两者之间通过命令对象进行沟通&#xff0c;这样方便将命令对象进行储存、传递、调用、增加与管理。命令…

10基于matlab的悬臂梁四节点/八节点四边形单元有限元编程(平面单元)

悬臂梁&#xff0c;有限元编程。基于matlab的悬臂梁四节点/八节点四边形单元有限元编程&#xff08;平面单元&#xff09;&#xff0c;程序有详细注解&#xff0c;可根据需要更改参数&#xff0c;包括长度、截面宽度和高度、密度、泊松比、均布力、集中力、单元数量等。需要就拍…

数字化转型对企业有什么好处?

引言 数字化转型已经成为当今商业领域中的一股强大力量&#xff0c;它不仅仅是简单的技术更新&#xff0c;更是企业发展的重要战略转变。随着科技的迅猛发展和全球化竞争的加剧&#xff0c;企业们正在积极探索如何将数字化的力量融入到他们的运营和战略中。 数字化转型不仅是传…

智能优化算法应用:基于布谷鸟算法3D无线传感器网络(WSN)覆盖优化 - 附代码

智能优化算法应用&#xff1a;基于布谷鸟算法3D无线传感器网络(WSN)覆盖优化 - 附代码 文章目录 智能优化算法应用&#xff1a;基于布谷鸟算法3D无线传感器网络(WSN)覆盖优化 - 附代码1.无线传感网络节点模型2.覆盖数学模型及分析3.布谷鸟算法4.实验参数设定5.算法结果6.参考文…

多维时序 | MATLAB实现BWO-CNN-BiGRU-Multihead-Attention多头注意力机制多变量时间序列预测

多维时序 | MATLAB实现BWO-CNN-BiGRU-Multihead-Attention多头注意力机制多变量时间序列预测 目录 多维时序 | MATLAB实现BWO-CNN-BiGRU-Multihead-Attention多头注意力机制多变量时间序列预测预测效果基本介绍模型描述程序设计参考资料 预测效果 基本介绍 MATLAB实现BWO-CNN-B…