Skip to content

2021年最新版本基于golang的rbmq生产者消费者

Notifications You must be signed in to change notification settings

LonelySally/golang-rbmq-sl

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

8 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

go get github.com/ichunt2019/golang-rbmq-sl

发送消息

详见demo/send.go

消费消息

详见demo/recv.go

说明:

rabbitmq.Recv(rabbitmq.QueueExchange{
		"a_test_0001",
		"a_test_0001",
		"hello_go",
		"direct",
		"amqp://guest:guest@192.168.2.232:5672/",
	},t,3)

第一个参数 QueueExchange说明


	
// 定义队列交换机对象
type QueueExchange struct {
	QuName  string           // 队列名称
	RtKey   string           // key值
	ExName  string           // 交换机名称
	ExType  string           // 交换机类型
	Dns     string           //链接地址
}

第二个参数 type Receiver interface说明

Consumer FailAction
拿到消息后,用户可以处理任务,如果消费成功 返回nil即可,如果处理失败,返回一个自定义error即可 由于消息内部自带消息失败尝试3次机制,3次如果失败后就没必要一直存储在mq,所以此处扩展,可以用作消息补偿和告警
// 定义接收者接口
type Receiver interface {
	Consumer([]byte)    error
	FailAction(error ,[]byte)  error
}

第三个参数:runNusm

runNusm
消息并发数,同时可以处理多少任务 普通任务 设置为1即可 需要并发的设置成3-5即可

需要跟进优化地方

开启多协程的时候,存在并发的解决方案?

消费者监听任务链接断开问题?重连机制?

About

2021年最新版本基于golang的rbmq生产者消费者

Resources

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Go 100.0%