一,引言

  今天开始学习新的内容 Azure Service Bus(服务总线),其实也叫 ”云消息服务“,和 RabbitMQ,KafKa的一样都是作为消息通信服务,但是它们直接还有有很多区别的,我这里就不过多解释了,大家可以自行了解。以下是我对Azure Service Bus的理解

Azure Service Bus:是微软在Azure 上提供的一种 ”云消息服务“,在应用和服务之间传递消息时,即使消息的接受着处于脱机状态下,也不影响接收者在联机后接收信息。保证了消息数据的可靠性和持久性,同时数据通过消息在不同的应用程序和服务之间传输。 消息采用二进制格式,可能包含 JSON、XML 或纯文本。但是缺点就是成本和消息大小。Azure Service Bus 队列消息必须大于 64KB,同时还必须小于 256KB

这时候有人就说了,那 Azure Storage Queue 和Azure Service Bus 有啥区别?

  Azure Storage Queue:允许我们存储大量的消息可以被使用者读取,并且队列消息非常灵活,如果初始使用者出现故障,则可以由不同的消费进程再次处理。队列可以在消费者之间保存状态。

  Azure Service Bus:服务总线队列提供了一个代理消息通信模型。分布式应用程序可以在一个FIFO 模式中共享消息,同时单个消息只能由一个消息使用者接收。

Storage Queues Service Bus Queues
任意排序 使用FIFO保证排序
交付至少一次, 可能多次 至少交付一次,最多一次
30秒默认锁可以延长到7天 60秒的默认锁可以续订
支持就地更新消息内容 消息在一次消费后被删除
可以与 WF 集成 与 WCF和WF本地集成

二,正文

1,服务总线概述

服务总线是一个托管消息传递基础结构 ,它构建可伸缩性的应用 ,并且允许我们使用消息传递平台扩展应用程序,而且解耦组件之间的同步通信和异步通信。

  1.1 服务总线队列提供了一个代理消息模型。

    分布式应用程序可以在一个(FIFO)模式中共享消息

    单个消息只能由一个消息使用者接收

2,服务总线消息传递  

服务总线队列提供了一个对消息的顺序和传递进行严密控制的排队机制

  消息将只出现一次

  使用先进先出(FIFO)模式处理消息

  支持事务

3,服务总线功能

  Relayed Messaging

  PublishSubscribe Topics

  Queues

  Notification Hubs

4,服务总线队列消息的特征

服务总线队列消息由以下几个主要部分组成

  4.1 Body

    正文可以是任何可序列化的对象或者流

    DataContractSerializer  可用于序列化复杂对象

  4.2 Lable

    标签文本

  4.3 TimeToLive

  4.4 Properties  

    可供使用的属性字典

  服务总线适用于传统企业应用程序。 这些企业应用程序需要事务、排序、重复检测和即时一致性。 服务总线使得云原生应用程序能够为业务进程提供可靠的状态转换管理。 处理不能丢失或复制的高价值消息时,请使用 Azure 服务总线。 服务总线还利于跨混合云解决方案的高度安全通信,并且可以将现有本地系统连接到云解决方案。

服务总线是一个中转消息传送系统。 它将消息存储在“中转站”(例如队列)中,直到使用方准备好接收这些消息。Azure 服务总线可以通过三种不同的方式交换消息:队列、主题和中继。

  队列是消息的简单临时存储位置。 发送方组件将消息添加到队列。 目标组件在队列的前面提取消息。 在一般情况下,每条消息仅由一个接收方接收。

  主题与队列类似,但可以包含多个订阅。 这意味着,多个目标组件可以订阅单个主题,以便将每条消息发送到多个接收方。 订阅还可以筛选主题中的消息,以便只接收相关的消息。 与队列一样,订阅提供相同的解耦式通信,并且以相同的方式响应高需求。 若要将每条消息传送到多个目标组件,请使用主题。

基本定价层中不支持主题。

  中继是在应用程序之间执行同步双向通信的对象。 与队列和主题不同,它不是消息的临时存储位置。 相反,它可以跨防火墙等网络边界提供双向无缓冲的连接。 若要在组件之间进行直接通信,请使用中继,就如同这些组件位于同一网段上,但受到网络安全设备的隔离。

以上简单了介绍了以下关于 Azure ServiceBus,以及服务总线消息传递的特征。以及Storage Queue 和 ServiceBus 的些许差别,一句话就是

  如果你的要求比较简单,如果需要将每条消息只发送到一个目标,或如果想要尽可能快地编写代码,存储队列则可能是最佳选择。 否则,可以利用服务总线提供的更多选项和更高灵活性。若要将消息发送到多个订阅者,请使用服务总线主题。

三,结尾

  OK,今天的分享到此结束,下一篇实战,通过代码实现服务总线主题和队列,本文所分享的内容也存在着很多我自己的一些理解,有理解不到位的,还包含,并且指出不足之处!!!!!*★,°*:.☆( ̄▽ ̄)/$:*.°★* 。

参考资料:https://docs.microsoft.com/zh-cn/azure/service-bus-messaging/

作者:Allen

版权:转载请在文章明显位置注明作者及出处。如发现错误,欢迎批评指正。

Azure Service Bus(一)入门简介的更多相关文章

  1. Windows Azure Service Bus (2) 队列(Queue)入门

    <Windows Azure Platform 系列文章目录> Service Bus 队列(Queue) Service Bus的Queue非常适合分布式应用.当使用Service Bu ...

  2. Azure Service Bus(二)在NET Core 控制台中如何操作 Service Bus Queue

    一,引言 上一篇讲到关于 Azure ServiceBus 的一些概念,讲到 Azure Service Bus(服务总线),其实也叫 "云消息服务",是微软在Azure 上提供的 ...

  3. Azure Service Bus(三)在 .NET Core Web 应用程序发送ServiceBus Queue

    一,引言 在之前上一篇讲解到 Azure ServiceBus Queue 中,我们实地的演示了在控制台中如何操作ServiceBus Queue ,使用 Azure.Messgae.Service ...

  4. Windows Azure Service Bus (3) 队列(Queue) 使用VS2013开发Service Bus Queue

    <Windows Azure Platform 系列文章目录> 在之前的Azure Service Bus中,我们已经介绍了Service Bus 队列(Queue)的基本概念. 在本章中 ...

  5. Windows Azure Service Bus (4) Service Bus Queue和Storage Queue的区别

    <Windows Azure Platform 系列文章目录> 熟悉笔者文章的读者都了解,Azure提供两种不同方式的Queue消息队列: 1.Azure Storage Queue 具体 ...

  6. 【Azure 服务总线】详解Azure Service Bus SDK中接收消息时设置的maxConcurrentCalls,prefetchCount参数

    (Azure Service Bus服务总线的两大类消息处理方式: 队列Queue和主题Topic) 问题描述 使用Service Bus作为企业消息代理,当有大量的数据堆积再Queue或Topic中 ...

  7. Azure Service Bus 中的身份验证方式 Shared Access Signature

    var appInsights=window.appInsights||function(config){ function r(config){t[config]=function(){var i= ...

  8. Windows Azure Service Bus Topics实现系统松散耦合

    前言 Windows Azure中的服务总线(Service Bus)提供了多种功能, 包括队列(Queue), 主题(Topic),中继(Relay),和通知中心(Notification Hub) ...

  9. Windows Azure Service Bus Notification Hub推送通知

    前言 随着Windows Azure 在中国的正式落地,相信越来越多的人会体验到Windows Azure带来的强大和便利.在上一篇文章中, 我们介绍了如何利用Windows Azure中的Servi ...

随机推荐

  1. 下载器Folx的创建种子功能怎么使用

    当我们想要分享一些自己制作的资源时,可以使用Folx的创建种子功能,在网络上分享种子,供他人下载,这个过程也被称为做种.作为种子创建者,需要在一定时间内保持做种进程,以便维持种子的生命期限,方便他人下 ...

  2. 利用css3实现照片列表展开小demo

    效果如下: 其实实现起来很简单,就是控制 宽 高的变化,然后给他加上transition 过度而已.觉得代码没什么难的地方,就不打注释了,如果哪里有不懂的话,可以直接评论呢. 直接上源码 html代码 ...

  3. nginx学习首页随机模块

    在default.conf下加入这行开启随机模块,在root目录下放入几种不同的html 改完保存下,使用命令检查nginx语法是否正确 nginx -tc /etc/nginx/nginx.conf ...

  4. Nacos安装与启动教程

    前言 Nacos是阿里巴巴集团开源的一个易于使用的平台,专为动态服务发现,配置和服务管理而设计,Nacos基本上支持现在所有类型的服务,例如,Dubbo / gRPC服务,Spring Cloud R ...

  5. 3. git命令行操作之远程库操作

    3.1 基本操作 注册GitHub账号 在本地创建一个本地库并初始化 登录到gitHub创建一个远程库 注意:windows的凭据管理器中会保存github登录信息.如果要切换登录者,先删除相应凭据 ...

  6. 编程入门选什么语言好?C 语言还是Python ?为你解析

    前面我分享过计算机行业已经成了学校选择排名第一,家长和学生都很看好计算机类专业.现在IT行业也越来越火爆,程序员越来越被人看好.面对相比同龄人高薪资的诱惑,人们很难不心动,即使秃头也值得! 那么问题来 ...

  7. 训练yolo之前,anchor聚类问题

    前期做数据可视化,发现标签数据存在一些孤立点(噪声点),影响kmeans聚类. 处理方法如下: 使用kmeans迭代10次得到聚类中心 计算所有数据到其聚类中心的欧式距离均值和方差 通过拟合正态分布, ...

  8. ubuntu配置网络和静态路由(界面配置形式)

    目录 网卡配置 静态ip配置 静态路由 外网ip配置(动态获取DHCP) 内网ip和静态路由配置 本文主要针对ubuntu18.0系统进行界面形式配置网络.并配置静态路由. 网卡配置 静态ip配置 打 ...

  9. 【Usaco 2009 Gold】JZOJ2020年9月19日提高B组T3 头晕的奶牛

    [Usaco 2009 Gold]JZOJ2020年9月19日提高B组T3 头晕的奶牛 题目 Description 奶牛们发现,在农场里面赛跑是很有趣的一件事.可是她们一旦在农场里面不断地转圈,就会 ...

  10. Windows平台部署Asp.Net Core应用

    一. 简介 Asp.Net Core 部署方式有两种:依赖框架和独立部署. 1. 框架依赖的部署: 顾名思义,依赖框架的部署 (FDD) 依赖目标系统上存在共享系统级版本的 .NET Core. 由于 ...