目录
一、Redis集群环境搭建
1、概念
2、主从复制的作用
3、为什么一般使用多台Redis服务器
4、为什么使用集群
5、环境配置
查看当前库的信息:
默认是主机:
演示视频:
需要修改的配置文件内容:
启动单机多服务集群:
二、主从复制之复制原理及手动配置主机
1、一主二从配置
2、使用规则
一、Redis集群环境搭建
1、概念
主从复制,是指将一台Redis服务器的数据,复制到其他的Redis服务器。前者称为主节点(Master/Leader),后者称为从节点(Slave/Follower), 数据的复制是单向的!只能由主节点复制到从节点(主节点以写为主、从节点以读为主);
默认情况下,每台Redis服务器都是主节点,一个主节点可以有0个或者多个从节点,但每个从节点只能由一个主节点;
主从复制,读写分离,我们80%的情况都是在读取数据,减缓服务器压力,在架构中经常使用;
最低配是一主二从;
2、主从复制的作用
数据冗余:主从复制实现了数据的热备份,是持久化之外的一种数据冗余的方式;
故障恢复:当主节点故障时,从节点可以暂时替代主节点提供服务,是一种服务冗余的方式;
负载均衡:在主从复制的基础上,配合读写分离,由主节点进行写操作,从节点进行读操作,分担服务器的负载;尤其是在多读少写的场景下,通过多个从节点分担负载,提高并发量;
高可用(集群)基石:主从复制还是哨兵和集群能够实施的基础;
3、为什么一般使用多台Redis服务器
为防止宕机,一般配置三台Redis服务器,一主二从;
单台Redis服务器内存一般不应该超过20GB,否则赶紧使用集群;
在企业中,主从复制是必须使用的,真实项目中不存在使用单机redis;
默认情况下,每台Redis服务器都是主节点(从节点需要配置),一个主节点可以有个从节点,一个从节点只能属于一个主节点;
4、为什么使用集群
单台服务器难以负载大量的请求;
单台服务器故障率高,系统崩坏概率大;
单台服务器内存容量有限;
5、环境配置
只配置从库,不用配置主库(默认自己就是主库);
查看当前库的信息:
默认是主机:
演示视频:
我们使用的是Windows环境学习的,就不再演示了,狂神的教程:
下面的笔记就直接摘抄了,不再实际演示;
需要修改的配置文件内容:
既然需要启动多个服务,就需要多个配置文件。每个配置文件对应修改以下信息:
- 端口号;
- pid文件名;
- 日志文件名;
- rdb文件名;
启动单机多服务集群:
二、主从复制之复制原理及手动配置主机
1、一主二从配置
默认情况下,每台Redis服务器都是主节点;我们一般情况下只用配置从机就好了;
认老大!一主(79)二从(80,81)
使用SLAVEOF host port就可以为从机配置主机了;
然后主机上也能看到从机的状态:
我们这里是使用命令搭建,是暂时的,真实开发中应该在从机的配置文件中进行配置,这样的话是永久的;
2、使用规则
①从机只能读,不能写,主机可读可写但是多用于写;
②当主机断电宕机后,默认情况下从机的角色不会发生变化 ,集群中只是失去了写操作,当主机恢复以后,又会连接上从机恢复原状;
③当从机断电宕机后,若不是使用配置文件配置的从机,再次启动后作为主机是无法获取之前主机的数据的,若此时重新配置称为从机,又可以获取到主机的所有数据。这里就要提到一个同步原理;
④第二条中提到,默认情况下,主机故障后,不会出现新的主机,有两种方式可以产生新的主机:
如果没有老大了,这个时候能不能选择出来一个老大呢?手动!
如果主机断开了连接,我们可以使用SLAVEOF no one让自己变成主机!其他的节点就可以手动连接到最新的主节点(手动)!如果这个时候老大修复了,那么久重新连接!