Sentinel Tunnel is a tool that allows you using the Redis Sentinel capabilities, without any code modifications to your application.
Redis Sentinel provides high availability (HA) for Redis. In practical terms this means that using Sentinel you can create a Redis deployment that tolerates certain kinds of failures without human intervention. For more information about Redis Sentinel refer to: https://redis.io/topics/sentinel.
Connecting an application to a Sentinel-managed Redis deployment is usually done with a Sentinel-aware Redis client. While most Redis clients do support Sentinel, the application needs to call a specialized connection management interface of the client to use it. When one wishes to migrate to a Sentinel-enabled Redis deployment, she/he must modify the application to use Sentinel-based connection management. Moreover, when the application uses a Redis client that does not provide support for Sentinel, the migration becomes that much more complex because it also requires replacing the entire client library.
Sentinel Tunnel (ST) discovers the current Redis master via Sentinel, and creates a TCP tunnel between a local port on the client computer to the master. When the master fails, ST disconnects your client's connection. When the client reconnects, ST rediscovers the current master via Sentinel and provides the new address. The following diagram illustrates that:
+----------------------------------------------------------+ _,-'*'-,_
| +---------------------------------------+ | _,-._ (_ o v # _)
| | +--------+ | +----------+ | +----------+ _,-' * `-._ (_'-,_,-'_)
| |Application code | Redis | | | Sentinel | | | Redis | + (_ O # _) (_'|,_,|'_)
| |(uses regular connections) | client +<--->+ Tunnel +<----->+ Sentinel +<--+---->(_`-._ ^ _,-'_) '-,_,-'
| | +--------+ | +----------+ | +----------+ | | (_`|._`|'_,|'_)
| +---------------------------------------+ | +----------+ | (_`|._`|'_,|'_)
| Application node | +----------+ `-._`|'_,-'
+----------------------------------------------------------+ `-'
Make sure you have a working Go environment - see the installation instructions here.
To install sentinel_tunnel
, run:
$ go get github.com/RedisLabs/sentinel_tunnel
Make sure your PATH
includes the $GOPATH/bin
directory so your commands can be easily used:
$ export PATH=$PATH:$GOPATH/bin
The code contains an example configuration file named sentinel_tunnel_configuration_example.json
. The configuration file is a json file that contains the following information:
- The Sentinels addresses list
- The list of databases and their corresponding local port
For example, the following config file contains two Sentinel addresses and two databases. When the client connects to the local port 12345
it actually connect to db1
.
{
"sentinels": [
"127.0.0.1:26381",
"127.0.0.1:26382",
"127.0.0.1:26383"
],
"databases": [
{
"name": "my_redis_master",
"port": 36381
},
{
"name": "my_redis_master2",
"port": 36382
}
]
}
In order to run sentinel_tunnel
:
$ ./sentinel_tunnel <config_file_path>