Слияние кода завершено, страница обновится автоматически
package outbox
import (
"context"
"github.com/go-redis/redis/v8"
)
// MessageTracker 消息追踪
type MessageTracker interface {
HasProcessed(msgID string) (exist bool, err error)
MarkAsProcessed(msgID string) (err error)
}
// NewRedisMessageTracker 创建基于redis做的消息追踪,用于幂等操作
func NewRedisMessageTracker(rd *redis.Client, hashKey string) MessageTracker {
return &redisMessageTracker{
redis: rd,
}
}
type redisMessageTracker struct {
redis *redis.Client
hashKey string
}
func (t *redisMessageTracker) HasProcessed(msgID string) (exist bool, err error) {
exist, err = t.redis.HExists(context.Background(), t.hashKey, msgID).Result()
return
}
func (t *redisMessageTracker) MarkAsProcessed(msgID string) (err error) {
err = t.redis.HSet(context.Background(), t.hashKey, msgID, "1").Err()
return
}
Вы можете оставить комментарий после Вход в систему
Неприемлемый контент может быть отображен здесь и не будет показан на странице. Вы можете проверить и изменить его с помощью соответствующей функции редактирования.
Если вы подтверждаете, что содержание не содержит непристойной лексики/перенаправления на рекламу/насилия/вульгарной порнографии/нарушений/пиратства/ложного/незначительного или незаконного контента, связанного с национальными законами и предписаниями, вы можете нажать «Отправить» для подачи апелляции, и мы обработаем ее как можно скорее.
Опубликовать ( 0 )