范文健康探索娱乐情感热点
投稿投诉
热点动态
科技财经
情感日志
励志美文
娱乐时尚
游戏搞笑
探索旅游
历史星座
健康养生
美丽育儿
范文作文
教案论文
国学影视

AMQP协议介绍

  这篇文章主要介绍AMQP 0-9-1 协议,是RabbitMQ支持的协议之一,理解AQMP对于使用和理解RabbitMQ也很有帮助。
  AMQP 0-9-1(高级消息队列协议)是一种消息传递协议,它使客户端应用程序能与消息中间件进行通信。消息中间件接收Producer的消息,并将消息路由到Queue,Consumer订阅Queue,就能消费到消息。从AMQP 0-9-1 模型看,Producer发布消息到Exchange(交换器),Exchange根据绑定规则,将消息路由到一个或多个Queue。消息中间件把消息推送给订阅该Queue的Consumer,或者由Consumer从Queue上拉取消息。
  下图直观的展示了AMQP 0-9-1 协议中的角色和消息主要流转过程,其中Exchange、Bindings、Qeue是AMQP 0-9-1的主要实体。
  Exchange
  AMQP 0-9-1 定义了Exchange,用来把消息路由到Queue,路由算法依赖 Binding Rule 和 Exchange 类型,AMQP 0-9-1 提供了4种Exchange类型。
  Exchange type
  默认的预定义的名字
  Direct exchange
  (Empty string) and amq.direct
  Fanout exchange
  amq.fanout
  Topic exchange
  amq.topic
  Headers exchange
  amq.match (and amq.headers in RabbitMQ) Default Exchange
  默认的Exchange是没有名字的,它是一种特殊的Direct Exchange。所有的Queue创建完,如果没有手动设置绑定关系,自动绑定到默认的Exchange,Routing Key 和 Queue 名字相同。 Direct Exchange
  Direct Exchange 要求发布消息时设置的Routing Key 必须与 Binding Key 一致,才能路由到Queue。它常用的场景是分发消息,根据Routing Key,把消息分发给不同的Consumer。 Fanout Exchange
  Fanout Exchange忽略Binding Key,会把消息路由给所有与它绑定的Queues,类似于广播消息。 Topic Exchange
  Topic Exchange是一种比较灵活的Exchange,采用模式匹配的方式路由消息,具体的模式匹配规则由各个消息中间件实现。 RabbitMQ的实现规则在下一篇文章中更新,小伙伴慢记得关注哦。 Headers Exchange
  Headers Exchange根据消息的属性来路由消息,比如设置绑定的属性是x-product=product1,那么只有消息上有x-product=product1这个属性值时才会路由到队列。 Bindings
  Bindings是Exchange和Queue绑定的具体规则,Exchange就是根据这个Bindings路由消息到Queue的。发布消息时的Routing Key必须和Binding Key匹配,消息才能正确路由到Queue。 Queue
  Queue是实际保存消息的地方,AMQP 0-9-1规定队列名字的长度不能超过255个字节。如果客户端没有指定队列名字,Broker会自动生成队列名字,不管是哪种方式,必须保证队列名字唯一。如果申明的队列已经在Broker存在,那么就会报403错误。 持久性
  AMPQ 0-9-1 规定,队列可以申明为持久化和非持久化的,持久化队列会保存到磁盘,包括它的元数据。非持久化的队列只是保存在内存中。 Consumer
  AQMP 0-9-1 规定消费者有两种方式消费消息: Consumer订阅,Broker推送消息给Consumer,这种方式也是推荐的一种实现。优点是获取消息实时,缺点是失去了对消息控制的灵活性,比如根据机器的性能决定一次消费多少消息。 Consumer拉取消息,优点是客户端可控性高,缺点是无法准确获知消息何时到达。 消息确认
  由于网络是不可靠的,当Broker推送消息给Consumer后,无法知道这条消息是否已经被Consumer接收并正确处理了,Broker也无法判断是否可以移除这条消息。所以AMQP 0-9-1 定义了消息确认机制,有两种不同的模式:在Broker发出消息之后,这种方式容易导致消息丢失。在应用程序返回ack之后。
  默认是自动确认,也支持手动确认,推荐使用手动确认,因为客户端程序可以自己控制在何时进行消息确认。拒绝消息
  消费者处理消息有可能失败,或者当前业务逻辑无法正确处理,就可以拒绝消息,此时,消息可能会被丢弃,也有可能重新入队,取决客户端的实现。注意,当队列只有一个订阅者,避免由于处理逻辑不当造成死循环。 批量拒绝消息
  消费者可以批量接受消息,如果这批消息都无法处理,或者都处理失败,可以批量拒绝消息。 消息接收数量
  当一个队列有多个消费者订阅时,定义每个消费在下一个ack之前能接收的最大消息数量,可以实现消息的负载均衡和提高吞吐量。 消息属性
  AMQP 0-9-1 规范定义消息有元数据和消息体,元数据就是消息的属性,比如: Content type Content encoding Routing key Delivery mode (persistent or not) Message priority Message publishing timestamp Expiration period Publisher application id
  消息体就是发送到队列的具体数据,以二进制格式发送,broker接收到消息,不会处理它,根据客户端的设置,保存到磁盘或者内存。 函数列表
  AMQP 0-9-1 定义了非常丰富的函数,比如跟exchange相关的如下: exchange.declare exchange.declare-ok exchange.delete exchange.delete-ok
  完整的函数定义请参考官方 手册:https://www.rabbitmq.com/amqp-0-9-1-reference.htmlConnection
  AMQP 0-9-1 规范定义了连接是建立在TCP的可靠性连接,并且是长连接。当一个客户端不需要连接Broker,AQMP 0-9-1 规范是应该关闭AMQP的连接,而不是底层的TCP连接。 Channel
  客户端有可能需要和Broker建立多个连接,那么就需要建立多个TCP连接,而这是很消耗资源和时间的。所以AMQP 0-9-1 规范定义了通道,通道是建立在连接之上的,一个连接可以有多个通道。客户端需要建立多个连接时,可以创建多个通道,每个通过都有唯一的ID。
  当连接关闭时,在这个连接之上的所有通过都会关闭。虚拟主机
  这里的虚拟主机的概念是AQMP 0-9-1 中定义的,在一个Broker中(可以理解为一个服务)创建多个环境,用于资源隔离,每个环境中都有各自的Exchange、Bindings、Queue、用户、元数据等等,环境之间资源不会共享。
  好了,以上就是关于AMQP 0-9-1 的介绍。
  RabbitMQ系列文章会陆续更新,欢迎各位小伙伴关注后面的技术分享。

晨起后吸烟会造成什么影响?提醒3个时间段,尽量别吸国家卫健委和世卫组织共同发布中国吸烟危害健康报告2020,报告显示,我国吸烟人数超3亿,15岁及以上人群吸烟率为26。6,其中男性吸烟率高达50。5。随着生活节奏的加快,人们的压力三种草,通淤堵!治子宫肌瘤囊肿甲状腺乳腺增生,事半功倍有三种草,通淤堵,活经络,于平凡处见真章,今天给大家一一介绍。第一种草威灵仙,辛咸,归膀胱经威灵仙到底是个啥?威灵仙其实就是一种入药的植物,有俗语说铁脚威灵仙,骨见软如棉,这句话主小麦的营养成分和健康益处,你了解多少?小麦是作为世界上最重要的粮食作物之一,被广泛应用于食物制造过程中,具有重要的经济和社会意义。小麦的营养成分和健康益处已被充分认识,是人们摄取均衡营养的重要来源。小麦的营养成分丰富,乳糖不耐症怎么喝牛奶?3大原因7招改善乳糖不耐症牛奶富含优质蛋白质和钙,是很多人早餐的标配。中国居民膳食指南(2022)推荐成人每天的奶量应该有300500ml。但有一部分人即使知道牛奶营养价值高,也不爱喝奶。因为他们一喝牛奶肚恋情曝光?郭艾伦和女星亲密互动,首钢名宿嘲讽周鹏,许钟豪踢裆球场上的表现虎虎生威,球场下面,郭艾伦是CBA商业价值最高的球员,没有之一,他的商业价值已经超过了大哥易建联,如今的郭艾伦可谓妥妥的人生赢家。不过郭艾伦这边也没有抵达完美的状态,比大洗牌!山东泰山5员老将冬窗或离队,签下2大新援加速球队年轻化如今的中超联赛到底有多么不景气?连山东泰山这样拥有大型国企背景的俱乐部,上个赛季都差一点就出现欠薪情况,就足以说明这个问题的严重性。好在,泰山俱乐部也在积极地进行新的股改,新东家入除夕前,梅西友谊赛迎C罗,球王拒绝沙特3亿年薪北京时间1月20日凌晨,C罗领衔的利雅得全明星队将迎战梅西姆巴佩内马尔领衔的巴黎圣日耳曼,由于恰逢除夕前夜,这场表演赛也赚足了中国球迷的眼球。据悉,比赛将在利雅得的法赫德国王体育场2023年F1赛历公布中国站遗憾无缘F1官方昨晚发布了确认版的2023赛季比赛安排,今年共包含23场大奖赛,此前盛传有望回归赛历的中国大奖赛遗憾无缘。图说中国站无缘2023F1新民晚报记者李铭珅摄资料图按照这份确认版最后的拼图!凯尔特人可能的选择Hi掌握篮板球,掌握命运。在此前1月12日于击败新奥尔良鹈鹕之后,凯尔特人成为本赛季联盟第一支取得常规赛30胜的球队,而截至目前,他们依旧保持着33胜12负的战绩,稳坐联盟战绩第一澳网兹维列夫晋级1月17日,兹维列夫在比赛后庆祝。当日,在澳大利亚墨尔本进行的澳大利亚网球公开赛男子单打首轮比赛中,德国选手兹维列夫以3比2战胜秘鲁选手巴里利亚斯,晋级下一轮。新华社记者郭磊摄1月名记今天将有球队解散!武汉或成今年首支解散的球队1月18日,李璇在其社交媒体上发文今天,中国足球的主题应该是解散和分别。不少球迷猜测,今天将有一支俱乐部宣布解散。而结合各方消息,这支解散的球队大概率将是已经降级的武汉长江队。记者
山西ampampquot巨虎ampampquot落马敛财9421万,包养歌手女演员,遭情妇举报判无期为了您更好的阅读互动体验,为了您及时看到更多内容,点个关注,我们每天为您更新精彩故事分享不一样的故事瞬间!卖地挣钱,一出戏,睡了一群女人。乔家大院的爆火,带红了一众演员,也让申维辰群演这份工作,究竟是一种什么样的体验?有综艺节目让明星在横店的剧组体验横漂工作,还有生活中300多名大学生素人,集体做群演参加电影拍摄,最近群演这份工作频繁登上热搜。之前电视剧梦华录热播时,也带火了一位面无表情目光呆滞法新社大量发射卫星造成严重光污染天文学家没法正常工作了中国小康网03月21日讯老马周一,天文学家警告说,绕地球运行的卫星数量激增造成的光污染对全球自然构成了前所未有的威胁。卫星划过夜空法新社报道,自2019年以来,低地球轨道上的卫星数我们希望乌克兰和平,但西方只在乎输赢据俄罗斯消息报网站3月21日报道,塞尔维亚总统亚历山大武契奇21日表示,塞尔维亚所希望的是乌克兰和平,而不是其中一方失败。报道称,他在同意大利副总理兼外长安东尼奥塔亚尼会谈后说我们红视频擎旗自有后来人纪念夏明翰烈士就义95周年视频加载中红网时刻通讯员曾凡珂记者蒋楠衡阳报道95年前,衡阳籍革命烈士夏明翰以生命赴使命,写下了砍头不要紧,只要主义真。杀了夏明翰,还有后来人这首共产党人的正气歌。深陷牢狱坚贞不屈狂飙后遗症还在继续,可留给张译一个最大遗憾,也是盖不住的最近,很多人患上了狂飙后遗症。这些人在追完狂飙后意犹未尽。有的去二刷三刷,有的去关注相关演员的动态,有的焦急等待下一部爆款剧。好在,我们没有等太久。很快,张译的新剧他是谁就上线了。她相貌平平演技一流,谈了16年师生恋坚持克丁,35岁生子被宠上天提起张龄心这个名字,很多人可能没印象,但她参演过许多大热电视剧,像琅琊榜我的前半生等都有她的身影,演技也被很多同行和前辈认可。只不过她本人却人气不高,典型的剧火人不火,而她似乎也不怀孕多久会有恶心想吐的感觉当受精卵着床到子宫壁上后,体内的激素水平开始发生变化,这可能导致孕妇出现一系列的早孕症状,其中包括恶心和呕吐。这些症状通常在怀孕的早期阶段出现,大约是怀孕6周的时候开始,但是也有些普通家庭你觉得怎么才算让孩子见过世面?经常能在网上看到有博主发的在孩子上幼儿园之前出去环游中国,给孩子增长见识,那么普通家庭怎么样才算让孩子见过世面呢?1911学堂好老师在线app周亚军老师认为这些不错,且方便践行的见自查!产后妈妈必做3大修复,你都做了吗去年徐州60岁的李阿姨,某天晚上跳广场舞时掉出一块肉,竟是子宫脱垂!看到这样的新闻,产后生完娃还纠结要不要做产后修复?不管是为了身体形态的优美,还是健康的生理,妈妈们,产后必做的3英达拒认儿子巴图20年,晚年突然改口挽救,暗藏私心还是真后悔?阅读文章前辛苦您点下关注,方便讨论和分享,为了回馈您的支持,我将每日更新优质内容。曾经对小儿子砸锅卖铁供养,对大儿子不管不顾,英达早已把巴图视为了弃子。可如今人到晚年,却又突然在节