1 Star 0 Fork 0

NilOrganization / outbox

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
克隆/下载
message_tracker.go 848 Bytes
一键复制 编辑 原始数据 按行查看 历史
Keng 提交于 2020-10-08 13:58 . add message tracker
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
}
Go
1
https://gitee.com/nilorg/outbox.git
git@gitee.com:nilorg/outbox.git
nilorg
outbox
outbox
master

搜索帮助