发布/订阅

✍ dations ◷ 2024-12-23 19:47:56 #软件设计模式,中间件

在软件架构中,发布-订阅是一种消息范式,消息的发送者(称为发布者)不会将消息直接发送给特定的接收者(称为订阅者)。而是将发布的消息分为不同的类别,无需了解哪些订阅者(如果有的话)可能存在。同样的,订阅者可以表达对一个或多个类别的兴趣,只接收感兴趣的消息,无需了解哪些发布者(如果有的话)存在。

发布/订阅是消息队列范式的兄弟,通常是更大的面向消息中间件(英语:Message-oriented_middleware)系统的一部分。大多数消息系统在API中同时支持消息队列模型和发布/订阅模型,例如Java消息服务(JMS)。

这种模式提供了更大的网络可扩展性和更动态的网络拓扑,同时也降低了对发布者和发布数据的结构修改的灵活性。

在发布/订阅模型中,订阅者通常接收所有发布的消息的一个子集。选择接受和处理的消息的过程被称作过滤。有两种常用的过滤形式:基于主题的和基于内容的。

在基于主题的系统中,消息被发布到主题或命名通道上。订阅者将收到其订阅的主题上的所有消息,并且所有订阅同一主题的订阅者将接收到同样的消息。发布者负责定义订阅者所订阅的消息类别。

在基于内容的系统中,订阅者定义其感兴趣的消息的条件,只有当消息的属性或内容满足订阅者定义的条件时,消息才会被投递到该订阅者。订阅者需要负责对消息进行分类。

一些系统支持两者的混合:发布者发布消息到主题上,而订阅者将基于内容的订阅注册到一个或多个主题上。

在许多发布/订阅系统中,发布者发布消息到一个中间的消息代理,然后订阅者向该消息代理注册订阅,由消息代理来进行过滤。消息代理通常执行存储转发的功能将消息从发布者发送到订阅者。

最早公开描述发布/订阅系统之一的是Isis Toolkit的“新闻”子系统,1987年,在计算机协会 (ACM)的操作系统原理的研讨会上,,在论文《在分布式系统中利用虚同步》中。该文描述的发布/订阅技术是由Frank Schmuck发明的。

发布/订阅系统最严重的问题是其主要优点的副作用:发布者解耦订阅者。

发布/订阅系统必须仔细设计,才能提供特定的应用程序可能需要的更强大的系统性能,例如有保障的交付。

在有少量发布者和订阅节点的小型网络和低信息量时发布/订阅能够自如伸缩。然而,随着节点和消息量的增长,不稳定性随之增长,限制了发布/订阅网络的最大可扩展性。大规模时吞吐量不稳定的例子包括:

使用中介(服务器)的发布/订阅系统,同意中介发送消息给带内(英语:In-band_control)订阅者,会引发安全问题。中介可能被愚弄,从而将通知发送给错误的客户端,增大了针对客户端的服务请求被拒绝的可能性。中介本身可能超载,因为他们分配资源来跟踪创建的订阅。

即使不依赖中介的系统,订阅者也可能可以接收未被授权的数据。未经授权的发布者可能将不正确或损坏的消息引入到发布/订阅系统。对于广播或多播消息的系统,这是尤其真实的。加密(例如传输层安全性协议(SSL/TLS)),可以防止未经授权的访问,但不能防止损坏的消息被授权的发布者引入。除了发布/订阅架构,例如客户端/服务器系统,也经常碰到授权的消息发送者有恶意行为。


相关

  • 磺胺磺胺(Sulfanilamide),即对氨基苯磺酰胺,是一种具有药用价值的有机物,最早在1908年由奥地利化学家保罗·雅各布·约瑟夫·杰尔莫(Paul Josef Jakob Gelmo)合成,并在1909年获得专利权
  • 氚(Tritium;符号:T或3H,注音:ㄔㄨㄢ;拼音:chuān)。亦称超重氢,是氢的同位素之一,元素符号为T或3H。它的原子核由一颗质子和两颗中子所组成,并带有放射性,会发生β衰变,放出电子变成氦-3,
  • 蓬皮杜中心蓬皮杜中心(法语:Centre Georges-Pompidou)全名为蓬皮杜国家艺术和文化中心(Centre national d'art et de culture Georges-Pompidou),是一栋座落于法国首都巴黎第四区的复合建筑,
  • 大阿尔伯特大阿尔伯特(Albertus Magnus,约1200年-1280年11月15日)是一位中世纪欧洲重要的哲学家和神学家,他是多明我会神父,由于他知识丰富而著名,他提倡神学与科学和平并存。有人认为他是中
  • 山东蓝翔高级技工学校山东蓝翔技师学院,简称山东蓝翔或蓝翔,是位于山东省济南市的一所职业技术学校。该校原名山东蓝翔高级技工学校。对山东蓝翔的调侃曾在网络上形成亚文化。河南虞城县农民、蓝翔
  • 非洲猛犸非洲猛犸(学名:,意即“非洲始祖猛犸”),是最古老的猛犸之一,它第一次出现大概是在300万年前的上新世末期。其化石在乍得、摩洛哥、突尼斯和利比亚都有发现。它可能是南方猛犸的祖
  • 弗兰兹·库恩弗兰兹·库恩(德语:Franz W. Kuhn,1884年3月10日-1961年1月22日),德国著名中国文学翻译家。中国古典文学的《红楼梦》、《三国演义》、《水浒传》、《金瓶梅》全由库恩翻译成德文,
  • 非对称关系 上的关系 是非对称的,若对所有的 和 属于 ,若 关系到 ,则 不关系到 。数学上表示为:非对称关系即反对称的非自反关系。反对称关系
  • 加的斯远征1625年的远征加的斯是英国与荷兰对西班牙发起的海上远征。在1625年议会被解散后,白金汉公爵,时任海军大臣,计划以牙还牙,以雪无敌舰队入侵英国之耻,故计划被推前。白金汉公爵携查
  • 常挺常挺(13世纪-1268年),字方叔,号东轩,福州连江县(今福建省连江县)人。南宋大臣,宋度宗时参知政事。宋理宗嘉熙二年(1238年)中进士,初任太学录。淳祐七年(1247年),召试馆职,担任秘书省正字,为母