diff --git a/initalize/rabbitmq.go b/initalize/rabbitmq.go index 7fd3fd06..004524c0 100644 --- a/initalize/rabbitmq.go +++ b/initalize/rabbitmq.go @@ -5,7 +5,7 @@ import ( "crypto/tls" "errors" "fusenapi/constants" - "fusenapi/server/websocket/consumer" + "fusenapi/utils/mq_consumer_factory" "github.com/streadway/amqp" "github.com/zeromicro/go-zero/core/logx" "log" @@ -84,10 +84,10 @@ func (h *RabbitMqHandle) SendMsg(queueName constants.RABBIT_MQ, message []byte) } // 消费消息 -func (h *RabbitMqHandle) Consume(ctx context.Context, queueName constants.RABBIT_MQ, handle consumer.MqHandle) error { +func (h *RabbitMqHandle) Consume(ctx context.Context, queueName constants.RABBIT_MQ, handle mq_consumer_factory.MqHandle) { object, ok := mapMq[queueName] if !ok { - return errors.New("unknown queue") + panic("unknown queue") } go func() { select { @@ -135,5 +135,4 @@ func (h *RabbitMqHandle) Consume(ctx context.Context, queueName constants.RABBIT }(msg) } wait.Wait() - return nil } diff --git a/server/render/consumer/assemble_render_data.go b/server/render/consumer/assemble_render_data.go new file mode 100644 index 00000000..9f3b6187 --- /dev/null +++ b/server/render/consumer/assemble_render_data.go @@ -0,0 +1,12 @@ +package consumer + +import "fmt" + +// 消费渲染需要组装的数据 +type MqConsumerRenderAssemble struct { +} + +func (m *MqConsumerRenderAssemble) Run(data []byte) error { + fmt.Println("收到消息:" + string(data)) + return nil +} diff --git a/server/render/etc/render.yaml b/server/render/etc/render.yaml index 2dba7dc7..30b4cdd7 100644 --- a/server/render/etc/render.yaml +++ b/server/render/etc/render.yaml @@ -5,4 +5,5 @@ SourceMysql: fusentest:XErSYmLELKMnf3Dh@tcp(110.41.19.98:3306)/fusentest Auth: AccessSecret: fusen2023 AccessExpire: 2592000 - RefreshAfter: 1592000 \ No newline at end of file + RefreshAfter: 1592000 +SourceRabbitMq: amqp://rabbit001:rabbit001129@110.41.19.98:5672 \ No newline at end of file diff --git a/server/render/internal/config/config.go b/server/render/internal/config/config.go index 5f9c4816..fa950a01 100644 --- a/server/render/internal/config/config.go +++ b/server/render/internal/config/config.go @@ -2,12 +2,12 @@ package config import ( "fusenapi/server/render/internal/types" - "github.com/zeromicro/go-zero/rest" ) type Config struct { rest.RestConf - SourceMysql string - Auth types.Auth + SourceMysql string + Auth types.Auth + SourceRabbitMq string } diff --git a/server/render/internal/svc/servicecontext.go b/server/render/internal/svc/servicecontext.go index bd083461..79e04e0d 100644 --- a/server/render/internal/svc/servicecontext.go +++ b/server/render/internal/svc/servicecontext.go @@ -18,14 +18,16 @@ type ServiceContext struct { MysqlConn *gorm.DB AllModels *gmodel.AllModelsGen + RabbitMq *initalize.RabbitMqHandle } func NewServiceContext(c config.Config) *ServiceContext { - + initalize.InitRabbitMq(c.SourceRabbitMq, nil) return &ServiceContext{ Config: c, MysqlConn: initalize.InitMysql(c.SourceMysql), AllModels: gmodel.NewAllModels(initalize.InitMysql(c.SourceMysql)), + RabbitMq: initalize.InitRabbitMq(c.SourceRabbitMq, nil), } } diff --git a/server/render/render.go b/server/render/render.go index af3b93f1..1210715d 100644 --- a/server/render/render.go +++ b/server/render/render.go @@ -1,8 +1,11 @@ package main import ( + "context" "flag" "fmt" + "fusenapi/constants" + "fusenapi/server/render/consumer" "net/http" "time" @@ -29,8 +32,12 @@ func main() { defer server.Stop() ctx := svc.NewServiceContext(c) + //消费渲染前组装数据队列 + ctx1 := context.Background() + ctx2, cancel := context.WithCancel(ctx1) + defer cancel() + go ctx.RabbitMq.Consume(ctx2, constants.RABBIT_MQ_ASSEMBLE_RENDER_DATA, &consumer.MqConsumerRenderAssemble{}) handler.RegisterHandlers(server, ctx) - fmt.Printf("Starting server at %s:%d...\n", c.Host, c.Port) server.Start() } diff --git a/server/websocket/consumer/consumer.go b/server/websocket/consumer/consumer.go index 69363bf0..16a7c8a9 100644 --- a/server/websocket/consumer/consumer.go +++ b/server/websocket/consumer/consumer.go @@ -2,10 +2,6 @@ package consumer import "fmt" -type MqHandle interface { - Run(data []byte) error -} - // 消费渲染结果数据 type MqConsumerRenderResult struct { } diff --git a/server/websocket/internal/logic/ws_render_image_logic.go b/server/websocket/internal/logic/ws_render_image_logic.go index 5be69551..e4881bba 100644 --- a/server/websocket/internal/logic/ws_render_image_logic.go +++ b/server/websocket/internal/logic/ws_render_image_logic.go @@ -22,11 +22,6 @@ type renderImageControlChanItem struct { } // 渲染发送到组装数据组装数据 -type assembleRenderData struct { - TaskId string `json:"task_id"` - RenderData interface{} `json:"render_data"` -} - func (w *wsConnectItem) assembleRenderData(data []byte) { var renderImageData websocket_data.RenderImageReqMsg if err := json.Unmarshal(data, &renderImageData); err != nil { @@ -42,7 +37,7 @@ func (w *wsConnectItem) assembleRenderData(data []byte) { TaskId: taskId, RenderId: renderImageData.RenderId, } - tmpData := assembleRenderData{ + tmpData := websocket_data.AssembleRenderData{ TaskId: taskId, RenderData: renderImageData.RenderData, } diff --git a/utils/mq_consumer_factory/mq.go b/utils/mq_consumer_factory/mq.go new file mode 100644 index 00000000..0f3bc97d --- /dev/null +++ b/utils/mq_consumer_factory/mq.go @@ -0,0 +1,6 @@ +package mq_consumer_factory + +// 消费mq消息要实现对应Run方法 +type MqHandle interface { + Run(data []byte) error +} diff --git a/utils/websocket_data/render_data.go b/utils/websocket_data/render_data.go index 2e6c6a9e..3ec0067a 100644 --- a/utils/websocket_data/render_data.go +++ b/utils/websocket_data/render_data.go @@ -19,3 +19,9 @@ type ThirdPartyLoginRspMsg struct { //websocket三方登录的通知数据 Token string `json:"token"` } + +// 发送到渲染组装的mq数据 +type AssembleRenderData struct { + TaskId string `json:"task_id"` + RenderData interface{} `json:"render_data"` +}