


Comparison and selection of multiple message modes using RabbitMQ in Golang
Comparison and selection of multiple message modes using RabbitMQ in Golang
Introduction:
In distributed systems, message queues are a common communication Mechanism for decoupling message senders and receivers and enabling asynchronous communication. As one of the most popular message queues currently, RabbitMQ provides a variety of message modes for developers to choose from. This article will compare the four classic message modes in RabbitMQ, namely simple queue, work queue, publish/subscribe mode and topic mode, analyze their characteristics and applicable scenarios, and give Golang sample code.
1. Simple Queue (Simple Queue)
Simple queue is the most basic message mode in RabbitMQ, which sends a message to a consumer. Messages are sent to the queue and read by a consumer in turn.
Features:
- A message can only be consumed by one consumer.
- If there are multiple consumers listening to the same queue, messages will be distributed equally to the consumers.
- Consumers with fast processing speed will consume more messages.
Applicable scenarios:
- Application scenarios that require tasks or messages to be distributed to multiple work units, such as log collection, task distribution, etc.
Sample code:
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. Work Queue (Work Queue)
The work queue mode is a load balancing mechanism for messages, through multiple consumers Work together to process messages in a queue. When using the work queue mode, messages are sent to the queue and obtained and processed by consumers in order.
Features:
- A message can only be processed by one consumer.
- The tasks processed by each consumer are relatively equal, that is, consumers with fast processing speed will process more messages.
Applicable scenarios:
- Background task processing, such as image processing, video transcoding, etc.
Sample code:
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 mode (Publish/Subscribe)
In the publish/subscribe mode, the message is broadcast to all subscribers. Every subscriber will receive the same message.
Features:
- Each message will be broadcast to all subscribers.
- Different subscribers can have different message processing logic.
Applicable scenarios:
- Broadcast messages, such as log broadcast, notification broadcast, etc.
Sample code:
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. Topic mode (Topic)
The topic mode is a more complex message mode, which uses the wildcard rules of the topic to Messages are sent to subscribers of the matching topic.
Features:
- Messages are routed through the matching rules of the topic.
- Supports topic matching in wildcard form.
- Different subscribers can subscribe according to the topics they are interested in.
Applicable scenarios:
- Scenarios that require message filtering and routing based on topics.
Sample code:
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 }
Summary:
As a high-performance message queue system, RabbitMQ has rich message modes to meet the needs of different scenarios. According to actual business needs, you can choose the corresponding message mode. This article compares four typical message modes: simple queue, work queue, publish/subscribe mode and topic mode, and gives the corresponding Golang sample code. Developers can choose the appropriate message mode to build a distributed system based on their needs.
The above is the detailed content of Comparison and selection of multiple message modes using RabbitMQ in Golang. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics



Reading and writing files safely in Go is crucial. Guidelines include: Checking file permissions Closing files using defer Validating file paths Using context timeouts Following these guidelines ensures the security of your data and the robustness of your application.

How to configure connection pooling for Go database connections? Use the DB type in the database/sql package to create a database connection; set MaxOpenConns to control the maximum number of concurrent connections; set MaxIdleConns to set the maximum number of idle connections; set ConnMaxLifetime to control the maximum life cycle of the connection.

The difference between the GoLang framework and the Go framework is reflected in the internal architecture and external features. The GoLang framework is based on the Go standard library and extends its functionality, while the Go framework consists of independent libraries to achieve specific purposes. The GoLang framework is more flexible and the Go framework is easier to use. The GoLang framework has a slight advantage in performance, and the Go framework is more scalable. Case: gin-gonic (Go framework) is used to build REST API, while Echo (GoLang framework) is used to build web applications.

JSON data can be saved into a MySQL database by using the gjson library or the json.Unmarshal function. The gjson library provides convenience methods to parse JSON fields, and the json.Unmarshal function requires a target type pointer to unmarshal JSON data. Both methods require preparing SQL statements and performing insert operations to persist the data into the database.

Best practices: Create custom errors using well-defined error types (errors package) Provide more details Log errors appropriately Propagate errors correctly and avoid hiding or suppressing Wrap errors as needed to add context

The FindStringSubmatch function finds the first substring matched by a regular expression: the function returns a slice containing the matching substring, with the first element being the entire matched string and subsequent elements being individual substrings. Code example: regexp.FindStringSubmatch(text,pattern) returns a slice of matching substrings. Practical case: It can be used to match the domain name in the email address, for example: email:="user@example.com", pattern:=@([^\s]+)$ to get the domain name match[1].

How to address common security issues in the Go framework With the widespread adoption of the Go framework in web development, ensuring its security is crucial. The following is a practical guide to solving common security problems, with sample code: 1. SQL Injection Use prepared statements or parameterized queries to prevent SQL injection attacks. For example: constquery="SELECT*FROMusersWHEREusername=?"stmt,err:=db.Prepare(query)iferr!=nil{//Handleerror}err=stmt.QueryR

Backend learning path: The exploration journey from front-end to back-end As a back-end beginner who transforms from front-end development, you already have the foundation of nodejs,...
