-
-
Notifications
You must be signed in to change notification settings - Fork 711
Automatic Failover
Lukasz Gut edited this page Dec 4, 2023
·
7 revisions
This page explains how to configure asynq to take advantage of Redis Sentinel to avoid downtime due to Redis failure.
Please read the doc on Redis Sentinel to understand the topic.
Configuring asynq
's Client
and Server
to use Redis Sentinel is simple.
Use RedisFailoverClientOpt
to speicfy the name of your Redis master and addresses of your Redis Sentinels.
var redis = &asynq.RedisFailoverClientOpt{
MasterName: "mymaster",
SentinelAddrs: []string{"localhost:5000", "localhost:5001", "localhost:5002"},
}
And pass this client option to NewClient
and NewServer
to create an instance that uses Redis Sentinels.
client := asynq.NewClient(redis)
// ...
srv := asynq.NewServer(redis, asynq.Config{ Concurrency: 10 })
With this setup, when your Redis master goes down, Sentinels will start a failover process and asynq
will be notified of the new master and background task processing will continue to work 👍.