ZVVQ代理分享网

如何在 Golang 框架中集成 RabbitMQ 消息队列?(g

作者:zvvq博客网
导读如何在 go 框架中集成 rabbitmq 消息队列?安装 rabbitmq:安装 erlang 和 rabbitmq。创建 go 项目:创建一个新的 go 项目,并初始化 go 模块。安装 rabbitmq amqp 客户端库:使用 go get 命令安装。连

如何在 go 框架中集成 rabbitmq 消息队列?安装 rabbitmq:安装 erlang 和 rabbitmq。创建 go 项目:创建一个新的 go 项目,并初始化 go 模块。安装 rabbitmq amqp 客户端库:使用 go get 命令安装。连接到 rabbitmq 服务器:使用 amqp 包连接到服务器。创建频道并声明队列:创建频道并声明一个名为 “my-queue” 的队列。准备消息:准备要发送的消息体。发布消息到队列:使用 ch.publish 函数发布消息。实战案例 :演示

如何在 Golang 框架中集成 RabbitMQ 消息队列

RabbitMQ 是一个流行的消息队列服务,可在各种应用程序中用于可靠且高效的通信。本文将指导您如何在 Golang 框架中集成 RabbitMQ 消息队列。

安装 RabbitMQ

确保已安装 Erlang,它是 RabbitMQ 的依赖项:

1

sudo apt install erlang

安装 RabbitMQ:

”;

1

sudo apt install rabbitmq-server

启动 RabbitMQ 服务:

1

sudo systemctl start rabbitmq-server

创建 Go 项目

创建一个新的 Go 项目目录:

1

2

mkdir my-rabbitmq-app

cd my-rabbitmq-app

初始化 Go 模块:

1

go mod init my-rabbitmq-app

安装 RabbitMQ AMQP 客户端库

安装 RabbitMQ AMQP 客户端库:

1

go get <a style=color:f60; text-decoration:underline; href="https://www.php.cn/zt/15841.html" target="_blank">git</a>hub.com/streadway/amqp

连接到 RabbitMQ 服务器

在您的 Go 代码中,您可以使用 amqp 包连接到 RabbitMQ 服务器:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

package main

import (

"context"

"fmt"

"log"

"os"

"github.com/streadway/amqp"

)

func main() {

// 获取环境变量中的 RabbitMQ 设置

username := os.Getenv("RABBITMQ_USERNAME")

password := os.Getenv("RABBITMQ_PASSWORD")

host := os.Getenv("RABBITMQ_HOST")

port := os.Getenv("RABBITMQ_PORT")

// 建立连接到 RabbitMQ 服务器

conn, err := amqp.Dial(fmt.Sprintf("amqp://%s:%s@%s:%s/", username, password, host, port))

if err != nil {

log.Fatalf("Failed to connect to RabbitMQ: %s", err)

}

defer conn.Close()

}

创建频道并声明队列

一旦建立连接,您可以创建频道并声明队列:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

// 创建一个新的 AMQP 频道

ch, err := conn.Channel()

if err != nil {

log.Fatalf("Failed to create channel: %s", err)

}

defer ch.Close()

// 声明一个名为 "my-queue" 的队列

_, err = ch.QueueDeclare(

"my-queue", // 队列名称

false,      // 是否持久化

false,      // 是否自动删除

false,      // 是否独占

false,      // 是否为临时队列

nil,        // 其他参数

)

if err != nil {

log.Fatalf("Failed to declare queue: %s", err)

}

准备要发送的消息

接下来,您可以准备要发送的消息:

1

2

3

4

5

6

7

// 定义消息主体

msgBody := "Hello, RabbitMQ!"

// 创建一个 AMQP 消息

msg := amqp.Publishing{

Body: []byte(msgBody),

}

发布消息到队列

最后,您可以发布消息到队列:

1

2

3

4

5

6

7

8

9

10

11

12

13

// 发布消息到队列

err = ch.Publish(

"",             // 交换机名称(留空表示默认交换机)

"my-queue",  // 队列名称

false,       // 是否为强制性消息

false,       // 是否为立即确认

msg,         // 消息

)

if err != nil {

log.Fatalf("Failed to publish message: %s", err)

}

log.Printf("Message published: %s", msgBody)

实战案例 :演示发送和接收消息

创建一个名为 producer.go 的文件来发送消息:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

61

62

63

64

65

66

67

68

69

70

71

72

73

74

75

76

package main

import (

"context"

"fmt"

"log"

"os"

"strconv"

"time"

"github.com/streadway/amqp"

)

func main() {

// 获取环境变量中的 RabbitMQ 设置

username := os.Getenv("RABBITMQ_USERNAME")

password := os.Getenv("RABBITMQ_PASSWORD")

host := os.Getenv("RABBITMQ_HOST")

port := os.Getenv("RABBITMQ_PORT")

// 建立连接到 RabbitMQ 服务器

conn, err := amqp.Dial(fmt.Sprintf("amqp://%s:%s@%s:%s/", username, password, host, port))

if err != nil {

log.Fatalf("Failed to connect to RabbitMQ: %s", err)

}

defer conn.Close()

// 创建一个新的 AMQP 频道

ch, err := conn.Channel()

if err != nil {

log.Fatalf("Failed to create channel: %s", err)

}

defer ch.Close()

// 声明一个名为 "my-queue" 的队列

_, err = ch.QueueDeclare(

"my-queue", // 队列名称

false,      // 是否持久化

false,      // 是否自动删除

false,      // 是否独占

false,      // 是否为临时队列

nil,        // 其他参数

)

if err != nil {

log.Fatalf("Failed to declare queue: %s", err)

}

// 初始化消息计数

msgCount := 1

// 发送消息循环

for {

// 创建要发送的消息

msg := amqp.Publishing{

Body: []byte(fmt.Sprintf("Message %d", msgCount)),

}

// 发布消息到队列

err = ch.Publish(

"",             // 交换机名称(留空表示默认交换机)

"my-queue",  // 队列名称

false,       // 是否为强制性消息

false,       // 是否为立即确认

msg,         // 消息

)

if err != nil {

log.Fatalf("Failed to publish message: %s", err)

}

// 每 5 秒发送一条消息

time.Sleep(5 time.Second)

// 递增消息计数

msgCount++

}

}

创建一个名为 consumer.go 的文件来接收消息:

1

2

3

4

5

6

7

8

9

10

11

12

package main

import (

"context"

"fmt"

"log"

"os"

"github.com/streadway/amqp"

)

func main() {

以上就是如何在 Golang 框架中集成 RabbitMQ 消息队列?的详细内容,更多请关注其它相关文章!