백엔드 개발 Golang Go에서 RabbitMQ 사용: 전체 가이드

Go에서 RabbitMQ 사용: 전체 가이드

Jun 19, 2023 am 08:10 AM
언어로 가다 가이드 rabbitmq

최신 애플리케이션의 복잡성이 증가함에 따라 메시징은 강력한 도구가 되었습니다. 이 분야에서 RabbitMQ는 다양한 애플리케이션 간에 메시지를 전달하는 데 사용할 수 있는 매우 인기 있는 메시지 브로커가 되었습니다.

이 기사에서는 Go 언어에서 RabbitMQ를 사용하는 방법을 살펴보겠습니다. 이 가이드에서는 다음 내용을 다룹니다.

  • RabbitMQ 소개
  • RabbitMQ 설치
  • RabbitMQ의 기본 개념
  • Go 언어로 RabbitMQ 시작하기
  • RabbitMQ 및 Go 언어의 고급 사용법

RabbitMQ 소개

RabbitMQ 오픈 소스 메시지 브로커 미들웨어입니다. 이는 애플리케이션 간 메시징을 쉽게 처리하는 데 도움이 되는 안정적이고 가용성이 높으며 확장 가능하고 사용하기 쉬운 브로커입니다.

RabbitMQ는 AMQP, MQTT 및 STOMP와 같은 여러 메시징 프로토콜을 지원합니다. 또한 메시지 배포, 메시지 지속성, 메시지 확인 및 메시지 대기열과 같은 많은 고급 기능도 있습니다.

RabbitMQ 설치

RabbitMQ를 사용하기 전에 다음 명령을 사용하여 설치해야 합니다.

$ sudo apt-get install rabbitmq-server
로그인 후 복사

RabbitMQ를 Docker 컨테이너로 설치할 수도 있습니다. 더 많은 정보를 원하시면 공식 홈페이지를 방문해주세요.

RabbitMQ의 기본 개념

RabbitMQ를 사용하기 전에 몇 가지 기본 개념을 이해해 봅시다.

  • Producer: 메시지를 보내는 애플리케이션입니다.
  • 메시지 큐(Queue): RabbitMQ가 메시지를 저장하는 데 사용하는 컨테이너입니다.
  • Consumer: 메시지를 수신하는 애플리케이션입니다.
  • Exchange: RabbitMQ가 메시지를 수신하고 라우팅하는 데 사용하는 구성 요소입니다.
  • 바인딩: 스위치와 대기열을 연결하는 프로세스입니다.
  • 라우팅 키: 메시지를 일치하는 대기열로 라우팅하는 데 사용되는 문자열입니다.
  • 메시지 패턴: 직접, 팬아웃, 주제 및 헤더를 포함하여 메시지가 라우팅되는 방식을 지정하는 규칙입니다.

Go 언어로 RabbitMQ 시작하기

Go 언어를 사용하여 간단한 RabbitMQ 생산자와 소비자를 작성해 보겠습니다.

먼저 Go 언어용 RabbitMQ 클라이언트를 설치해야 합니다.

$ go get github.com/streadway/amqp
로그인 후 복사

다음으로 다음 코드를 RabbitMQ의 간단한 생산자로 사용합니다.

package main

import (
    "log"

    "github.com/streadway/amqp"
)

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

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

    // 声明一个队列
    q, err := ch.QueueDeclare(
        "hello", // 队列名称
        false,  // 是否持久化
        false,  // 是否自动删除
        false,  // 是否具有排他性
        false,  // 是否阻塞处理
        nil,    // 额外的参数
    )
    if err != nil {
        log.Fatalf("Failed to declare a queue: %v", err)
    }

    // 发送两条消息
    for _, body := range []string{"Hello", "World"} {
        err = ch.Publish(
            "",    // 交换机名称
            q.Name,  // 队列名称
            false, // 是否强制遵循新的基于名称的路由规则
            false, // 是否立即将消息传递给消费者
            amqp.Publishing{
                ContentType: "text/plain",
                Body:        []byte(body),
            },
        )
        if err != nil {
            log.Fatalf("Failed to publish a message: %v", err)
        }
        log.Printf("Sent a message: %v", body)
    }
}
로그인 후 복사

이 예에서는 "hello"라는 대기열에 연결합니다. for 루프를 사용하여 두 개의 메시지를 큐에 보냅니다. 각 메시지는 게시 구조에 포함된 간단한 문자열입니다. ch.Publish() 메서드는 메시지를 대기열에 게시하는 데 사용됩니다. ch.Publish()方法用于将消息发布到队列。

现在,让我们创建一个消费者来接收这些消息:

package main

import (
    "log"

    "github.com/streadway/amqp"
)

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

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

    // 声明一个队列
    q, err := ch.QueueDeclare(
        "hello", // 队列名称
        false,  // 是否持久化
        false,  // 是否自动删除
        false,  // 是否具有排他性
        false,  // 是否阻塞处理
        nil,    // 额外的参数
    )
    if err != nil {
        log.Fatalf("Failed to declare a queue: %v", err)
    }

    // 将通道设置为接收模式
    msgs, err := ch.Consume(
        q.Name, // 队列名称
        "",     // 消费者名称
        true,   // 自动确认消息
        false,  // 是否具有排他性
        false,  // 是否阻塞处理
        false,  // 额外参数
    )
    if err != nil {
        log.Fatalf("Failed to register a consumer: %v", err)
    }

    // 使用通道消费消息
    forever := make(chan bool)

    go func() {
        for d := range msgs {
            log.Printf("Received a message: %v", string(d.Body))
        }
    }()

    log.Printf("Waiting for messages...")

    <-forever
}
로그인 후 복사

在这个消费者例子中,我们从名为“hello”的队列中拉取消息,然后对消息进行回显。在这个例子中,我们使用通道的ch.Consume()方法从队列中消费消息。

RabbitMQ和Go语言的高级用法

在本部分中,我们将探讨RabbitMQ和Go语言的高级用法。

首先,让我们探讨如何使用RabbitMQ和Go语言实现消息确认。消息确认通常用于确保消息已被正确处理。

首先,我们需要在消费者端打开确认模式:

msgs, err := ch.Consume(
    q.Name, // 队列名称
    "",     // 消费者名称
    false,  // 自动确认消息
    false,  // 是否具有排他性
    false,  // 是否阻塞处理
    false,  // 额外参数
)
로그인 후 복사

在手动确认模式下,我们需要在消费者端明确地确认每一条消息:

for d := range msgs {
    log.Printf("Received a message: %v", string(d.Body))

    // 确认消息
    d.Ack(false)
}
로그인 후 복사

我们还可以使用RabbitMQ的RPC模式来实现分布式RPC调用。在RPC模式下,客户端应用程序将请求发送到RabbitMQ,RabbitMQ将请求转发给适当的服务器,服务器将处理请求并返回响应。

首先,我们需要声明一个交换机来接收RPC请求:

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

// 声明一个Direct类型的交换机
err = ch.ExchangeDeclare(
    "rpc_exchange", // 交换机名称
    "direct",       // 交换机类型
    true,           // 是否持久化
    false,          // 是否自动删除
    false,          // 是否具有排他性
    false,          // 是否阻塞处理
    nil,            // 额外参数
)
if err != nil {
    log.Fatalf("Failed to declare a exchange: %v", err)
}

// 声明一个接收RPC请求的队列
q, err := ch.QueueDeclare("", false, false, true, false, nil)
if err != nil {
    log.Fatalf("Failed to declare a queue: %v", err)
}

// 将队列绑定到交换机
err = ch.QueueBind(
    q.Name,         // 队列名称
    "rpc_routing",  // 路由键
    "rpc_exchange", // 交换机名称
    false,          // 是否强制遵循新的基于名称的路由规则
    nil,            // 额外参数
)
if err != nil {
    log.Fatalf("Failed to bind a queue: %v", err)
}
로그인 후 복사

接下来,我们将创建一个函数来处理RPC请求:

func rpcHandler(body []byte) []byte {
    log.Printf("Received RPC request: %s", string(body))

    // 处理请求
    result := []byte("Hello, World!")

    return result
}
로그인 후 복사

然后,我们需要编写一个消费者来接收RPC请求:

msg, ok, err := ch.Get(q.Name, true)
if err != nil {
    log.Fatalf("Failed to handle RPC request: %v", err)
}

if !ok {
    log.Printf("No messages available")
    return
}

// 处理RPC请求
response := rpcHandler(msg.Body)

// 发送RPC响应
err = ch.Publish(
    "",              // 交换机名称
    msg.ReplyTo,     // 回调队列名称
    false,           // 是否强制遵循新的基于名称的路由规则
    false,           // 是否立即将消息传递给消费者
    amqp.Publishing{ // 发布消息
        ContentType: "text/plain",
        CorrelationId: msg.CorrelationId,
        Body:        response,
    },
)
if err != nil {
    log.Fatalf("Failed to publish a message: %v", err)
}

log.Printf("Sent RPC response: %v", string(response))
로그인 후 복사

在这个例子中,我们使用ch.Get()方法从队列中拉取消息,并将其发送给rpcHandler()方法进行处理。一旦处理完成,我们使用ch.Publish()

이제 다음 메시지를 수신하는 소비자를 만들어 보겠습니다.

rrreee

이 소비자 예에서는 "hello"라는 대기열에서 메시지를 가져온 다음 메시지를 에코합니다. 이 예에서는 채널의 ch.Consume() 메서드를 사용하여 대기열의 메시지를 사용합니다.

RabbitMQ 및 Go 언어의 고급 사용법🎜🎜이 섹션에서는 RabbitMQ 및 Go 언어의 고급 사용법을 살펴보겠습니다. 🎜🎜먼저 RabbitMQ와 Go 언어를 사용하여 메시지 확인을 구현하는 방법을 살펴보겠습니다. 메시지 확인은 일반적으로 메시지가 올바르게 처리되었는지 확인하는 데 사용됩니다. 🎜🎜먼저 소비자 측에서 확인 모드를 켜야 합니다. 🎜rrreee🎜수동 확인 모드에서는 소비자 측에서 각 메시지를 명시적으로 확인해야 합니다. 🎜rrreee🎜분배를 위해 RabbitMQ의 RPC 모드를 사용할 수도 있습니다. RPC 호출. RPC 모드에서 클라이언트 애플리케이션은 RabbitMQ에 요청을 보내고, RabbitMQ는 해당 요청을 적절한 서버로 전달하며, 서버는 요청을 처리하고 응답을 반환합니다. 🎜🎜먼저 RPC 요청을 수신하기 위한 교환을 선언해야 합니다: 🎜rrreee🎜다음으로 RPC 요청을 처리하는 함수를 생성합니다: 🎜rrreee🎜그런 다음 RPC 요청을 수신하기 위한 소비자를 작성해야 합니다: 🎜rrreee🎜In 이 예에서는 ch.Get() 메서드를 사용하여 대기열에서 메시지를 가져와 처리를 위해 rpcHandler() 메서드로 보냅니다. 처리가 완료되면 ch.Publish() 메서드를 사용하여 클라이언트에 응답을 다시 보냅니다. 🎜🎜결론🎜🎜RabbitMQ는 애플리케이션 간 메시징을 쉽게 처리하는 데 도움이 되는 강력한 도구입니다. 이 가이드에서는 Go에서 RabbitMQ의 기본 및 고급 사용법을 다룹니다. 이제 RabbitMQ를 통한 효율적인 메시징을 위해 이 지식을 자신의 프로젝트에 적용할 수 있습니다! 🎜

위 내용은 Go에서 RabbitMQ 사용: 전체 가이드의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25 : Myrise에서 모든 것을 잠금 해제하는 방법
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

GO에서 플로팅 포인트 번호 작업에 어떤 라이브러리가 사용됩니까? GO에서 플로팅 포인트 번호 작업에 어떤 라이브러리가 사용됩니까? Apr 02, 2025 pm 02:06 PM

Go Language의 부동 소수점 번호 작동에 사용되는 라이브러리는 정확도를 보장하는 방법을 소개합니다.

Go 's Crawler Colly의 큐 스레드의 문제는 무엇입니까? Go 's Crawler Colly의 큐 스레드의 문제는 무엇입니까? Apr 02, 2025 pm 02:09 PM

Go Crawler Colly의 대기열 스레딩 문제는 Colly Crawler 라이브러리를 GO 언어로 사용하는 문제를 탐구합니다. � ...

GO의 어떤 라이브러리가 대기업에서 개발하거나 잘 알려진 오픈 소스 프로젝트에서 제공합니까? GO의 어떤 라이브러리가 대기업에서 개발하거나 잘 알려진 오픈 소스 프로젝트에서 제공합니까? Apr 02, 2025 pm 04:12 PM

GO의 어떤 라이브러리가 대기업이나 잘 알려진 오픈 소스 프로젝트에서 개발 했습니까? GO에 프로그래밍 할 때 개발자는 종종 몇 가지 일반적인 요구를 만납니다.

GO 언어에서 'var'와 'type` 키워드 정의 구조의 차이점은 무엇입니까? GO 언어에서 'var'와 'type` 키워드 정의 구조의 차이점은 무엇입니까? Apr 02, 2025 pm 12:57 PM

GO 언어에서 구조를 정의하는 두 가지 방법 : VAR과 유형 키워드의 차이. 구조를 정의 할 때 Go Language는 종종 두 가지 다른 글쓰기 방법을 본다 : 첫째 ...

Redis Stream을 사용하여 GO Language에서 메시지 대기열을 구현할 때 User_ID 유형 변환 문제를 해결하는 방법은 무엇입니까? Redis Stream을 사용하여 GO Language에서 메시지 대기열을 구현할 때 User_ID 유형 변환 문제를 해결하는 방법은 무엇입니까? Apr 02, 2025 pm 04:54 PM

Go Language에서 메시지 대기열을 구현하기 위해 Redisstream을 사용하는 문제는 Go Language와 Redis를 사용하는 것입니다 ...

이동 중에 왜 println 및 string () 함수로 문자열이 다른 효과를 갖는 이유는 무엇입니까? 이동 중에 왜 println 및 string () 함수로 문자열이 다른 효과를 갖는 이유는 무엇입니까? Apr 02, 2025 pm 02:03 PM

Go Language의 문자열 인쇄의 차이 : println 및 String () 함수 사용 효과의 차이가 진행 중입니다 ...

Go 및 Viper 라이브러리를 사용할 때 포인터를 전달 해야하는 이유는 무엇입니까? Go 및 Viper 라이브러리를 사용할 때 포인터를 전달 해야하는 이유는 무엇입니까? Apr 02, 2025 pm 04:00 PM

Go Pointer Syntax 및 Viper Library 사용의 문제 해결 GO 언어로 프로그래밍 할 때 특히 포인터의 구문 및 사용법을 이해하는 것이 중요합니다.

Go Language to Traverse 슬라이스 및 매장 맵에 범위를 사용할 때 모든 값이 마지막 요소가되는 이유는 무엇입니까? Go Language to Traverse 슬라이스 및 매장 맵에 범위를 사용할 때 모든 값이 마지막 요소가되는 이유는 무엇입니까? Apr 02, 2025 pm 04:09 PM

GO의지도 반복이 왜 모든 값이 마지막 요소가되게합니까? Go Language에서 인터뷰 질문에 직면했을 때, 당신은 종종지도를 만납니다 ...

See all articles