`
情情说
  • 浏览: 39055 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

RabbitMQ实战:消息通信模式和最佳实践

 
阅读更多

 

本系列是「RabbitMQ实战:高效部署分布式消息队列」书籍的总结笔记。

关注我的微信公众号:情情说,分享工作、学习和生活 ~

通过前2篇的介绍,了解了消息通信的主要元素和交互过程,以及如何运行和管理RabbitMQ,这篇将站在开发模式的角度理解「面向消息通信」带来的好处,以及在各种场景下的最佳实践。

通过介绍,你会了解到:

  • 面向消息通信的好处
  • 发后即忘模型
  • 用RabbitMQ实现RPC

面向消息通信的好处

主要从异步状态思维、处理能力扩展性、集成复杂度方面,说明面向消息通信的好处。

异步状态思维

当将消息通信集成到应用程序时,开发模式将从同步模型变为异步模型,RabbitMQ提供了不同的方法,允许我们在一处发送请求,在另一处进行处理,这样同步程序可以继续执行其他逻辑。

举个简单的例子来说明,通过支付宝还信用卡:

  • 用户填写信用卡号、发卡银行、持卡人姓名、还款金额,提交还款申请;
  • 支付宝会立即提示用户,申请已提交,多少小时内完成还款;
  • 还款完成后,会推送给用户一条消息,提醒还款是否成功;

如果是同步请求,用户需要等待几个小时查看结果,等待过程中不能进行其他操作,这是很不合理的。

异步的思维是将请求和处理分离,在应用中紧密耦合的两部分中间使用RabbitMQ,请求解析后,发送一条业务能够理解的消息到RabbitMQ,就返回给用户,真正的处理由另外的服务异步处理。

扩展性

随着业务的扩展,对服务处理能力的要求越来越高,RabbitMQ可以很简单的增加处理能力。

因为RabbitMQ可以将请求在处理服务器间平均地分发,不需要负载均衡器了。

零成本API

系统间相互调用,需要约定一套API,通常来讲,需要花费一点点时间,编写一大段代码将传入的HTTP请求转化为应用程序中的函数调用。

如果使用AMQP来连接应用程序的各个部分,无需额外定义API,使用消息通信即可。另外, AMQP是语言无关的,拥有数十种语言的本地语言绑定。

发后即忘模型

当考虑消息通信能够解决的问题类型时,消息通信适用的主要领域是的「发后即忘」处理模式。关心的是任务将会完成,但无须实时完成,创建一个任务,发送到交换器上后,就可以返回继续工作,甚至都不需要通知用户任务已经完成。

匹配该模式的两种类型任务:

  • 批处理:针对大型数据集合的工作或者转换,多个任务对数据集合的独立部分进行操作;
  • 通知:对发送事件的描述,可以是消息的日志,或者通知另一个程序或者管理员;

书上介绍的实例比较简单,就不在此列出了,主要是根据不同的场景,确定交换器的类型和routingkey,可以参考上一篇介绍的「收集日志」的例子进行理解。

用RabbitMQ实现RPC

有多种方式来实现远程过程调用RPC,比如REST API、SOAP、Thrift等,这些传统的RPC实现方法有共同之处:客户端和服务器紧密相连、而且要等待返回结果。另外考虑这些问题:

  • 当有多个服务节点时,客户端如何发现对应服务器;
  • 如果客户端连接的RPC服务器崩溃了,客户端需要额外逻辑进行重连;

通过MQ服务器来实现时,只是简单地发布消息而已,将消息路由到合适的地方放,通过多台RPC服务器对消息进行负载均衡,当处理消息的服务器崩溃时,将RPC消息重发到另一台。

现在的问题在于,如果将应答返回给客户端?

RabbitMQ使用消息来发回应答,在AMQP消息头里有一个字段叫做reply_to,消息的生成者可以通过该字段来确定队列名称,并监听队列等待应答,消息接收者能够检查reply_to字段,并创建包含应答内容的新的消息,并以队列名称作为路由键。

关于reply_to的队列名称,如果生成者声明了没有名字的队列,RabbitMQ为自动生成一个唯一的队列名,同时在声明的时候指定exclusive参数,确保只有创建队列的生产者可以读取队列上的消息。

这样,所有RPC客户端要做的,就是声明临时的、排他的、匿名队列,并将该队列名称包含到RPC消息的reply_to头中,这样服务器端就知道应答消息该发往哪儿了。

很多场景使用「发后即忘」模型,不需要处理者响应,如果需要响应,可以使用RabbitMQ的RPC模型。

下一篇将介绍RabbitMQ集群和高可用性以及它们的设置。

欢迎扫描下方二维码,关注我的个人微信公众号 ~

 


情情说

 

 

0
0
分享到:
评论

相关推荐

    RabbitMQ实战:高效部署分布式消息队列

    9. **错误处理与异常恢复**:书中会讲解如何设计健壮的错误处理机制,包括死信队列的使用、异常重试和消息确认机制。 10. **安全与最佳实践**:介绍RabbitMQ的安全策略,包括SSL/TLS加密、用户认证与授权,以及部署...

    RabbitMQ实战 高效部署分布式消息队列pdf

    **RabbitMQ实战:高效部署分布式消息队列** 在当今的IT行业中,分布式系统和微服务架构变得越来越普遍,而消息队列作为这些系统中的重要组件,承担着数据同步、异步处理、解耦和负载均衡等关键任务。RabbitMQ,作为...

    RabbitMQ实战 高效部署分布式消息队列.pdf

    《RabbitMQ实战:高效部署分布式消息队列》是一本深度探讨RabbitMQ技术的书籍,旨在帮助读者理解和掌握如何在实际项目中高效地部署和使用这个强大的分布式消息队列系统。RabbitMQ是一个开源的消息代理和队列服务器,...

    RabbitMQ实战 高效部署分布式消息队列

    《RabbitMQ实战:高效部署分布式消息队列》是一本深度解析RabbitMQ技术的书籍,旨在帮助读者理解和掌握如何在分布式系统中有效地利用消息队列。RabbitMQ作为一款广泛应用的消息中间件,其核心功能在于提供可靠的异步...

    RabbitMQ实战视频.zip

    在这个“RabbitMQ实战视频”压缩包中,你将找到一系列关于RabbitMQ的实战教程,包括视频讲解、源代码示例以及相关的文档资料,帮助你深入理解和应用这个强大的工具。 1. **消息队列基础**:了解消息队列的基本概念...

    rabbitmq实战-rabbitmq-action.zip

    五、最佳实践与运维 5.1 监控与日志:使用RabbitMQ管理界面、Prometheus、Grafana等工具监控系统状态和性能。 5.2 性能优化:调整内存、磁盘、网络等参数,提升RabbitMQ性能。 5.3 安全性:设置访问控制、加密通信...

    RabbitMQ实战++高效部署分布式消息队列

    **RabbitMQ实战:高效部署分布式消息队列** 在当今的互联网应用开发中,分布式系统已经成为常态,而消息队列(Message Queue)作为其中的关键组件,对于系统的解耦、异步处理以及容错能力的提升起到了重要作用。...

    RabbitMQ实战-RabbitMQInAction.zip

    **正文** RabbitMQ是一种广泛使用的开源消息代理和队列服务器...此外,这份资料可能还会涵盖如何监控RabbitMQ性能,以及处理常见问题和最佳实践。对于想要精通RabbitMQ的IT从业者来说,这是一份非常有价值的参考资料。

    rabbitmq 实战练习-rabbitmq-actual.zip

    RabbitMQ是一个开源的消息代理和队列服务器,它在分布式系统中被广泛使用,用于处理异步任务、消息通信和工作队列。本实战练习将深入探讨RabbitMQ的核心概念和实际应用,帮助你掌握其核心功能。 1. **RabbitMQ基本...

    《RabbitMQ实战指南》知识点总结-RabbitMQ-Demo.zip

    - **持久化**: 队列和消息可以设置为持久化,防止服务器重启时丢失数据。 - **公平分发**: 当多个消费者同时工作时,消息按顺序公平分配。 - **死信队列**: 错误消息或无法路由的消息会被发送到死信队列,便于...

    动力RabbitMQ实战视频教程-视频课程资源网盘链接提取码下载 .txt

    ### 动力RabbitMQ实战视频教程知识点概览 #### 一、RabbitMQ基础知识 1. **消息队列的概念**: - 消息队列是一种应用程序间通信的模式,它通过在发送者和接收者之间传递消息来实现解耦。 - RabbitMQ是一种开源的...

    rabbitmq学习笔记和软件和插件

    此外,官方文档也是深入理解RabbitMQ功能和特性的关键资源,包括了详细的API参考、插件介绍以及最佳实践。 **五、RabbitMQ插件** RabbitMQ提供了丰富的插件以增强其功能: 1. **Management Plugin**:提供了一个...

    demo-rabbitmq.rar

    同时,示例代码也是学习RabbitMQ API和最佳实践的好材料。 总结,"demo-rabbitmq.rar"提供了丰富的RabbitMQ实战案例,帮助我们掌握RabbitMQ的核心概念和工作模式。无论是初学者还是有经验的开发者,都能从中受益,...

    分布式消息中间件实践_倪炜(著)

    通过阅读《分布式消息中间件实践_倪炜(著)》,读者将能够深入理解这四种消息中间件的内部原理、配置方法、使用技巧以及最佳实践,从而更好地应对分布式环境下的各种挑战。这本书是IT从业者提升专业技能、优化系统...

    rabbitMQ代码案例

    1. **可编辑-商谈PPT.pptx**:这可能是一个关于RabbitMQ商业应用的演示文稿,详细介绍了RabbitMQ在业务场景中的使用策略和最佳实践,对于理解RabbitMQ如何助力企业提升效率和灵活性具有指导意义。 2. **rabbitMQ**:...

    rabbitmq学习书籍

    5. **最佳实践**:结合实际场景,学习如何设计合理的消息传递模型,提高系统的可靠性和性能。 通过以上几个方面的深入学习,相信您可以掌握RabbitMQ的核心技术和应用技巧,为您的项目开发提供强大的支持。

    rabbitmq面试题.pdf

    RabbitMQ的安全最佳实践包括哪些?** - **限制网络访问:** 仅允许信任的IP地址连接。 - **使用强密码:** 增加账户安全性。 - **启用TLS/SSL:** 保护通信安全。 **41. 如何在RabbitMQ中实现用户认证和授权?** ...

    rabbitmq面试题.zip

    **RabbitMQ基础** ...以上只是RabbitMQ面试中可能会涉及的部分知识点,实际面试可能会更深入探讨RabbitMQ在具体项目中的应用、问题解决以及最佳实践。熟悉这些内容能帮助你在面试中展现出对RabbitMQ的深入理解。

    rabbitmq+PHP教程代码.rar

    `course1`至`course6`的课程可能逐级递进,涵盖更复杂的使用场景和最佳实践,如故障恢复、负载均衡和监控等。 总的来说,这份"rabbitmq+PHP教程代码"提供了一个全面的学习路径,适合初学者和有一定经验的开发者,...

Global site tag (gtag.js) - Google Analytics