1、集群原理简介
1.1、什么是集群?什么是分区?
集群简单的说就是将同一个服务部署在不同的机器上,从而提高服务的横向扩展能力。
分区就是将数据分布在多个实例(服务器)上,让每一个实例都只存储一部分数据,从而达到增大总的存储数据量的效果。
1.2、为什么要实用集群?
为什么要实用集群呢?主从+哨兵模式不是已经很好了吗,已经高可用了吗?
但是主从+哨兵虽然解决了高可用问题,但是没有解决数据分区存储问题。因为我们存储的数据量大小取决于主服务器的存储容量。那么集群模式将数据分区存储就是为了实现数据存储量可以横向扩展。
1.3、数据分区的优点与缺点?
优点
- 1、性能提升
- 单机Redis的网络I/O能力和计算能力是有限的,将请求分发到多台机器,充分利用多台机器的计算能力和带宽,有助于Redis总体的服务能力。
- 2、存储能力横向扩展
- 即使Redis的存储能力已经能满足大部分需求,但是随着key的数量不断增加,单台机器受限于机器本身的存储容量,将数据分散到多台机器存储使得Redis服务可以横向扩展。
缺点
- 1、管理更加复杂
- Redis数据分散到多台机器,管理起来自然会更加的复杂。还涉及到数据迁移等工作,增大了操作难度。
- 2、分散后的数据节点宕机使得集群缺少部分数据(可以使用主