码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 消息队列 - RabbitMQ


    合集 - Golang学习(55)
    1.iota简介07-102.go generate命令简介07-113.golang uuid库介绍07-244.gRPC基本教程07-255.protolator简介07-316.Govulncheck v1.0.0 发布了!08-037.每日一库:GORM简介08-078.Go泛型简介08-099.Go 1.21发布!08-1010.Golang zip压缩文件读写操作2020-12-2311.本地搭建playground2021-01-1712.zap自定义日志级别02-0913.Gorm日志设置02-0914.gin启动https支持2022-11-3015.Go Plugin介绍2021-12-1416.Golang漏洞管理07-3017.可以丢掉123456了07-0418.如何优雅地退出程序06-2719.PGO前瞻06-2520.go多版本管理05-1621.openAI发布v0.2.0了05-1122.Gin中间件开发08-1123.Fabric区块链浏览器(1)08-1524.每日一库:Memcache08-1725.protojson简介08-1826.每日一库:gosec08-2127.Fabric区块链浏览器(2)08-2228.每日一库:fsnotify简介08-2629.gRPC with JWT08-2730.embed简介08-2931.Fabric区块链浏览器(3)08-3032.每日一库:pprof简介09-0133.go 1.21:cmp09-0234.完全可复制、经过验证的 Go 工具链09-0535.PGO in Go 1.2109-0936.Fabric 2.x 智能合约开发记录09-1037.为不断增长的Go生态系统扩展gopls09-1138.每日一库:lumberjack -- 日志轮换和管理09-1439.2023-04-26-微信安全模式下消息解析09-1440.WASI support in Go09-1541.每日一库:Prometheus09-1742.如何实现流量控制和熔断降级?09-18
    43.消息队列 - RabbitMQ09-19
    44.Go 1.22 中的 For 循环09-2245.设计模式之单例模式09-2346.每日一库:使用Viper处理Go应用程序的配置09-2547.使用 gopkg.in/yaml.v3 解析 YAML 数据09-2648.在Go中如何实现并发09-2849.解析类型参数10-0450.设计模式之工厂模式10-0651.每日一库:cobra 简介10-0752.slices in Go 1.2110-0853.go defer简介10-1354.slice简介10-2055.Golang Map底层实现简述10-22
    收起

    RabbitMQ简介

    RabbitMQ 是一个广泛使用的开源消息队列系统,它实现了高级消息队列协议(AMQP)标准,为分布式应用程序提供了强大的消息传递功能。RabbitMQ 是 Erlang 语言编写的,具有高度的可扩展性和可靠性,因此被广泛用于构建分布式、异步的消息通信系统。

    以下是关于 RabbitMQ 的详细介绍:

    1. 消息队列的概念

    消息队列是一种通信模式,用于在不同组件、服务或应用程序之间传递消息。它允许发送者将消息放入队列,而接收者可以从队列中获取消息,实现了解耦、异步通信和数据传递的目标。消息队列通常用于处理以下情况:

    • 异步通信:发送方和接收方之间不需要立即响应,提高了系统的可伸缩性和性能。
    • 任务排队:将需要处理的任务放入队列,由工作进程异步执行。
    • 解耦组件:允许不同的应用程序或服务之间进行松耦合的通信。

    2. RabbitMQ 的核心概念

    RabbitMQ 中的核心概念包括:

    • Producer(生产者):负责向消息队列发送消息的应用程序或服务。
    • Consumer(消费者):负责从消息队列接收和处理消息的应用程序或服务。
    • Queue(队列):用于存储消息的缓冲区,消费者从队列中获取消息进行处理。
    • Exchange(交换机):接收生产者发送的消息并将其路由到一个或多个队列。
    • Binding(绑定):定义了队列和交换机之间的关系,指定了如何将消息从交换机路由到队列。
    • Virtual Host(虚拟主机):RabbitMQ 允许将多个逻辑消息队列隔离到不同的虚拟主机中,以实现资源隔离和多租户支持。

    3. 工作流程

    RabbitMQ 的工作流程如下:

    • 生产者将消息发布到一个或多个交换机。
    • 交换机根据绑定规则将消息路由到一个或多个队列。
    • 消费者订阅队列并接收消息。
    • 消费者处理消息,并可以确认消息已被成功处理。
    • 消息可以持久化到磁盘,以确保在 RabbitMQ 重启后不会丢失。

    4. 消息确认和持久化

    RabbitMQ 具有高度的可靠性,它支持消息确认机制,确保消息在成功处理后才从队列中删除。如果消费者在处理消息时发生错误,消息将被重新排队,而不会丢失。此外,RabbitMQ 还支持将消息持久化到磁盘,以防止消息在系统故障时丢失。

    5. 可用性和扩展性

    RabbitMQ 具有高可用性和可伸缩性的特性。它支持镜像队列(Queue Mirroring)来确保队列数据的冗余备份,以提高可用性。此外,RabbitMQ 集群可以水平扩展,允许将多个节点添加到集群中以增加处理能力。

    6. 协议支持

    RabbitMQ 支持多种协议,包括 AMQP(高级消息队列协议)、STOMP、MQTT 等。这使得不同类型的应用程序可以与 RabbitMQ 进行通信,而无需修改现有代码。

    7. 应用场景

    RabbitMQ 可以应用于许多不同的场景,包括:

    • 分布式系统通信:用于不同组件或服务之间的消息传递。
    • 异步任务处理:将需要执行的任务放入队列,由工作者进行处理。
    • 日志和监控数据的收集:将日志和监控数据发送到 RabbitMQ,以进行集中处理和分析。
    • 微服务架构:支持微服务之间的异步通信

    在Golang中使用

    可以通过 github.com/rabbitmq/amqp091-go 包来在 Go 中与 RabbitMQ 进行交互,以下是一些基本步骤来连接到 RabbitMQ、发送消息和接收消息:

    1. 安装 RabbitMQ 客户端库

    首先,您需要使用 Go 的包管理工具安装 github.com/rabbitmq/amqp091-go 包,可以使用以下命令:

    go get github.com/rabbitmq/amqp091-go

    2. 导入库

    在您的 Go 代码中导入 github.com/rabbitmq/amqp091-go 包:

    import (
    "github.com/rabbitmq/amqp091-go"
    "log"
    )

    3. 建立连接

    使用 amqp.Dial() 函数建立到 RabbitMQ 服务器的连接。通常,您需要提供 RabbitMQ 服务器的连接 URL,例如:

    conn, err := amqp.Dial("amqp://guest:guest@localhost:5672/")
    if err != nil {
    log.Fatalf("Failed to connect to RabbitMQ: %v", err)
    }
    defer conn.Close()

    请根据您的 RabbitMQ 服务器的实际配置提供正确的连接 URL。

    4. 打开通道

    在连接上打开一个通道(channel),用于进行消息传递操作。通道是轻量级的通信路径,允许您在单个连接上创建多个通道。

    channel, err := conn.Channel()
    if err != nil {
    log.Fatalf("Failed to open a channel: %v", err)
    }
    defer channel.Close()

    5. 定义队列

    在发送和接收消息之前,您需要定义一个队列。如果队列不存在,它将被创建。

    queueName := "my-queue"
    _, err = channel.QueueDeclare(
    queueName, // 队列名称
    false, // 是否持久化
    false, // 是否自动删除
    false, // 是否排他
    false, // 是否阻塞
    nil, // 额外的属性
    )
    if err != nil {
    log.Fatalf("Failed to declare a queue: %v", err)
    }

    6. 发送消息

    使用 channel.Publish() 方法发送消息到队列:

    messageBody := []byte("Hello, RabbitMQ!")
    err = channel.Publish(
    "", // 交换机名称(留空表示直接发送到队列)
    queueName, // 目标队列名称
    false, // 是否强制
    false, // 是否立即
    amqp.Publishing{
    ContentType: "text/plain",
    Body: messageBody,
    },
    )
    if err != nil {
    log.Fatalf("Failed to publish a message: %v", err)
    }

    7. 接收消息

    使用 channel.Consume() 方法从队列接收消息:

    messages, err := channel.Consume(
    queueName, // 队列名称
    "", // 消费者名称(留空表示自动生成)
    true, // 自动确认消息
    false, // 是否排他
    false, // 是否阻塞
    false, // 是否为消费者创建临时队列
    nil, // 额外的属性
    )
    if err != nil {
    log.Fatalf("Failed to register a consumer: %v", err)
    }
    for msg := range messages {
    message := string(msg.Body)
    log.Printf("Received a message: %s", message)
    }

    孟斯特

    声明:本作品采用署名-非商业性使用-相同方式共享 4.0 国际 (CC BY-NC-SA 4.0)进行许可,使用时请注明出处。
    Author: mengbin
    blog: mengbin
    Github: mengbin92
    cnblogs: 恋水无意


  • 相关阅读:
    生命周期详解
    dvwa 文件上传漏洞通关攻略
    android之常用adb
    Win10安装Linux--使用HyperV安装CentOS7
    LIinux服务器之间如何传输文件
    小米汽车,能否在新能源汽车江湖站稳脚跟?
    驱动点云格式修改带来的效率提升
    提高编程效率-Vscode实用指南
    超市管理系统(java+Mysql)
    文本中物流获取易语言代码
  • 原文地址:https://www.cnblogs.com/lianshuiwuyi/p/17713993.html
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号