Ids
我有一个类型的数组,int64
这是我正在尝试发布的 Nsq 消息。
nsqMsg := st{
Action : "insert",
Ids : Ids
GID : Gids
}
msg, err := json.Marshal(nsqMsg)
if err != nil {
log.Println(err)
return err
}
err = nsqProducer.Publish(TOPIC-NAME, msg)
if err != nil {
log.Println(err)
return err
}
在我的消费者中,我一个接一个地获取每个 ID,并根据我的 ID 从我的数据存储中获取信息。
因此,在获取时,如果我的 CreateObject 方法返回错误,则可能会出现这种情况,因此我通过重新排队 msg(给出错误)来处理这种情况,因此可以重试。
for i := 0; i < len(data.Ids); i++ {
Object, err := X.CreateObject(data.Ids[i)
if err != nil {
requeueMsgData = append(requeueMsgData, data.Ids[i])
continue
}
DataList = append(DataList, Object)
}
if len(requeueMsgData) > 0 {
msg, err := json.Marshal(requeueMsgData)
if err != nil {
log.Println(err)
return err
}
message.Body = msg
message.Requeue(60 * time.Second)
log.Println("error while creating Object", err)
return n
}
那么,这是正确的做法吗?他们在这种情况下有什么缺点吗?再发布一次更好吗?