玩转Redis集群(下)

接上一篇《玩转Redis集群(上)》,咱们来继续玩~

Redis集群操做实践

数据的分布性

wKioL1jBWouwIK0JAADFSCC9LRs672.png

从上面的操做,你能够看到,当存储某一个数据的时候,会分配一个slot,而这个slot从属于某一个Master,也就是说你须要明白,数据是分布的存储在Redis集群当中的。java


在线水平扩容

Redis Cluster有一个很是重要的特色就是能够在线的添加节点,实现不影响业务的水平扩容。在这里,我将会在原来6个redis节点上,再添加2个redis节点。作法和之前一致,注意修改redis.conf,而后在启动800七、8008这2个redis实例。node

wKioL1jBWynSIlw1AAAtrPi5eqc891.png


wKiom1jBW03B5vC3AACQSpX0GUo758.png


wKioL1jBW2nhGjwkAABVgXnJldk477.png

其实,目前虽然启动了新加的2个redis实例,可是它们是不属于集群的。下面,咱们来让它们加入集群中。git


wKiom1jBW47yY6OoAAC_UBSuTwI350.png


./redis-trib.rb add-node 192.168.99.121:8007 192.168.99.121:8006

./redis-trib.rb add-node 新节点 集群中已经存在的节点


在往集群中添加节点A的时候,须要提供一个在集群中已经存在的节点B的信息。由于知道了B的信息,就知道了整个集群的信息。为何这么说呢,来,咱们看一个文件,你就知道了。github

wKiom1jBW-LijIu_AADh3t7Ptzg879.png

要知道集群中的每个节点都有这么一个文件,存储着集群中每个节点的信息:节点的角色、节点的ID、链接状态、slot范围、IP/PORT信息等。仔细观察图中,你能够发现,新加入的8007节点,实际上被默认为master节点,而且没有slot分配!这说明,新加入的节点如今还不能够存储数据,所以咱们要为新节点分配slot槽。redis

[root@mydream121 bin]# ./redis-trib.rb reshard 192.168.99.121:8001


要知道slot都分配在master上,所以其实咱们要作的就是从集群的masters上进行从新分配。上面的命令须要指定一个master节点进行reshard分片。spring

wKioL1jBXDHj8ktvAACThrpWMj8439.png


图中要为新加入的节点8007分配500个slot,并且分配的方式是"all",all是什么意思呢?all表明从已经存在的全部的master上均匀的分配一部分slot给8007。固然你能够经过"done"来指定某一个master进行分配。注意分配给8007是经过节点ID来指定的。tomcat

wKiom1jBXFjxJpd1AABoB7e9DIE714.png

按照上面的操做,我将8008节点也加入集群中,个人想法是让8008成为8007的从节点。既然是从节点,就不须要分配slot槽。注意到add-node方式加入的节点,默认就是master节点,所以这里咱们得利用replicate指定主节点。bash

[root@mydream121 bin]# ./redis-trib.rb add-node 192.168.99.121:8008 192.168.99.121:8001

wKiom1jBXJPxE3IhAADqFZt8QPM182.png

那么到如今,咱们就在线完成了对Redis集群的水平扩容。那么如何删除节点呢?删除节点时,数据怎么办呢?对于从节点,删除就删除了,并没关系,关键是主节点,由于主节点上有slot。所以,在删除主节点前,咱们要对主节点的slot进行从新分配,完成数据的迁移。这里我就再也不演示了,直接给出命令。session

删除主节点:先reshard + 后del-node
删除从节点:直接del-node

Redis实现Session共享

Redis能够被用于Session共享,不过如今CAS实现单点登陆更容易些。(CAS之后为你们介绍)app

wKioL1jBXNCy75npAABUhyVjheY404.png

不管是Nginx挂了,仍是其中的Tomcat挂掉,都不会丢失Session信息。在实现上,有现成的插件,好比:https://github.com/jcoleman/tomcat-redis-session-manager 

Java操做Redis

在单机Redis环境:Jedis

这个没什么好说的,就是给定IP/PORT实例化Jedis操做便可。

Jedis jedis = new Jedis("192.168.99.121", 8001);


在多台Redis环境:ShardedJedis+ShardedJedisPool

wKioL1jBXSOD9bKKAABja7mHgR0762.png


这是一种切片的方式来操做redis,经过hash而均匀的分配到pool里的redis机器中。

在Redis集群环境:JedisCluster

wKiom1jBXVCwPuJDAAC9YMiQICw820.png


与Spring整合

咱们直接来看配置文件吧!

wKioL1jBXXqz1GyPAACNC1_whOI374.png


同上文Java操做Redis集群的代码对比下,其实XML就是代码的映射。只不过经过spring的方式,帮助咱们配置生成了一个bean:redisCluster。咱们能够经过注入的方式获得redisCluster,而后咱们想干啥就能够干啥,就这么简单~


到这里,redis集群部分整个就结束了,下一篇文章是关于什么的呢,我不告诉你,哈哈~

相关文章
相关标签/搜索