当前位置:首页 > 编程技术 > 正文内容

MQ消息队列使用场景及代码示例

yc8881个月前 (09-17)编程技术121

MQ消息队列使用场景及代码示例

在现代软件架构中,消息队列(Message Queue, MQ)扮演了至关重要的角色。消息队列能够解耦应用程序的不同部分,使得它们可以异步地进行通信,从而提高系统的可扩展性和可靠性。本文将介绍消息队列的几个典型使用场景,并提供相关的代码示例。

使用场景

  1. 异步处理消息队列常用于处理需要异步执行的任务。例如,用户提交订单后,系统需要处理订单、发送通知、更新库存等。通过将这些操作放入消息队列,应用可以立即响应用户,而这些任务会在后台异步处理。

  2. 负载均衡在高流量应用中,消息队列可以作为负载均衡器。通过将请求放入队列,多个消费者可以并行处理这些请求,从而避免了单一服务的瓶颈。

  3. 流量削峰消息队列可以帮助系统应对突发流量。例如,在电商促销活动中,用户请求可能会突然增加。通过将请求缓存在消息队列中,可以平滑处理这些请求,防止系统过载。

  4. 系统解耦在微服务架构中,不同服务之间的通信可以通过消息队列来实现,从而减少服务之间的耦合,提高系统的灵活性和可维护性。

代码示例

以下是一个基于 RabbitMQ 的消息队列使用示例,展示了如何使用 Python 的 pika 库进行消息的发送和接收。

发送消息

import pika
def send_message(queue_name, message):
    # 连接到 RabbitMQ 服务器
    connection = pika.BlockingConnection(pika.ConnectionParameters('localhost'))
    channel = connection.channel()
    # 声明一个队列
    channel.queue_declare(queue=queue_name, durable=True)
    # 发送消息
    channel.basic_publish(
        exchange='',
        routing_key=queue_name,
        body=message,
        properties=pika.BasicProperties(
            delivery_mode=2,  # 消息持久化
        )
    )
    print(f" [x] Sent '{message}'")
    connection.close()
# 发送一条消息
send_message('task_queue', 'Hello RabbitMQ!')


接收消息


import pika
def callback(ch, method, properties, body):
    print(f" [x] Received {body}")
    # 模拟处理任务
    import time
    time.sleep(body.count(b'.'))
    print(" [x] Done")
    ch.basic_ack(delivery_tag=method.delivery_tag)
def receive_messages(queue_name):
    # 连接到 RabbitMQ 服务器
    connection = pika.BlockingConnection(pika.ConnectionParameters('localhost'))
    channel = connection.channel()
    # 声明一个队列
    channel.queue_declare(queue=queue_name, durable=True)
    # 告诉 RabbitMQ 使用哪个回调函数处理消息
    channel.basic_consume(queue=queue_name, on_message_callback=callback)
    print(' [*] Waiting for messages. To exit press CTRL+C')
    channel.start_consuming()


# 开始接收消息

receive_messages('task_queue')

消息队列在现代应用中起到了重要的作用,通过实现异步处理、负载均衡、流量削峰和系统解耦,帮助开发者构建更加高效、稳定的系统。以上示例展示了如何使用 RabbitMQ 进行基本的消息发送和接收操作,希望对你了解消息队列的使用场景有所帮助。如果你对其他消息队列系统(如 Kafka、ActiveMQ 等)感兴趣,可以参考相关文档进行学习。

本站发布的内容若侵犯到您的权益,请邮件联系站长删除,我们将及时处理!


从您进入本站开始,已表示您已同意接受本站【免责声明】中的一切条款!


本站大部分下载资源收集于网络,不保证其完整性以及安全性,请下载后自行研究。


本站资源仅供学习和交流使用,版权归原作者所有,请勿商业运营、违法使用和传播!请在下载后24小时之内自觉删除。


若作商业用途,请购买正版,由于未及时购买和付费发生的侵权行为,使用者自行承担,概与本站无关。


本文链接:https://www.10zhan.com/biancheng/11513.html

分享给朋友:

“MQ消息队列使用场景及代码示例” 的相关文章

【说站】Thymeleaf报错Error resolving template “XXX”

【说站】Thymeleaf报错Error resolving template “XXX”

修改了一下开源项目的目录结构访问突然报错Error resolving template “XXX”可能原因有如下三种:第一种可能:原因:在使用springboot的过程中,如果使用thymeleaf...

【说站】Centos8.0如何配置静态IP详解及永久关闭防火墙

【说站】Centos8.0如何配置静态IP详解及永久关闭防火墙

这篇文章主要介绍了详解Centos8 配置静态IP的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来学习一下!1. 查看自己的网关地址点击虚...

【说站】利用Webhook实现Java项目自动化部署

【说站】利用Webhook实现Java项目自动化部署

用webhook就能实现Java项目自动部署,其实原理很简单。费话不多说,直接往下看教程。1. 创建gitee仓库并初始化2. 在linux安装git3. 在宝塔的软件的商店里下载Webhook4....

【说站】电脑安装MySQL时出现starting the server失败原因及解决方案

【说站】电脑安装MySQL时出现starting the server失败原因及解决方案

今天在安装MySQL时出现starting the server失败,经过查询分析得出以下结论,记录一下操作步骤。原因分析:如果电脑是第一次安装MySQL,一般不会出现这样的报错。如下图所示。star...

【说站】vagrant实现linux虚拟机的安装并配置网络

【说站】vagrant实现linux虚拟机的安装并配置网络

一、VirtualBox的下载和安装1、下载VirtualBox官网下载:https://www.virtualbox.org/wiki/Downloads我的电脑是Windows的,所以下载Wind...

【说站】Java从resources读取文件内容的方法有哪些

【说站】Java从resources读取文件内容的方法有哪些

本文主要介绍的是java读取resource目录下文件的方法,比如这是你的src目录的结构├── main│ ├── java│ │ └── ...