监听Rabbitmq系统日志(python版)
介绍
rabbitmq默认有7个交换机,其中amq.rabbitmq.log为系统日志的交换机,这个日志为topic类型,会有三个等级的(routing_key)的日志发送到这个交换机上。
#!/usr/bin/env python # -*- coding: utf-8 -*- import pika # ########################### 订阅者 ########################### credentials = pika.PlainCredentials("用户名","密码") connection = pika.BlockingConnection(pika.ConnectionParameters( 'ip', 5672, '/', credentials=credentials)) channel = connection.channel() # 声明队列 channel.queue_declare(queue='info_queue',durable=True) channel.queue_declare(queue='error_queue',durable=True) channel.queue_declare(queue='warning_queue',durable=True) # 绑定 channel.queue_bind(exchange='amq.rabbitmq.log',queue="info_queue",routing_key="info") channel.queue_bind(exchange='amq.rabbitmq.log',queue="error_queue",routing_key="error") channel.queue_bind(exchange='amq.rabbitmq.log',queue="warning_queue",routing_key="warning") print(' [*] Waiting for logs. To exit press CTRL+C') def callback(ch, method, properties, body): print(" [x] %r" % body) print(" [x] Done") ch.basic_ack(delivery_tag=method.delivery_tag) channel.basic_consume("info_queue",callback,auto_ack=False) channel.basic_consume("error_queue",callback,auto_ack=False) channel.basic_consume("warning_queue",callback,auto_ack=False) channel.start_consuming() ''' 然后发布者只需要给exchange发送消息,然后exchange绑定的多个队列都有这个消息了。订阅者就收到这个消息了。 '''
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 三行代码完成国际化适配,妙~啊~
· .NET Core 中如何实现缓存的预热?