国产av日韩一区二区三区精品,成人性爱视频在线观看,国产,欧美,日韩,一区,www.成色av久久成人,2222eeee成人天堂

首頁 後端開發(fā) Golang Golang中使用RabbitMQ實現(xiàn)多種訊息模式的比較與選擇

Golang中使用RabbitMQ實現(xiàn)多種訊息模式的比較與選擇

Sep 28, 2023 pm 12:10 PM
golang rabbitmq 訊息模式

Golang中使用RabbitMQ實現(xiàn)多種訊息模式的比較與選擇

Golang中使用RabbitMQ實作多種訊息模式的比較與選擇

引言:
在分散式系統(tǒng)中,訊息佇列是一種常見的通信機制,用於解耦訊息的發(fā)送者和接收者,並實現(xiàn)非同步通訊。 RabbitMQ作為目前最受歡迎的訊息佇列之一,提供了多種訊息模式供開發(fā)者選擇。本文將透過比較RabbitMQ中經(jīng)典的四種訊息模式,即簡單佇列、工作佇列、發(fā)布/訂閱模式和主題模式,分析它們的特點和適用場景,並給出Golang範例程式碼。

一、簡單佇列(Simple Queue)

簡單佇列是RabbitMQ中最基礎(chǔ)的訊息模式,它將一則訊息傳送給一個消費者。訊息傳送到佇列中,然後依序經(jīng)由一個消費者被讀取。

特點:

  1. 一個訊息只能被一個消費者消費。
  2. 如果有多個消費者監(jiān)聽同一個隊列,訊息將會被均等分發(fā)給消費者。
  3. 處理速度快的消費者會消費更多的訊息。

適用場景:

  1. 需要將任務(wù)或訊息分發(fā)給多個工作單元的應(yīng)用程式場景,例如日誌收集、任務(wù)分發(fā)等。

範例程式碼:

package main

import (
    "log"

    "github.com/streadway/amqp"
)

func failOnError(err error, msg string) {
    if err != nil {
        log.Fatalf("%s: %s", msg, err)
    }
}

func main() {
    conn, err := amqp.Dial("amqp://guest:guest@localhost:5672/")
    failOnError(err, "Failed to connect to RabbitMQ")
    defer conn.Close()

    ch, err := conn.Channel()
    failOnError(err, "Failed to open a channel")
    defer ch.Close()

    q, err := ch.QueueDeclare(
        "simple_queue",
        false,
        false,
        false,
        false,
        nil,
    )
    failOnError(err, "Failed to declare a queue")

    msgs, err := ch.Consume(
        q.Name,
        "",
        true,
        false,
        false,
        false,
        nil,
    )
    failOnError(err, "Failed to register a consumer")

    forever := make(chan bool)

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

    log.Printf(" [*] Waiting for messages. To exit press CTRL+C")
    <-forever
}

二、工作佇列(Work Queue)

工作佇列模式是一種訊息的負載平衡機制,透過多個消費者共同處理一個隊列中的消息。使用工作佇列模式時,訊息會傳送到佇列中,並依照順序被消費者取得並處理。

特點:

  1. 一個訊息只能被一個消費者處理。
  2. 每個消費者處理的任務(wù)相對均等,即處理速度快的消費者會處理更多的訊息。

適用場景:

  1. 後臺任務(wù)處理,例如圖片處理、影片轉(zhuǎn)碼等。

範例程式碼:

package main

import (
    "log"
    "os"
    "strconv"
    "strings"

    "github.com/streadway/amqp"
)

func failOnError(err error, msg string) {
    if err != nil {
        log.Fatalf("%s: %s", msg, err)
    }
}

func main() {
    conn, err := amqp.Dial("amqp://guest:guest@localhost:5672/")
    failOnError(err, "Failed to connect to RabbitMQ")
    defer conn.Close()

    ch, err := conn.Channel()
    failOnError(err, "Failed to open a channel")
    defer ch.Close()

    q, err := ch.QueueDeclare(
        "work_queue",
        true,
        false,
        false,
        false,
        nil,
    )
    failOnError(err, "Failed to declare a queue")

    body := bodyFrom(os.Args)
    err = ch.Publish(
        "",
        q.Name,
        false,
        false,
        amqp.Publishing{
            DeliveryMode: amqp.Persistent,
            ContentType:  "text/plain",
            Body:         []byte(body),
        })
    failOnError(err, "Failed to publish a message")

    log.Printf(" [x] Sent %s", body)
}

func bodyFrom(args []string) string {
    var s string
    if (len(args) < 2) || os.Args[1] == "" {
        s = "Hello, World!"
    } else {
        s = strings.Join(args[1:], " ")
    }
    return strconv.Itoa(os.Getpid()) + ":" + s
}

三、發(fā)布/訂閱模式(Publish/Subscribe)

發(fā)布/訂閱模式中,訊息會廣播到所有訂閱者。每個訂閱者都會接收到相同的訊息。

特點:

  1. 每個訊息都會被廣播到所有訂閱者。
  2. 不同訂閱者對訊息的處理邏輯可以不同。

適用場景:

  1. 廣播訊息,例如日誌廣播、通知廣播等。

範例程式碼:

package main

import (
    "log"

    "github.com/streadway/amqp"
)

func failOnError(err error, msg string) {
    if err != nil {
        log.Fatalf("%s: %s", msg, err)
    }
}

func main() {
    conn, err := amqp.Dial("amqp://guest:guest@localhost:5672/")
    failOnError(err, "Failed to connect to RabbitMQ")
    defer conn.Close()

    ch, err := conn.Channel()
    failOnError(err, "Failed to open a channel")
    defer ch.Close()

    err = ch.ExchangeDeclare(
        "logs",
        "fanout",
        true,
        false,
        false,
        false,
        nil,
    )
    failOnError(err, "Failed to declare an exchange")

    q, err := ch.QueueDeclare(
        "",
        false,
        false,
        true,
        false,
        nil,
    )
    failOnError(err, "Failed to declare a queue")

    err = ch.QueueBind(
        q.Name,
        "",
        "logs",
        false,
        nil,
    )
    failOnError(err, "Failed to bind a queue")

    msgs, err := ch.Consume(
        q.Name,
        "",
        true,
        false,
        false,
        false,
        nil,
    )
    failOnError(err, "Failed to register a consumer")

    forever := make(chan bool)

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

    log.Printf(" [*] Waiting for messages. To exit press CTRL+C")
    <-forever
}

四、主題模式(Topic)

主題模式是一種比較複雜的訊息模式,它根據(jù)主題的通配符規(guī)則將訊息發(fā)送到符合主題的訂閱者。

特點:

  1. 訊息透過主題的匹配規(guī)則進行路由。
  2. 支援通配符形式的主題匹配。
  3. 不同訂閱者可以根據(jù)自己感興趣的主題進行訂閱。

適用場景:

  1. 需要根據(jù)主題進行訊息過濾與路由的場景。

範例程式碼:

package main

import (
    "log"
    "os"

    "github.com/streadway/amqp"
)

func failOnError(err error, msg string) {
    if err != nil {
        log.Fatalf("%s: %s", msg, err)
    }
}

func main() {
    conn, err := amqp.Dial("amqp://guest:guest@localhost:5672/")
    failOnError(err, "Failed to connect to RabbitMQ")
    defer conn.Close()

    ch, err := conn.Channel()
    failOnError(err, "Failed to open a channel")
    defer ch.Close()

    err = ch.ExchangeDeclare(
        "direct_logs",
        "direct",
        true,
        false,
        false,
        false,
        nil,
    )
    failOnError(err, "Failed to declare an exchange")

    severity := severityFrom(os.Args)
    body := bodyFrom(os.Args)

    err = ch.Publish(
        "direct_logs",
        severity,
        false,
        false,
        amqp.Publishing{
            ContentType: "text/plain",
            Body:        []byte(body),
        },
    )
    failOnError(err, "Failed to publish a message")

    log.Printf(" [x] Sent %s", body)
}

func severityFrom(args []string) string {
    var severity string
    if len(args) < 3 || os.Args[2] == "" {
        severity = "info"
    } else {
        severity = os.Args[2]
    }
    return severity
}

func bodyFrom(args []string) string {
    var s string
    if len(args) < 4 || os.Args[3] == "" {
        s = "Hello, World!"
    } else {
        s = strings.Join(args[3:], " ")
    }
    return s
}

總結(jié):
RabbitMQ作為一種高效能的訊息佇列系統(tǒng),具有豐富的訊息模式可以滿足不同場景下的需求。根據(jù)實際業(yè)務(wù)需求,可以選擇相應(yīng)的訊息模式。本文透過簡單佇列、工作佇列、發(fā)佈/訂閱模式和主題模式四種典型的訊息模式進行比較,並給出了對應(yīng)的Golang範例程式碼。開發(fā)者可根據(jù)需求選擇合適的訊息模式來建構(gòu)分散式系統(tǒng)。

以上是Golang中使用RabbitMQ實現(xiàn)多種訊息模式的比較與選擇的詳細內(nèi)容。更多資訊請關(guān)注PHP中文網(wǎng)其他相關(guān)文章!

本網(wǎng)站聲明
本文內(nèi)容由網(wǎng)友自願投稿,版權(quán)歸原作者所有。本站不承擔相應(yīng)的法律責任。如發(fā)現(xiàn)涉嫌抄襲或侵權(quán)的內(nèi)容,請聯(lián)絡(luò)admin@php.cn

熱AI工具

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅(qū)動的應(yīng)用程序,用於創(chuàng)建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發(fā)環(huán)境

Dreamweaver CS6

Dreamweaver CS6

視覺化網(wǎng)頁開發(fā)工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

如何使用 Golang 安全地讀取和寫入檔案? 如何使用 Golang 安全地讀取和寫入檔案? Jun 06, 2024 pm 05:14 PM

在Go中安全地讀取和寫入檔案至關(guān)重要。指南包括:檢查檔案權(quán)限使用defer關(guān)閉檔案驗證檔案路徑使用上下文逾時遵循這些準則可確保資料的安全性和應(yīng)用程式的健全性。

Golang vs.C:性能和速度比較 Golang vs.C:性能和速度比較 Apr 21, 2025 am 12:13 AM

Golang適合快速開發(fā)和並發(fā)場景,C 適用於需要極致性能和低級控制的場景。 1)Golang通過垃圾回收和並發(fā)機制提升性能,適合高並發(fā)Web服務(wù)開發(fā)。 2)C 通過手動內(nèi)存管理和編譯器優(yōu)化達到極致性能,適用於嵌入式系統(tǒng)開發(fā)。

Golang和C:並發(fā)與原始速度 Golang和C:並發(fā)與原始速度 Apr 21, 2025 am 12:16 AM

Golang在並發(fā)性上優(yōu)於C ,而C 在原始速度上優(yōu)於Golang。 1)Golang通過goroutine和channel實現(xiàn)高效並發(fā),適合處理大量並發(fā)任務(wù)。 2)C 通過編譯器優(yōu)化和標準庫,提供接近硬件的高性能,適合需要極致優(yōu)化的應(yīng)用。

從前端轉(zhuǎn)型後端開發(fā),學(xué)習(xí)Java還是Golang更有前景? 從前端轉(zhuǎn)型後端開發(fā),學(xué)習(xí)Java還是Golang更有前景? Apr 02, 2025 am 09:12 AM

後端學(xué)習(xí)路徑:從前端轉(zhuǎn)型到後端的探索之旅作為一名從前端開發(fā)轉(zhuǎn)型的後端初學(xué)者,你已經(jīng)有了nodejs的基礎(chǔ),...

Go語言中哪些庫是由大公司開發(fā)或知名的開源項目提供的? Go語言中哪些庫是由大公司開發(fā)或知名的開源項目提供的? Apr 02, 2025 pm 04:12 PM

Go語言中哪些庫是大公司開發(fā)或知名開源項目?在使用Go語言進行編程時,開發(fā)者常常會遇到一些常見的需求,?...

Golang vs. Python:性能和可伸縮性 Golang vs. Python:性能和可伸縮性 Apr 19, 2025 am 12:18 AM

Golang在性能和可擴展性方面優(yōu)於Python。 1)Golang的編譯型特性和高效並發(fā)模型使其在高並發(fā)場景下表現(xiàn)出色。 2)Python作為解釋型語言,執(zhí)行速度較慢,但通過工具如Cython可優(yōu)化性能。

Golang的目的:建立高效且可擴展的系統(tǒng) Golang的目的:建立高效且可擴展的系統(tǒng) Apr 09, 2025 pm 05:17 PM

Go語言在構(gòu)建高效且可擴展的系統(tǒng)中表現(xiàn)出色,其優(yōu)勢包括:1.高性能:編譯成機器碼,運行速度快;2.並發(fā)編程:通過goroutines和channels簡化多任務(wù)處理;3.簡潔性:語法簡潔,降低學(xué)習(xí)和維護成本;4.跨平臺:支持跨平臺編譯,方便部署。

Golang vs. Python:主要差異和相似之處 Golang vs. Python:主要差異和相似之處 Apr 17, 2025 am 12:15 AM

Golang和Python各有優(yōu)勢:Golang適合高性能和并發(fā)編程,Python適用于數(shù)據(jù)科學(xué)和Web開發(fā)。Golang以其并發(fā)模型和高效性能著稱,Python則以簡潔語法和豐富庫生態(tài)系統(tǒng)著稱。

See all articles