liuyong00 2019-12-30
运行Redis Sentinel将需要以下两个可执行文件之一:redis-sentinel或redis-server。
使用redis-sentinel可执行文件,你可以使用以下命令运行Redis Sentinel:
1 redis-sentinel /path/to/sentinel.conf
其中“ /path/to/sentinel.conf”是Sentinel配置文件的路径。
借助redis-server可执行文件,你可以使用以下命令运行Redis Sentinel:
1 redis-server /path/to/sentinel.conf --sentinel
请注意,在两种情况下,都必须提供指向Sentinel配置文件的链接。 运行Redis Sentinel时需要使用配置文件,以便在系统重新启动时保存系统的当前状态。
Redis Sentinel配置文件示例如下所示:
sentinel monitor mymaster 127.0.0.1 6379 2 sentinel down-after-milliseconds mymaster 60000 sentinel failover-timeout mymaster 180000 sentinel parallel-syncs mymaster 1 sentinel monitor resque 192.168.1.3 6380 4 sentinel down-after-milliseconds resque 10000 sentinel failover-timeout resque 180000 sentinel parallel-syncs resque 5
在此示例中,行``Sentinel Monitor <主组名称> <ip> <端口> <仲裁>‘‘在给定的IP地址和端口号上定义了一个名为master-group-name的Sentinel主节点。 法定参数是必须就主节点不可访问这一事实达成共识的Sentinel进程数。
其他行定义以下设置:
“毫秒后下降”:定义将主节点视为不可达之后经过的毫秒数。
“ Sentinel故障转移超时”:定义Sentinel进程将尝试投票主节点的故障转移的时间。
“ sentinel parallel-syncs”:定义可以在故障转移后同时重新配置为使用同一主节点的从节点的数量。
对于Java程序员而言,坏消息是Redis Sentinel与Java兼容。 但是,好消息是Redis Sentinel和Java可以使用诸如Redisson的框架轻松地协同工作,Redisson是Redis的Java客户端,它使用许多熟悉的Java编程语言构造。 Redisson提供了数十种以分布式方式实现的Java对象,集合,锁和服务,从而允许用户在不同的应用程序和服务器之间共享它们。
以下代码示例演示了如何在Java中开始使用Redis Sentinel。 设置配置文件和Redisson客户端后,该应用程序执行一些基本操作以演示将Redis与Java一起使用的可行性。
package redis.demo; import org.redisson.Redisson; import org.redisson.api.RBucket; import org.redisson.api.RedissonClient; /** * Redis Sentinel Java example * */ public class Application { public static void main( String[] args ) { Config config = new Config(); config.useSentinelServers() .addSentinelAddress("redis://127.0.0.1:6379") .setMasterName("myMaster"); RedissonClient redisson = Redisson.create(config); // perform operations // implements java.util.concurrent.ConcurrentMap RMap<String, String> map = redisson.getMap("simpleMap"); map.put("mapKey", "This is a map value"); String mapValue = map.get("mapKey"); System.out.println("stored map value: " + mapValue); // implements java.util.concurrent.locks.Lock RLock lock = redisson.getLock("simpleLock"); lock.lock(); try { // do some actions } finally { lock.unlock(); } redisson.shutdown(); } }
总结
请务必注意,Redisson用户必须指定至少一台Redis Sentinel服务器和至少一台Redis主节点。 启动后,Redisson继续监视Redis Sentinel中可用的主节点和从节点以及Sentinel节点的列表。 这意味着用户无需监视Redis拓扑的状态即可处理故障转移情况; Redisson独自完成了此任务。