1 В избранное 0 Ответвления 0

OSCHINA-MIRROR/nilorg-outbox

Присоединиться к Gitlife
Откройте для себя и примите участие в публичных проектах с открытым исходным кодом с участием более 10 миллионов разработчиков. Приватные репозитории также полностью бесплатны :)
Присоединиться бесплатно
Клонировать/Скачать
message_tracker.go 848
Копировать Редактировать Web IDE Исходные данные Просмотреть построчно История
Kevin Отправлено 08.10.2020 08:58 122a9e0
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 )

Вы можете оставить комментарий после Вход в систему

1
https://api.gitlife.ru/oschina-mirror/nilorg-outbox.git
git@api.gitlife.ru:oschina-mirror/nilorg-outbox.git
oschina-mirror
nilorg-outbox
nilorg-outbox
master