suchen
HeimBackend-EntwicklungGolangVergleich und Auswahl mehrerer Nachrichtenmodi mit RabbitMQ in Golang

Vergleich und Auswahl mehrerer Nachrichtenmodi mit RabbitMQ in Golang

Vergleich und Auswahl mehrerer Nachrichtenmodi mit RabbitMQ in Golang

Einführung:
In verteilten Systemen ist die Nachrichtenwarteschlange ein gängiger Kommunikationsmechanismus, der verwendet wird, um Sender und Empfänger einer Nachricht zu entkoppeln und eine asynchrone Kommunikation zu implementieren. RabbitMQ ist derzeit eine der beliebtesten Nachrichtenwarteschlangen und bietet Entwicklern eine Vielzahl von Nachrichtenmodi zur Auswahl. In diesem Artikel werden die vier klassischen Nachrichtenmodi in RabbitMQ, nämlich einfache Warteschlange, Arbeitswarteschlange, Veröffentlichungs-/Abonnementmodus und Themenmodus, verglichen, ihre Eigenschaften und anwendbaren Szenarien analysiert und Golang-Beispielcode gegeben.

1. Simple Queue

Simple Queue ist der einfachste Messaging-Modus in RabbitMQ, der eine Nachricht an einen Verbraucher sendet. Nachrichten werden an die Warteschlange gesendet und wiederum von einem Verbraucher gelesen.

Eigenschaften:

  1. Eine Nachricht kann nur von einem Verbraucher konsumiert werden.
  2. Wenn mehrere Verbraucher dieselbe Warteschlange abhören, werden die Nachrichten gleichmäßig an die Verbraucher verteilt.
  3. Verbraucher mit hoher Verarbeitungsgeschwindigkeit werden mehr Nachrichten konsumieren.

Anwendbare Szenarien:

  1. Anwendungsszenarien, in denen Aufgaben oder Nachrichten auf mehrere Arbeitseinheiten verteilt werden müssen, z. B. Protokollerfassung, Aufgabenverteilung usw.

Beispielcode:

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
}

2. Arbeitswarteschlange (Arbeitswarteschlange)

Der Arbeitswarteschlangenmodus ist ein Nachrichtenlastausgleichsmechanismus, der mehrere Verbraucher verwendet, um Nachrichten in einer Warteschlange gemeinsam zu verarbeiten. Bei Verwendung des Arbeitswarteschlangenmodus werden Nachrichten an die Warteschlange gesendet und von den Verbrauchern der Reihe nach abgerufen und verarbeitet.

Eigenschaften:

  1. Eine Nachricht kann nur von einem Verbraucher verarbeitet werden.
  2. Die von jedem Verbraucher verarbeiteten Aufgaben sind relativ gleich, dh Verbraucher mit hoher Verarbeitungsgeschwindigkeit verarbeiten mehr Nachrichten.

Anwendbare Szenarien:

  1. Hintergrundaufgabenverarbeitung wie Bildverarbeitung, Videotranskodierung usw.

Beispielcode:

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
}

3. Publish/Subscribe-Modus (Publish/Subscribe)

Im Publish/Subscribe-Modus werden Nachrichten an alle Abonnenten gesendet. Jeder Abonnent erhält die gleiche Nachricht.

Funktionen:

  1. Jede Nachricht wird an alle Abonnenten gesendet.
  2. Verschiedene Abonnenten können unterschiedliche Verarbeitungslogiken für Nachrichten haben.

Anwendbare Szenarien:

  1. Broadcast-Nachrichten, wie Protokoll-Broadcast, Benachrichtigungs-Broadcast usw.

Beispielcode:

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
}

4. Themenmodus (Thema)

Der Themenmodus ist ein komplexerer Nachrichtenmodus, der Nachrichten an Abonnenten sendet, die dem Thema entsprechen, basierend auf den Platzhalterregeln des Themas.

Funktionen:

  1. Nachrichten werden über passende Themenregeln weitergeleitet.
  2. Unterstützt den Themenabgleich in Wildcard-Form.
  3. Verschiedene Abonnenten können je nach Themen, die sie interessieren, abonnieren.

Anwendbare Szenarien:

  1. Szenarien, die eine Nachrichtenfilterung und -weiterleitung basierend auf Themen erfordern.

Beispielcode:

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
}

Zusammenfassung:
RabbitMQ verfügt als leistungsstarkes Nachrichtenwarteschlangensystem über umfangreiche Nachrichtenmodi, um den Anforderungen verschiedener Szenarien gerecht zu werden. Entsprechend den tatsächlichen Geschäftsanforderungen können Sie den entsprechenden Nachrichtenmodus auswählen. Dieser Artikel vergleicht vier typische Nachrichtenmodi: einfache Warteschlange, Arbeitswarteschlange, Veröffentlichungs-/Abonnementmodus und Themenmodus und gibt den entsprechenden Golang-Beispielcode. Entwickler können den geeigneten Nachrichtenmodus auswählen, um ein verteiltes System basierend auf ihren Anforderungen aufzubauen.

Das obige ist der detaillierte Inhalt vonVergleich und Auswahl mehrerer Nachrichtenmodi mit RabbitMQ in Golang. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Verwenden von Init für die Paketinitialisierung in GoVerwenden von Init für die Paketinitialisierung in GoApr 24, 2025 pm 06:25 PM

In Go wird die Init -Funktion für die Paketinitialisierung verwendet. 1) Die Init -Funktion wird automatisch bei der Paketinitialisierung aufgerufen und ist geeignet, um globale Variablen zu initialisieren, Verbindungen zu setzen und Konfigurationsdateien zu laden. 2) Es kann mehrere Init -Funktionen geben, die in Dateireihenfolge ausgeführt werden können. 3) Bei der Verwendung sollten die Ausführungsreihenfolge, die Testschwierigkeit und die Leistungsauswirkungen in Betracht gezogen werden. 4) Es wird empfohlen, Nebenwirkungen zu reduzieren, die Abhängigkeitsinjektion zu verwenden und die Initialisierung zu verzögern, um die Verwendung von Init -Funktionen zu optimieren.

GO's Select Anweisung: Multiplexing gleichzeitige OperationenGO's Select Anweisung: Multiplexing gleichzeitige OperationenApr 24, 2025 pm 05:21 PM

GO'SSelectstatementsTreamlinesConcurrentProgrammingByMultiplexingoperationen.1) ITallowswaitingonMultiPhanneloperationen, ExecutingTheFirstreadyone) TheDefaultCasepreventsDeadlocksByAntheProgramtoprosectroseverifnooperation.3) itcanpeusedefoursend

Erweiterte Genauigkeitstechniken in Go: Kontext und KarteigruppenErweiterte Genauigkeitstechniken in Go: Kontext und KarteigruppenApr 24, 2025 pm 05:09 PM

Contextandwaitgroupsarecrucialingoforminggoroutineseffektiv.1) contextAllowSsignalingCancellationanddeadlinesAcrossapiobears, Sicherstellung von Goroutinescanbesten

Die Vorteile der Verwendung von GO for Microservices ArchitectureDie Vorteile der Verwendung von GO for Microservices ArchitectureApr 24, 2025 pm 04:29 PM

GoisbenficialformicroservicesDuetoitsSimplicity, Effizienz, Androbustconcurcysupport.1) GO'Sdesignemphesimplication und idealFormicroservices.2) seine Konzernmodelusings und ChannelsAllows -Handlings -Handlings -Handlings -Handlings -Handlings -Fassungen

Golang gegen Python: Die Vor- und NachteileGolang gegen Python: Die Vor- und NachteileApr 21, 2025 am 12:17 AM

GolangissidealforbuildingsCalablesSystemduetoitseffizienz und Konsumverkehr, whilepythonexcelsinquickScriptingandDataanalyseduetoitssimplication und VacevastEcosystem.golangsDesineScouragesCouragescournations, tadelcodedeanDitsGoroutaTinoutgoroutaTinoutgoroutaTinoutsGoroutinesGoroutinesGoroutsGoroutins, t

Golang und C: Parallelität gegen RohgeschwindigkeitGolang und C: Parallelität gegen RohgeschwindigkeitApr 21, 2025 am 12:16 AM

Golang ist in Gleichzeitigkeit besser als C, während C bei Rohgeschwindigkeit besser als Golang ist. 1) Golang erreicht durch Goroutine und Kanal eine effiziente Parallelität, die zum Umgang mit einer großen Anzahl von gleichzeitigen Aufgaben geeignet ist. 2) C über Compiler -Optimierung und Standardbibliothek bietet es eine hohe Leistung in der Nähe der Hardware, die für Anwendungen geeignet ist, die eine extreme Optimierung erfordern.

Warum Golang verwenden? Vorteile und Vorteile erläutertWarum Golang verwenden? Vorteile und Vorteile erläutertApr 21, 2025 am 12:15 AM

Gründe für die Auswahl von Golang umfassen: 1) Leistung mit hoher Genauigkeit, 2) statisches System, 3) Mechanismusmechanismus, 4) Reiche Standardbibliotheken und Ökosysteme, die es zu einer idealen Wahl für die Entwicklung einer effizienten und zuverlässigen Software machen.

Golang gegen C: Leistung und GeschwindigkeitsvergleichGolang gegen C: Leistung und GeschwindigkeitsvergleichApr 21, 2025 am 12:13 AM

Golang ist für schnelle Entwicklung und gleichzeitige Szenarien geeignet, und C ist für Szenarien geeignet, in denen extreme Leistung und Kontrolle auf niedriger Ebene erforderlich sind. 1) Golang verbessert die Leistung durch Müllsammlung und Parallelitätsmechanismen und eignet sich für die Entwicklung von Webdiensten mit hoher Konsequenz. 2) C erreicht die endgültige Leistung durch das manuelle Speicherverwaltung und die Compiler -Optimierung und eignet sich für eingebettete Systementwicklung.

See all articles

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

Video Face Swap

Video Face Swap

Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

Herunterladen der Mac-Version des Atom-Editors

Herunterladen der Mac-Version des Atom-Editors

Der beliebteste Open-Source-Editor

MinGW – Minimalistisches GNU für Windows

MinGW – Minimalistisches GNU für Windows

Dieses Projekt wird derzeit auf osdn.net/projects/mingw migriert. Sie können uns dort weiterhin folgen. MinGW: Eine native Windows-Portierung der GNU Compiler Collection (GCC), frei verteilbare Importbibliotheken und Header-Dateien zum Erstellen nativer Windows-Anwendungen, einschließlich Erweiterungen der MSVC-Laufzeit zur Unterstützung der C99-Funktionalität. Die gesamte MinGW-Software kann auf 64-Bit-Windows-Plattformen ausgeführt werden.

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

WebStorm-Mac-Version

WebStorm-Mac-Version

Nützliche JavaScript-Entwicklungstools