首页 » 网站推广 » phpnginxredis集群技巧_简单几步玩转Redis集群

phpnginxredis集群技巧_简单几步玩转Redis集群

duote123 2024-11-01 0

扫一扫用手机浏览

文章目录 [+]

数据分布性

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

phpnginxredis集群技巧_简单几步玩转Redis集群

在线水平扩容

phpnginxredis集群技巧_简单几步玩转Redis集群
(图片来自网络侵删)

Redis Cluster有一个非常主要的特点便是可以在线的添加节点,实现不影响业务的水平扩容。
在这里,我将会在原来6个redis节点上,再添加2个redis节点。
做法和以前同等,把稳修正redis.conf,然后在启动8007、8008这2个redis实例。

修正redis.conf配置

启动新添加的2个redis实例

集群状态

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

add-node命令

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

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

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

nodes-xxx.conf

要知道集群中的每一个节点都有这么一个文件,存储着集群中每一个节点的信息:节点的角色、节点的ID、连接状态、slot范围、IP/PORT信息等。
仔细不雅观察图中,你可以创造,新加入的8007节点,实际上被默认为master节点,并且没有slot分配!
这解释,新加入的节点现在还不可以存储数据,因此我们要为新节点分配slot槽。

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

要知道slot都分配在master上,因此实在我们要做的便是从集群的masters上进行重新分配。
上面的命令须要指定一个master节点进行reshard分片。

slot重新分配

图中要为新加入的节点8007分配500个slot,而且分配的办法是\"大众all\"大众,all是什么意思呢?all代表从已经存在的所有的master上均匀的分配一部分slot给8007。
当然你可以通过\公众done\"大众来指定某一个master进行分配。
把稳分配给8007是通过节点ID来指定的。

分配后的集群信息

按照上面的操作,我将8008节点也加入集群中,我的想法是让8008成为8007的从节点。
既然是从节点,就不须要分配slot槽。
把稳到add-node办法加入的节点,默认便是master节点,因此这里我们得利用replicate指定主节点。

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

为从节点指定主节点

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

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

删除从节点:直接del-node

Redis实现Session共享

Redis可以被用于Session共享,不过现在CAS实现单点登录更随意马虎些。
(CAS往后为大家先容)

redis集群存储session信息

不论是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

ShardedJedis办法

这是一种切片的办法来操作redis,通过hash而均匀的分配到pool里的redis机器中。

在Redis集议论况:JedisCluster

JedisCluster

与Spring整合

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

redis集群与Spring整合

同上文Java操作Redis集群的代码比拟下,实在XML便是代码的映射。
只不过通过spring的办法,帮助我们配置天生了一个bean:redisCluster。
我们可以通过注入的办法得到redisCluster,然后我们想干啥就可以干啥,就这么大略~

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

作者:张丰哲

链接:https://www.jianshu.com/p/ee18dbd45d02

來源:简书

简书著作权归作者所有,任何形式的转载都请联系作者得到授权并注明出处。

标签:

相关文章

Python编程从入门到精通,探索编程之美

编程已经成为现代社会的一项基本技能。Python作为一种简单易学、功能强大的编程语言,在我国教育领域备受关注。本文将从Python...

网站推广 2025-03-02 阅读1 评论0

Scum07代码编程之美与适用方法

编程已成为当今社会不可或缺的技能之一。Scum07代码作为一款经典的编程语言,在我国众多程序员中备受推崇。本文将深入解析Scum0...

网站推广 2025-03-02 阅读1 评论0

Linux环境下的前端代码运行优化与步骤

前端技术逐渐成为软件开发的核心。Linux操作系统因其稳定性、安全性、开放性等特点,成为众多开发者和企业青睐的运行环境。本文将从L...

网站推广 2025-03-02 阅读1 评论0