You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

89 lines
2.5 KiB

This file contains ambiguous Unicode characters!

This file contains ambiguous Unicode characters that may be confused with others in your current locale. If your use case is intentional and legitimate, you can safely ignore this warning. Use the Escape button to highlight these characters.

package work_queue
import (
amqp "github.com/rabbitmq/amqp091-go"
"goskeleton/app/global/variable"
"goskeleton/app/utils/rabbitmq/error_record"
)
// CreateProducer 创建一个生产者
func CreateProducer() (*producer, error) {
// 获取配置信息
conn, err := amqp.Dial(variable.ConfigYml.GetString("RabbitMq.WorkQueue.Addr"))
queueName := variable.ConfigYml.GetString("RabbitMq.WorkQueue.QueueName")
durable := variable.ConfigYml.GetBool("RabbitMq.WorkQueue.Durable")
if err != nil {
variable.ZapLog.Error(err.Error())
return nil, err
}
prod := &producer{
connect: conn,
queueName: queueName,
durable: durable,
}
return prod, nil
}
// 定义一个消息队列结构体helloworld 模型
type producer struct {
connect *amqp.Connection
queueName string
durable bool
occurError error
}
func (p *producer) Send(data string) bool {
// 获取一个频道
ch, err := p.connect.Channel()
p.occurError = error_record.ErrorDeal(err)
defer func() {
_ = ch.Close()
}()
// 声明消息队列
_, err = ch.QueueDeclare(
p.queueName, // 队列名称
p.durable, //队列是否持久化false模式数据全部处于内存true会保存在erlang自带数据库但是影响速度
!p.durable, //生产者、消费者全部断开时是否删除队列。一般来说,数据需要持久化,就不删除;非持久化,就删除
false, //是否私有队列false标识允许多个 consumer 向该队列投递消息true 表示独占
false, // 队列如果已经在服务器声明,设置为 true ,否则设置为 false
nil, // 相关参数
)
p.occurError = error_record.ErrorDeal(err)
// 如果队列的声明是持久化的,那么消息也设置为持久化
msgPersistent := amqp.Transient
if p.durable {
msgPersistent = amqp.Persistent
}
// 投递消息
if err == nil {
err = ch.Publish(
"", // helloworld 、workqueue 模式设置为空字符串,表示使用默认交换机
p.queueName, // 注意:简单模式 key 表示队列名称
false,
false,
amqp.Publishing{
DeliveryMode: msgPersistent, //消息是否持久化,这里与保持保持一致即可
ContentType: "text/plain",
Body: []byte(data),
})
}
p.occurError = error_record.ErrorDeal(err)
if p.occurError != nil { // 发生错误,返回 false
return false
} else {
return true
}
}
// Close 发送完毕手动关闭这样不影响send多次发送数据
func (p *producer) Close() {
_ = p.connect.Close()
}