package mq import ( "encoding/json" "mongo.games.com/goserver/core/broker" "mongo.games.com/goserver/core/broker/rabbitmq" "mongo.games.com/goserver/core/logger" "mongo.games.com/game/dbproxy/svc" "mongo.games.com/game/model" "mongo.games.com/game/mq" ) func init() { mq.RegisterSubscriber(model.GameDetailedLogCollName, func(e broker.Event) (err error) { msg := e.Message() if msg != nil { defer func() { e.Ack() }() var log model.GameDetailedLog err = json.Unmarshal(msg.Body, &log) if err != nil { return } logger.Logger.Tracef("mq receive GameDetailedLog:%v", log) c := svc.GameDetailedLogsCollection(log.Platform) if c != nil { err = c.Insert(log) if err != nil { logger.Logger.Tracef("c.Insert(log) err:%v", err.Error()) } } return } return nil }, broker.Queue(model.GameDetailedLogCollName), broker.DisableAutoAck(), rabbitmq.DurableQueue()) }