preload scripts and use evalsha to call them

This commit is contained in:
finley
2024-10-04 15:27:59 +08:00
parent 7354e38ce9
commit 705b9721d8
5 changed files with 161 additions and 12 deletions

View File

@@ -340,4 +340,54 @@ func TestDelayQueue_FetchLimit(t *testing.T) {
if len(ids3) == 0 {
t.Error("should get some messages, after consumption")
}
}
func TestDelayQueue_ScriptPreload(t *testing.T) {
redisCli := redis.NewClient(&redis.Options{
Addr: "127.0.0.1:6379",
})
redisCli.FlushDB(context.Background())
size := 101 // use a prime number may found some hidden bugs ^_^
retryCount := 3
mu := sync.Mutex{}
deliveryCount := make(map[string]int)
cb := func(s string) bool {
mu.Lock()
deliveryCount[s]++
mu.Unlock()
return true
}
queue := NewQueue("test", redisCli, cb).
WithFetchInterval(time.Millisecond * 50).
WithMaxConsumeDuration(0).
WithLogger(log.New(os.Stderr, "[DelayQueue]", log.LstdFlags)).
WithConcurrent(4).
WithScriptPreload(true)
for i := 0; i < size; i++ {
err := queue.SendDelayMsg(strconv.Itoa(i), 0, WithRetryCount(retryCount), WithMsgTTL(time.Hour))
if err != nil {
t.Error(err)
}
}
for i := 0; i < 2*size; i++ {
if i == 2 {
// random clean script cache
redisCli.ScriptFlush(context.Background())
}
ids, err := queue.beforeConsume()
if err != nil {
t.Errorf("consume error: %v", err)
return
}
for _, id := range ids {
queue.callback(id)
}
queue.afterConsume()
}
for k, v := range deliveryCount {
if v != 1 {
t.Errorf("expect 1 delivery, actual %d. key: %s", v, k)
}
}
}