Go 使用 RabbitMQ---------------之一

RabbitMQ 是一种消息代理。消息代理的主要目的是接收、存储并转发消息。在复杂的系统设计和微服务架构中,RabbitMQ 经常被用作中间件来处理和转发系统之间的消息,以确保数据的一致性和可靠性。正是因为提供了可靠的消息机制、跟踪机制和灵活的消息路由,常常被用于排队算法、秒杀活动、消息分发、异步处理、耗时任务等场景。

一、Go RabbitMQ 客户端&服务端 

1、代码结构

2、生产者发送消息

1). 初始化连接 rabbitmq 服务器

2). 创建 rabbitmq  通道

3). 声明队列,队列名为 go_hello,供我们发送消息

4)、交换机为默认交换机

5). 往队列里发送消息

创建 send.go 文件,通过 amqp091-go 库,将消息写入到 go_hello 这个队列 

package mainimport ("context"amqp "github.com/rabbitmq/amqp091-go""log""time"
)// 将消息写入到 go_hello 这个队列
func main() {// 1. 初始化连接(amqp://账号:密码@地址:端口默认为5672/")conn, err := amqp.Dial("amqp://guest:guest@localhost:5672/")failOnError(err, "无法连接到RabbitMQ")defer conn.Close()// 2. 创建通道ch, err := conn.Channel()failOnError(err, "无法创建通道")defer ch.Close()/*QueueDeclare声明一个队列,用于保存消息并传递给使用者。如果队列不存在,则声明会创建一个队列,或者确保现有队列匹配相同的参数。声明的每个队列都获得到空交换机“”的默认绑定,该交换机具有与队列名称匹配的路由,关键字的类型“direct”。有了这个默认绑定,可以发布直接路由到的消息,通过使用队列名称的路由关键字发布到“”来创建此队列。*/// 3. 声明队列q, err := ch.QueueDeclare("go_hello", // 队列名称false,      // 指定队列是否是持久的。如果设置为 true,则队列在服务器重启后仍然存在,消息也不会丢失。设置为 false 意味着队列是非持久的,服务器重启时队列将被删除,并且队列中的消息也会丢失。false,      // 指定当没有消费者连接到队列时,队列是否应该被自动删除。如果设置为 true,当最后一个消费者断开连接时,队列将被删除。false,      // 指定队列是否是排他的。如果设置为 true,则队列只能被声明它的连接使用,并且当连接关闭时,队列将被自动删除。false,      // 指定是否应该在声明队列时阻塞等待队列被成功创建。如果设置为 true,则函数将立即返回,不会等待队列被创建。nil,        // 可选的参数,可以传递给队列以控制其行为。在这个例子中,没有传递任何参数,所以它是 nil。)failOnError(err, "无法声明队列")// 4. 发送消息ctx, cancel := context.WithTimeout(context.Background(), 5*time.Second)defer cancel()body := "Hello World!"err = ch.PublishWithContext(ctx,"",     // 交换机的名称。在这个例子中,空字符串表示使用默认的交换机。交换机是 AMQP 中的一个组件,它接收消息并根据路由键将消息路由到一个或多个队列。q.Name, // 路由键,用于指定消息应该发送到哪个队列。在这个例子中,路由键是之前声明的队列的名称。false,  // 指定是否需要服务器确认消息的路由。如果设置为 true,则如果消息不能被路由到任何队列,服务器将返回一个错误。false,  // 指定是否需要服务器立即将消息路由给消费者。如果设置为 true,则如果队列上没有消费者,服务器将返回一个错误。amqp.Publishing{ContentType: "text/plain",Body:        []byte(body),})failOnError(err, "无法发布消息")log.Printf("生产者发送了消息:%s\n", body)
}func failOnError(err error, msg string) {if err != nil {log.Panicf("%s: %s", msg, err)}
}

 

3、消费者接收消息

创建 receive.go 文件,监听来自 RabbitMQ 的消息

package mainimport (amqp "github.com/rabbitmq/amqp091-go""log"
)func main() {// 1. 初始化连接conn, err := amqp.Dial("amqp://guest:guest@localhost:5672/")failOnError(err, "无法连接到RabbitMQ")defer conn.Close()// 2. 创建通道ch, err := conn.Channel()failOnError(err, "无法创建通道")defer ch.Close()// 3. 声明队列q, err := ch.QueueDeclare("go_hello", // namefalse,      // durablefalse,      // delete when unusedfalse,      // exclusivefalse,      // no-waitnil,        // arguments)failOnError(err, "无法声明队列")// 4. 构造消费者实例msgs, err := ch.Consume(q.Name, // 消费消息的队列的名称"",     // 消费者的标识符。在这个例子中,空字符串表示没有特定的消费者标识符true,   // 指定是否自动确认消息。如果设置为 true,则消息在被接收后会自动被确认,不需要显式调用确认方法。如果设置为 false,则需要手动确认每条消息。false,  // 指定消费者是否是排他的。如果设置为 true,则队列只能被这个消费者使用,并且当消费者断开连接时,队列将被删除。false,  // 指定是否将消息路由给与消息发布者在同一台服务器上的消费者。如果设置为 true,则不会将消息路由给本地消费者。false,  // 指定是否应该在声明消费者时阻塞等待消费者被成功创建。如果设置为 true,则函数将立即返回,不会等待消费者被创建。nil,    // 可选的参数,可以传递给消费者以控制其行为。在这个例子中,没有传递任何参数,所以它是 nil。)failOnError(err, "注册消费者失败")var forever chan struct{}go func() {for d := range msgs {log.Printf("收到消息: %s", d.Body)log.Printf("正在等待消息。要退出,请按CTRL+C")}}()log.Printf("正在等待消息。要退出,请按CTRL+C")<-forever
}func failOnError(err error, msg string) {if err != nil {log.Panicf("%s: %s", msg, err)}
}

 

二、工作队列 

工作队列:又名任务队列,其背后的主要思想是避免立即执行资源密集型任务并必须等待其完成。相反,我们将任务安排在以后完成。使用工作队列的好处就是它能够并行的处理队列,如果堆积了很多任务,我们只需要添加更多的工作者(workers)就可以了。 

1、代码结构

 仅供参考:

2、生产者 

package mainimport ("context"amqp "github.com/rabbitmq/amqp091-go""log""os""strings""time"
)func main() {// 1. 初始化连接conn, err := amqp.Dial("amqp://guest:guest@localhost:5672/")failOnError(err, "无法连接到RabbitMQ")defer conn.Close()// 2. 创建通道ch, err := conn.Channel()failOnError(err, "无法创建通道")defer ch.Close()// 3. 声明队列q, err := ch.QueueDeclare("task_queue", // nametrue,         // durablefalse,        // d

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

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

相关文章

MFC里的工具栏按钮图标如何使用外部图片?

&#x1f3c6;本文收录于「Bug调优」专栏&#xff0c;主要记录项目实战过程中的Bug之前因后果及提供真实有效的解决方案&#xff0c;希望能够助你一臂之力&#xff0c;帮你早日登顶实现财富自由&#x1f680;&#xff1b;同时&#xff0c;欢迎大家关注&&收藏&&…

据库管理-第196期 实战RDMA(20240528)

数据库管理196期 2024-05-28 数据库管理-第196期 实战RDMA&#xff08;20240528&#xff09;1 环境2 操作系统配置3 配置NVMe over RDMA4 挂载磁盘处理并挂载磁盘&#xff1a; 5 RDMA性能测试6 iSCSI部署7 iSCSI性能测试8 性能对比总结 数据库管理-第196期 实战RDMA&#xff08…

Transformer 从attention到grouped query attention (GQA)

Attention原理和理解 attention原理参考&#xff1a; Attention Is All You Need The Illustrated Transformer – Jay Alammar – Visualizing machine learning one concept at a time. Transformer图解 - 李理的博客 Attention首先对输入x张量乘以WQ, WK, WV得到query,…

软件程序设计规范(代码编写规范文档)-word下载

程序的编码是一个创造性极强的工作&#xff0c;必须要遵守一定的规则和限制&#xff0c;编码风格的重要性对软件项目开发来说是不言而喻的。 开发工程师在开发过程中必须遵守本规范&#xff0c;规范是代码编写及代码验收等管理环节中必须执行的标准。 编制基本原则&#xff1a;…

169. 多数元素

题目 解答 方法一&#xff1a;Boyer-Moore 投票算法 class Solution {func majorityElement(_ nums: [Int]) -> Int {var candidate 0var count 0for num in nums {if count 0 {candidate numcount 1} else {if candidate num {count 1} else {count - 1}}}return …

计算机毕业设计hadoop+spark+hive物流大数据分析平台 物流预测系统 物流信息爬虫 物流大数据 机器学习 深度学习

流程&#xff1a; 1.Python爬虫采集物流数据等存入mysql和.csv文件&#xff1b; 2.使用pandasnumpy或者MapReduce对上面的数据集进行数据清洗生成最终上传到hdfs&#xff1b; 3.使用hive数据仓库完成建库建表导入.csv数据集&#xff1b; 4.使用hive之hive_sql进行离线计算&…

webserver服务器从零搭建到上线(九)|⭐️EventLoop类(一)——详解成员变量、简述成员方法

在本节中&#xff0c;我们一起来仔细探讨一下EpollPoller类。该类可以说是muduo库中最最核心的类了&#xff0c;一定要搞懂&#xff01; 文章目录 私有成员using ChannelList std::vector<Channel*>looping_、quit_threadId_pollReturnTime_、poller_wakeup_fd、wakeupC…

一种基于单片机的智能饮水机设计

随着人们生活水平的提高&#xff0c;对美好生活质量的追求也越来越高。饮 水机是人们日常生活不可或缺的&#xff0c;实现饮水机的智能化控制不但方便&#xff0c; 而且更加安全。本文提出一种基于单片机的智能饮水控制系统&#xff0c;通过传 感器实现对水温的监测&#xff0c…

Redis(十四) 主从模式

文章目录 前言什么是分布式系统主从模式实现Redis主从模式主从模式原理nagle 算法拓扑结构主从模式实现的过程psync实时复制 前言 Redis 作为在内存中操作数据的服务器系统&#xff0c;每时都会接收成千上万的请求&#xff0c;如果我们的业务只在单个服务器上面部署了 Redis&a…

Android环境下Mesa初始化流程重学习之eglInitialize

Mesa初始化流程重学习之eglInitialize 引言 说来也惭愧&#xff0c;Mesa搞了这么久了&#xff0c;每次都想深入下&#xff0c;可是每次都是浅尝辄止了。这次趁着有了一定的闲暇时间并且有了调试景嘉微显卡的机会&#xff0c;还是想重新学习下&#xff0c;深入研究下&#xff0…

常见排序算法之插入排序

目录 一、直接插入排序 1.1 什么是插入排序 1.2 代码思路 1.3 C语言源码 二、希尔排序 2.0 插入排序的弊端 2.1 什么是希尔排序&#xff1f; 2.2 排序思路 2.3 C语言源码 一、直接插入排序 1.1 什么是插入排序 插入排序是一种简单直观的排序算法&#xff0c;它通过构…

LCD屏入门(基于ESP32)

主要参考资料&#xff1a; B站【乐鑫全球开发者大会】DevCon23 #17 &#xff5c;HMI 智能屏解决方案 目录 1.LCD屏幕硬件层2.LVGL驱动层 1.LCD屏幕硬件层 MCU常用的驱动接口在下面&#xff0c;大致可以划分为串口屏和并口屏。 串口屏相较于并行屏优势是占用IO少&#xff0c;相…

【oracle】Oracle RAC中的GNS到底是什么?

本文为云贝教育 刘峰 原创&#xff0c;请尊重知识产权&#xff0c;转发请注明出处&#xff0c;不接受任何抄袭、演绎和未经注明出处的转载 一、概述 Oracle Grid Naming Service (GNS) 是Oracle Grid Infrastructure的一个重要组件&#xff0c;它提供了一种集中式的命名服务&…

[机缘参悟-191] - 《道家-水木然人间清醒1》读书笔记 -14- 关系界限 - 经济和人格上的独立,走向成熟的必经之路,才能更好的谈其他情感(IT)

目录 前言&#xff1a; 1、“友善的孤独者” 2、“外向的孤独者” 3、道不同不相为谋 4、警惕依赖 5、完整独立的个体 6、不必纠正他人的错误&#xff0c;除非他影响了你 7、不再期待别人能理解自己&#xff0c;只有高维向下兼容你的人才能理解你 8、只有高维和同频的…

ChatGPT魔法,定制个性化提示词!

扮演Prompt创作者的角色 我想让你成为我的Prompt创作者。你的目标是帮助我创建最佳的Prompt&#xff0c;这个Prompt将由 你ChatGPT使用。 你将遵循以下过程&#xff1a; 1.首先&#xff0c;你会问我Prompt是关于什么的。我会告诉你&#xff0c;但我们需要通过不断的重复来改进…

jQuery下载教程

官网&#xff1a;https://jquery.com/ ** ** 点击为压缩版本 将网站打开 界面上邮件保存为js文件即可 在html文件中引入即可 <html> <head></head> <body><script src"./js/jquery-3.6.3.js"> </script> </body> <…

JDK9-21新特性概览(持续更新)

JDK9-21新特性概览 一、JDK9新特性1.1 JEP 102: Process API Updates简介案例风险 1.2 JEP 193: Variable Handles简介案例风险 1.3 JEP 200: The Modular JDK简介案例风险 1.4 JEP 213: Milling Project Coin简介案例1.1 try-with-resources增强1.2 接口中私有方法 1.5 JEP 22…

SpringBoot实现接口防抖的几种方案,杜绝重复提交

插&#xff1a; AI时代&#xff0c;程序员或多或少要了解些人工智能&#xff0c;前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;忍不住分享一下给大家(前言 – 人工智能教程 ) 坚持不懈&#xff0c;越努力越幸运&#xff0c;大家…

RK3568平台(camera篇)V4L2查询获取设置设备

一.查询设备能力VIDIOC_QUERYCAP struct v4l2_capability cap; ioctl(fd, VIDIOC_QUERYCAP, &cap) struct v4l2_capability 结构体描述了视频采集设备的 driver 信息。 struct v4l2_capability { __u8 driver[16]; // 驱动名字 __u8 card[32]; // 设备名字 __u8 bus_inf…

详解makefile中的foreach

在 Makefile 中&#xff0c;foreach 函数用于迭代处理一个以空格分隔的列表&#xff0c;并针对列表中的每个元素执行相同的操作。这个函数通常用于循环处理一组变量或文件名&#xff0c;并执行相同的规则或命令。 语法&#xff1a; makefile Copy Code $(foreach var, list, …