hotgo/server/internal/cmd/queue.go

44 lines
1.0 KiB
Go
Raw Normal View History

2022-11-24 23:37:34 +08:00
// Package cmd
// @Link https://github.com/bufanyun/hotgo
// @Copyright Copyright (c) 2023 HotGo CLI
2022-11-24 23:37:34 +08:00
// @Author Ms <133814250@qq.com>
// @License https://github.com/bufanyun/hotgo/blob/master/LICENSE
package cmd
import (
"context"
"github.com/gogf/gf/v2/os/gcmd"
"hotgo/internal/global"
"hotgo/internal/library/queue"
_ "hotgo/internal/queues"
"hotgo/utility/simple"
2022-11-24 23:37:34 +08:00
)
var (
Queue = &gcmd.Command{
Name: "queue",
Brief: "消息队列",
Description: ``,
Func: func(ctx context.Context, parser *gcmd.Parser) (err error) {
// 服务日志处理
queue.Logger().SetHandlers(global.LoggingServeLogHandler)
simple.SafeGo(ctx, func(ctx context.Context) {
queue.Logger().Debug(ctx, "start queue consumer..")
queue.StartConsumersListener(ctx)
queue.Logger().Debug(ctx, "start queue consumer success..")
})
serverWg.Add(1)
// 信号监听
signalListen(ctx, signalHandlerForOverall)
<-serverCloseSignal
queue.Logger().Debug(ctx, "queue successfully closed ..")
serverWg.Done()
2022-11-24 23:37:34 +08:00
return
},
}
)