python--使用pika库操作rabbitmq实现需求

Author: wencoo
Blog:https://wencoo.blog.csdn.net/
Date: 22/04/2024
Email: jianwen056@aliyun.com
Wechat:wencoo824
QQ:1419440391
Details:

文章目录

  • 目录
    • 正文 或 背景
    • pika链接mq
    • pika指定消费数量
    • pika自动消费实现
    • pika获取队列任务数量
    • pika主动获取任务消费
    • 根据需求实现的完整示例代码
    • 参考
  • 技术交流
  • 音视频领域其他技术文章的链接
    • opengl相关文章
    • ffmpeg相关文章
      • ffmpeg原理相关文章
      • ffmpeg源码分析相关文章
      • ffmpeg指令相关文章
      • ffmpeg报错相关文章
    • libass相关文章
    • c/c++相关文章
    • linux相关文章
    • 其他文章
  • 后面都是一些废话,不用看,刷分的
    • 推广一个AI学习网站
    • 中国软件行业倡议书
    • 作者有话说
    • 关于内卷

在这里插入图片描述

目录

正文 或 背景

前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到网站。

有这样业务场景,算法部的同事有一个算法需要集成,有国内和国外两条链路,使用rabbitmq对应的试两个队列,但是他的算法只能开启一个实例,不能开两个进程,否则计算资源不足会崩溃(此处我想吐槽,做算法这帮人,工资又高,结果工程能力太差啦,所谓的算法也不过把github的开源库拿来改改参数,怎么好意思叫算法,搞不懂现在的中国互联网环境了),基于以上原因,需求则是需要在只开一个实力的情况下,消费两个队列里的任务。

由于算法模型都是python写的,所以要使用python来处理mq,python处理mq的驱动库是pika,下面来学习一下pika一些使用操作。

pika链接mq

import pika
import timecredentials = pika.PlainCredentials('admin', 'Hasx9527')
connection = pika.BlockingConnection(pika.ConnectionParameters(host = '180.184.35.67',port = 5672,virtual_host = '/',credentials = credentials))
channel = connection.channel()

pika指定消费数量

# 可选:指定消费者处理队列消息的数量
channel.basic_qos(prefetch_count=1)  # 实现消费者负载均衡,表示同时只能处理1条消息,待处理完成后在接收下一条消息

pika自动消费实现

def callback(ch, method, properties, body):ch.basic_ack(delivery_tag = method.delivery_tag)print(body.decode())time.sleep(10)# 可选:指定消费者处理队列消息的数量
channel.basic_qos(prefetch_count=1)  # 实现消费者负载均衡,表示同时只能处理1条消息,待处理完成后在接收下一条消息# 告诉rabbitmq,用callback来接收消息
channel.basic_consume('test.python.pika.1',callback)
# 开始接收信息,并进入阻塞状态,队列里有信息才会调用callback进行处理
channel.start_consuming()

pika获取队列任务数量

queue_info = channel.queue_declare(queue,passive=True)
message_count = queue_info.method.message_count
print(f"队列任务数量为:{message_count}")

pika主动获取任务消费

method_frame, header_frame, body = channel.basic_get(queue)
if method_frame:# print(method_frame, header_frame, body)  # 收到的全部数据  就要bodyprint(body)          # 是b'xxx'的格式channel.basic_ack(method_frame.delivery_tag)  #用自动应答 这个应该不要
else:print('消费单条 没有收到消息')

根据需求实现的完整示例代码

import pika
import timecredentials = pika.PlainCredentials('admin', 'Hasx9527')
connection = pika.BlockingConnection(pika.ConnectionParameters(host = '180.184.35.67',port = 5672,virtual_host = '/',credentials = credentials))
channel = connection.channel()queue1 = 'test.python.pika.1'
queue2 = 'test.python.pika.2'
def queueConsumer(queueName):while True:# 申明消息队列,消息在这个队列传递,如果不存在,则创建队列queue = queueNamechannel.queue_declare(queue , durable = True)# 可选:指定消费者处理队列消息的数量channel.basic_qos(prefetch_count=1)  # 实现消费者负载均衡,表示同时只能处理1条消息,待处理完成后在接收下一条消息method_frame, header_frame, body = channel.basic_get(queue)if method_frame:print(body)          # 是b'xxx'的格式time.sleep(10)channel.basic_ack(method_frame.delivery_tag)  #用自动应答 这个应该不要else:time.sleep(1)breakdef queueConsumer2(queueName,queueName2):while True:# 申明消息队列,消息在这个队列传递,如果不存在,则创建队列queue = queueName2channel.queue_declare(queue , durable = True)queue_info = channel.queue_declare(queueName,durable = True,passive=True)message_count = queue_info.method.message_countif message_count != 0:break# 可选:指定消费者处理队列消息的数量channel.basic_qos(prefetch_count=1)  # 实现消费者负载均衡,表示同时只能处理1条消息,待处理完成后在接收下一条消息method_frame, header_frame, body = channel.basic_get(queue)if method_frame:print(body)          # 是b'xxx'的格式time.sleep(10)channel.basic_ack(method_frame.delivery_tag)  #用自动应答 这个应该不要else:time.sleep(1)breakwhile True:print("开始运行队列1================\n")queueConsumer(queue1)print("开始运行队列2================\n")queueConsumer2(queue1,queue2)

参考

  • python pika 消费mq basic_get方法
  • python 操作RabbitMq详解
  • python对RabbitMQ的简单使用
  • Python三方库:Pika(RabbitMQ基础使用)

由于笔者的水平有限, 加之编写的同时还要参与开发工作,文中难免会出现一些错误或者不准确的地方,恳请读者批评指正。如果读者有任何宝贵意见,可以加我微信 wencoo824。QQ:1419440391。

技术交流

欢迎加微信,搜索"wencoo824",进行技术交流,备注”博客音视频技术交流“

音视频领域其他技术文章的链接

opengl相关文章

  • opengl日记7-ubuntu20.04开发环境opengl拓展glfw和glad环境搭建
  • opengl日记8-opengl创建三角形
  • opengl日记9-opengl使用纹理示例
  • opengl日记10-opengl使用多个纹理示例
  • opengl日记11-opengl的transformtions变换示例
  • opengl日记12-opengl坐标系统
  • opengl日记19-opengl文字渲染-教程示例
  • opengl日记23-opengl文字渲染-渐变色-教程示例
  • opengl日记25-opengl文字渲染-渲染中文渐变色动画-直线线性运动-教程示例
  • opengl日记26-opengl文字渲染-渲染中文渐变色动画-贝塞尔运动-教程示例
  • opengl日记27-opengl报错ERROR::SHADER::PROGRAM::LINKING_FAILED
  • opengl日记28-opengl之c语言版本的glm库cglm编译使用教程

ffmpeg相关文章

  • ffmpeg学习日记1-ffmpeg的基本介绍(相关概念理解,资料收集)

  • ffmpeg学习日记2-新建工程打印ffmpeg版本

  • ffmpeg学习日记3-视频格式和视频编码的关系

  • ffmpeg学习日记4-使用ffmpeg获取视频文件属性值

  • ffmpeg学习日记5-使用ffmpeg进行h264解码

  • ffmpeg学习日记8-YUV的几个知识点

  • ffmpeg学习日记11-使用ffmpeg将视频格式转换为视频编码h264格式

  • ffmpeg学习日记17-获取MP4视频流的帧率

  • ffmpeg学习日记19-判断AVPacket中的一帧数据是否为关键帧

  • ffmpeg学习日记21-缓存AVPacket数据

  • ffmpeg学习日记22-内存读取avio_alloc_context函数的内存释放问题

  • ffmpeg学习日记29-使用vscode调试ffmpeg源码

  • ffmpeg学习日记101-视频-MP4提取YUV数据,每一帧保存为pgm图片

  • ffmpeg学习日记121-视频-各种图片转yuv

  • ffmpeg学习日记122-视频-获取视频的解码器,yuv格式名称,理解编码格式,封装格式,yuv格式的关系

  • ffmpeg学习日记122-视频-获取视频的解码器,yuv格式名称,理解编码格式,封装格式,yuv格式的关系

  • ffmpeg日记1011-过滤器-语法高阶,逻辑,函数使用

ffmpeg原理相关文章

  • ffmpeg日记4001-原理介绍-视频切割原理

ffmpeg源码分析相关文章

  • ffmpeg学习日记501-源码-parse_loglevel()函数
  • ffmpeg学习日记502-源码-ffmpeg_parse_options()函数分析
  • ffmpeg学习日记503-源码-transcode()函数分析
  • ffmpeg学习日记504-源码-readme汉化
  • ffmpeg学习日记506-源码-av_image_copy()函数分析及功能
  • ffmpeg学习日记508-源码-ffmpeg --help 汉化
  • ffmpeg学习日记509-源码-从ffmpeg 源码提取编码的流程分析
  • ffmpeg学习日记512-源码-ubuntu20.04下源码编译
  • ffmpeg学习日记513-源码-configure_filtergraph()函数分析及功能

ffmpeg指令相关文章

  • ffmpeg学习日记601-指令-视频裁剪,添加bgm合成mp4
  • ffmpeg学习日记602-指令-转换视频的分辨率
  • ffmpeg学习日记603-指令-获取视频分辨率
  • ffmpeg学习日记604-指令-将视频格式转为H264格式
  • ffmpeg学习日记605-指令-获取视频的总帧数
  • ffmpeg学习日记606-指令-将视频转为全I帧
  • ffmpeg学习日记607-指令-将mp4视频转yuv
  • ffmpeg学习日记612-指令-转换视频格式
  • ffmpeg学习日记612-指令-转换视频格式
  • ffmpeg学习日记614-指令-获取文件时长
  • ffmpeg学习日记619-指令-透明通道视频相关指令

ffmpeg报错相关文章

  • ffmpeg学习日记701-报错-co located POCs unavailable
  • ffmpeg学习日记702-报错-包含‘PRId64‘的报错

libass相关文章

  • libass分析1-源码分析-起源-源码编译
  • libass分析2-源码分析-示例程序test.c的源码分析
  • libass分析3-源码分析-libass中的宏定义分析
  • libass分析5-源码分析-ASS_Track结构体分析,ass文件数据是如何存放的
  • libass分析6-源码分析-ASS_Renderer结构体分析,ass文件数据是如何存放的
  • libass分析8-源码分析-libass处理event中{}的逻辑

c/c++相关文章

  • c/c++专栏

linux相关文章

  • linux专栏

其他文章

  • docker-创建rabbitmq容器指令

后面都是一些废话,不用看,刷分的

推广一个AI学习网站

前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到网站。

中国软件行业倡议书

精简软件开发,电脑性能越来越好,打出的程序安装包越来越大,磁盘,内存越吃越多,这不是好现象,手机同理,大家觉得呢,欢迎发表看法,各抒己见。

手机app随意读取用户通讯录,就是流氓行为,即使有时候弹窗提示是否授权,选择了否,但是他其实还是悄悄读取你的通讯录,并且随便给你的通讯录好友发推广信息,这一点是非常反感的,并且也触犯了用户的权益,这不仅是流氓行为,更是违法行为,某软件就不说了。

作者有话说

个人简介:多年工作工程经验,擅长linux下软件开发,qt,ffmpeg音视频二次开发。

欢迎各位叨扰作者,如果有什么项目合作,创业合伙需要研发,网站推广,猎头服务,内推等等,尽管来联系,对于能挣钱的事,作者可是很感兴趣的哦。

关于内卷

劝大家一句,不要内卷,内卷只能害了别人,害了自己。

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/2044.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

JavaScript(二)

JavaScript的语法 1.JavaScript的大小写 在JavaScript中,大小写是敏感的,这意味着大小写不同的标识符被视为不同的变量或函数。例如,myVariable 和 myvariable 被视为两个不同的变量。因此,在编写JavaScript代码时,必…

如何在PostgreSQL中创建并使用窗口函数来进行复杂的分析查询?

文章目录 解决方案1. 了解窗口函数的基本概念2. 常用的窗口函数3. 使用示例示例 1:计算每行销售数据的累计销售额示例 2:计算每行销售数据相对于前一行销售额的增长率 结论 PostgreSQL 提供了一套强大的窗口函数(Window Functions&#xff09…

MQTT Broker 白皮书:全面实用的 MQTT Broker 选型指南

在智能数字化时代,家居设备、工厂传感器、智能汽车、能源电力计量表等各类设备都已变身为新型的智能终端。为了满足这些海量且持续增长的智能设备之间对于实时、可靠的消息传递的需求,MQTT Broker 消息代理或消息中间件扮演了至关重要的角色。作为新一代…

STM32H750外设ADC之模拟窗口看门狗

目录 概述 1 相关寄存器 2 功能描述 3 AWDx 标志和中断 4 模拟看门狗 1 4.1 模拟看门狗 1 说明 4.2 模拟看门狗通道选择 4.3 阀值选择 5 模拟看门狗 2和3 6 ADCx_AWDy_OUT 信号输出生成 6.1 功能介绍 6.2 输出信号案例 7 模拟看门狗 1、 2、 3 比较 概述 本文主…

Opencv_3_图像对象的创建与赋值

ColorInvert.h 如下&#xff1a; #include <opencv.hpp> using namespace std; #include <opencv.hpp> using namespace cv; using namespace std; class ColorInvert{ public : void mat_creation(); }; ColorInvert.cpp 文件如下&#xff1a; #include &q…

解决宝塔面板无法访问(无法访问或拒绝链接)

&#x1f40c;博主主页&#xff1a;&#x1f40c;​倔强的大蜗牛&#x1f40c;​ &#x1f4da;专栏分类&#xff1a;Linux ❤️感谢大家点赞&#x1f44d;收藏⭐评论✍️ 问题如下&#xff1a; 本人设置了授权IP&#xff0c;但是有些问题&#xff0c;所以是打算取消授权IP 重…

Spring Boot 自动装配执行流程

Spring Boot 自动装配执行流程 Spring Boot 自动装配执行流程如下&#xff1a; Spring Boot 启动时会创建一个 SpringApplication实例&#xff0c;该实例存储了应用相关信息&#xff0c;它负责启动并运行应用。实例化 SpringApplication 时&#xff0c;会自动装载META-INF/spr…

Linux文件chattr/lsattr/Linux权限(搭建权限测试环境实战)引申到内部原理及Linux删除系统文件原理-7539字详谈

企业高薪思维: 每一个阶段什么时候是最重要的&#xff1f;&#xff08;快速定位&#xff09; 1.学习最重要的事情 &#xff08;学生阶段&#xff0c;找工作前阶段&#xff09; 2.家庭&#xff0c;女朋友 &#xff08;工作阶段/学生阶段&#xff0c;学习不受到影响&#xff09; …

修改Ubuntu22.04系统图标

在Ubuntu 22.04中更改开机时显示的Ubuntu图标需要修改的设置。 主要思路是用自己图片替换系统图片&#xff0c;保持系统图片同名&#xff0c;同格式。 以下是一般的步骤&#xff1a; 修改启动界面的logo&#xff1a; sudo cp 新logo.png /usr/share/plymouth/themes/spinn…

@NameBinding注解名称绑定过滤器/拦截器

NameBinding注解名称绑定过滤器/拦截器&#xff0c;只针对某一些资源方法执行处理逻辑 一、为什么要用名称绑定 一般情况下&#xff0c;借助Spring的过滤器或者拦截器等对Http请求或响应进行处理就能满足需求。但是在有些场景下若只需对特定的xxxResource做拦截处理&#xff0…

项目大集成

一 keeplived 高可用 192.168.11.11nginx keeplived192.168.11.12nginx keeplived 两台均编译安装服务器 1 主服务器修改文件&#xff1a; 2 备服务器修改文本 scp keepalived.conf 192.168.11.12:/etc/keepalived/ 3 给主服务器添加虚拟ip ifconfig ens33:0 192.168…

【多态】底层原理

博主首页&#xff1a; 有趣的中国人 专栏首页&#xff1a; C进阶 本篇文章主要讲解 多态底层原理 的相关内容 1. 多态原理 1.1 虚函数表 先看一下这段代码&#xff0c;计算一下sizeof(Base)是多少&#xff1a; class Base { public:virtual void Func1(){cout << &quo…

Oracle 21 C 安装详细操作手册,并配置客户端连接

Oracle 21 C 安装详细操作手册 Win 11 Oracle 21C 下载&#xff1a; Database Software Downloads | Oracle 中国 云盘共享 链接&#xff1a;https://pan.baidu.com/s/12XCilnFYyLFnSVoU_ShaSA 提取码&#xff1a;nfwc Oracle 21C 配置与登陆&#xff1a; 开始菜单 NetMa…

Git下载安装

天行健&#xff0c;君子以自强不息&#xff1b;地势坤&#xff0c;君子以厚德载物。 每个人都有惰性&#xff0c;但不断学习是好好生活的根本&#xff0c;共勉&#xff01; 文章均为学习整理笔记&#xff0c;分享记录为主&#xff0c;如有错误请指正&#xff0c;共同学习进步。…

华为认证云计算前景如何

互联网/移动互联网经历了高速发展的二十年&#xff0c;我们有幸一起见证了华为、阿里、腾讯、百度、字节跳动、京东、滴滴、拼多多等互联网公司的崛起&#xff0c;让普通技术人实现逆袭拿到高薪&#xff0c;也让小镇做题家们有了阶层跨越的机会。 但机会都是留给有准备的人&…

C++:特殊成员函数

构造函数、析构函数和拷贝构造函数是C类中的三种特殊成员函数&#xff0c;它们分别用于对象的初始化、清理和拷贝操作。 1.构造函数&#xff08;Constructor&#xff09;&#xff1a;构造函数在对象创建时自动调用&#xff0c;用于初始化对象的成员变量。它的名称与类名相同&a…

React Router 6 + Ant Design:构建基于角色的动态路由和菜单

要根据用户的角色生成不同的路由菜单并实现权限控制,你可以采取以下步骤: 定义路由配置 首先,你需要定义一个包含所有可能路由的配置文件,例如: const routes [{path: /dashboard,element: <DashboardPage />,roles: [admin, manager, user]},{path: /users,element:…

Node.js 基础学习

文章目录 1. Node.js1.1 是什么&#xff1f;1.2 作用 2. 命令行工具2.1 命令的结构2.2 常用命令 3. Node.js 注意点3.1 Node.js 中不能使用DOM 和BOM 的API3.2 Node.js 中顶级对象叫做global 4. Buffer4.1 Buffer 特点4.2 Buffer 创建方式4.3 Buffer 操作与注意点 5. 计算机基础…

CSS基础:浮动(float)的3种方式,清除浮动3种方式的详解

你好&#xff0c;我是云桃桃。 一个希望帮助更多朋友快速入门 WEB 前端的程序媛。 云桃桃-大专生&#xff0c;一枚程序媛&#xff0c;感谢关注。回复 “前端基础题”&#xff0c;可免费获得前端基础 100 题汇总&#xff0c;回复 “前端工具”&#xff0c;可获取 Web 开发工具合…

【报错】ModuleNotFoundError: No module named ‘einops‘

1 报错 💔💔💔 ModuleNotFoundError: No module named einops 解决方法 💚 💚 💚 pip --default-timeout=100 install einops -i https://pypi.tuna.tsinghua.edu.cn/simple 问题解决啦!!!🌺🌺🌺 2 报错 💔💔💔 ModuleNotFoundError: No module