redis主从搭建和分片集群搭建

redis主从搭建

搭建一主一从:

下载安装redis:两台机器都需要操作

  1. redis下载地址 https://redis.io/download
  2. tar -zxvf redis-5.0.5.tar.gz
  3. mv redis-5.0.5 redis
  4. cd redis
  5. make
  6. cd src
  7. make install
  8. cd ..
  9. mkdir bin
  10. mv src/redis* bin/

修改master redis.conf:

#开启守护线程,后台启动
daemonize yes  
# 开启远程访问
bind 0.0.0.0
# 关闭保护模式
protected-mode no

修改slave redis.conf

#开启守护线程,后台启动
daemonize yes  
# 开启远程访问
bind 0.0.0.0
# 关闭保护模式
protected-mode no
# 配置主redis ip port
replicaof 39.96.204.209 6379

两天机器分别启动redis

cd bin
./redis-server ../redis.conf

进入master客户端:

./redis-cli
127.0.0.1:6379> set weijie 666

进入slave客户端

127.0.0.1:6379> get weijie
"666"

127.0.0.1:6379> set weijie 222
(error) READONLY You can't write against a read only replica.

#Slaver向Master发送ping命令,Master的响应pong命令
127.0.0.1:6379> ping
PONG

如果出现该值,则说明主从搭建成功!!!

权限认证

修改master redis.conf:
配置主redis密码

requirepass 123456

修改slaver redis.conf,配置从redis的master密码

masterauth 123456

重启master slaver机器的redis,写入和读取测试

master中:

127.0.0.1:6379> info replication
127.0.0.1:6379> set jie
(error) ERR wrong number of arguments for 'set' command
127.0.0.1:6379> set jie 666
(error) NOAUTH Authentication required.
127.0.0.1:6379> auth 123456
OK
127.0.0.1:6379> set jie 666
OK

slaver中:

127.0.0.1:6379> info replication
127.0.0.1:6379> get jie
"666"

配置成功!!!

理解主从复制原理、同步数据集

redis 2.8以前:只能支持全量同步+命令传播,slave发送sync命令给master --> master生成rdb文件以及缓冲区所有写命令给slave --> salve清空数据解释rdb文件,保存数据一致。

缓冲区是对redis的一种保护机制,redis会将写命令保存在缓冲区,然后再取出执行,有AOF缓冲区、AOF重写缓冲区(解决重写期间数据不一致问题)、输出缓冲区

AOF 缓冲区的作用:目的是维持主线程 AOF 文件的正常写入,保证在重写阶段,AOF 文件写入的逻辑不变。

AOF 重写缓存区作用:目的是记录 AOF 重写开始之后的键增删改的命令。
解释:https://www.v2ex.com/t/193687

在这里插入图片描述

redis 2.8以后:全量同步+增量同步,从第一次连上master --> 全量同步 --> 断线重连触发全量同步、增量同步(master 判断runid是否一致),除此之外都是增量同步。
在这里插入图片描述

全量同步三个阶段:

  1. 同步快照阶段:master创建并发送快照RDB给slave --> slave载入解析RDB,master同时将此阶段所产生的新的写命令存储到缓冲区。
  2. 同步写缓冲阶段:master向slave同步缓冲区的命令
  3. 同步增量阶段:master向slave同步写命令
    在这里插入图片描述

增量同步:

  1. Redis增量同步主要值slave完成初始化后开始正常工作时,master发生的写操作同步到slave的过程。
  2. 通常情况下,master每执行一个写命令就会向slave发送相同的写命令,然后slave接受并执行

心跳检测

在命令传播阶段,从服务器默认会以每秒一次的频率向主服务器发送命令。
主要作用有三个:

  1. 检测主从的连接状态
  2. 辅助实现min-slaves,Redis可以通过配置防止主服务器在不安全的情况下执行写命令,配置信息(min-slaves-to-writ 3 min-slaves-max-lag 10 )表示从服务器的数量少于3个,或者三个从服务器的延迟(lag)值都大于或等于10
    秒时,主服务器将拒绝执行写命令。
  3. 检测命令丢失,补发命令

redis哨兵模式

哨兵是Redis高可用解决方案:
由于一个或多个sentinel实例组成sentinel集群可以监视一个或多个主服务器和多个从服务器。
当主服务器进入下线状态时,sentinel可以将该主服务器下的某一从服务器升级为主服务器继续提供服务,从而保证redis的高可用。

redis的sentinel系统用于管理多个redis服务器,该系统主要执行三个任务:监控、提醒、自动故障转移。

1、监控(Monitoring): Redis Sentinel实时监控主服务器和从服务器运行状态,并且实现自动切换。

2、提醒(Notification):当被监控的某个 Redis 服务器出现问题时, Redis Sentinel 可以向系统管理员发送通知, 也可以通过 API 向其他程序发送通知。

3、自动故障转移(Automatic failover): 当一个主服务器不能正常工作时,Redis Sentinel 可以将一个从服务器升级为主服务器, 并对其他从服务器进行配置,让它们使用新的主服务器。当应用程序连接Redis 服务器时, Redis Sentinel会告之新的主服务器地址和端口。

部署方案

在这里插入图片描述

搭建配置

slaves是自动发现,所以你没必要明确指定slaves

预留:后期补充

哨兵模式原理

建立连接

sentinel是一个特殊的redis服务器,不会进行持久化,sentinel实例启动后,每个sentinel会创建2个连向主服务器的网络连接。

命令连接:用于向主服务器发送命令,并接收响应
订阅连接:用于订阅主服务器的 sentinel:hello频道
!在这里插入图片描述

获取主服务器信息

Sentinel默认每10s一次,向被监控的主服务器发送info命令,获取主服务器和其下属从服务器的信息

127.0.0.1:6379> info
# Server
redis_version:5.0.5
os:Linux 3.10.0-229.el7.x86_64 x86_64
run_id:a4e06ab61b4116660aa37b85079ed482b0b695b1
# Replication
role:master
connected_slaves:2
slave0:ip=127.0.0.1,port=6380,state=online,offset=1571684,lag=1
slave1:ip=127.0.0.1,port=6381,state=online,offset=1571551,lag=1
master_replid:366322125dd7dc9bc95ed3467cfec841c112e207
master_replid2:0000000000000000000000000000000000000000
master_repl_offset:1571684
second_repl_offset:-1
repl_backlog_active:1
repl_backlog_size:1048576
repl_backlog_first_byte_offset
获取从服务器信息

当sentinel发现主服务器有新的从服务器出现时,sentinel会向从服务器建立命令连接和订阅连接了,在命令连接建立之后,sentinel还是默认10s一次,向从服务器发送info命令,并记录从服务器信息
在这里插入图片描述
向主服务器和从服务器发送消息(以订阅的方式)

哨兵模式后期搭建成功后再记录!

redis分配集群搭建

redis 3.0之后,Redis官方提供了完整的集群解决方案。
方案去中心化的方式,包括:sharding(分片)、replication(分区)、failover(故障转移)。称为redisCluster。

redis 5.0前采用redis-trib进行集群的创建和管理,需要ruby支持
redis 5.0可以直接使用redis-cli进行集群的创建和管理。

下面开始集群的搭建:redis 版本:5.0.5
搭建效果:在这里插入图片描述
在这里插入图片描述

1.编译安装

tar -zxvf redis-5.0.5.tar.gz
mkdir redis-cluster
cd redis-cluster
mkdir 7001
cd ..
cd redis-5.0.5/src
make install PREFIX=/home/weijie/redis-cluster/7001

查看7001目录下出现bin目录,则按照成功

2.集群配置

配置准备

cd redis-cluster
cd 7001
#引用配置文件
cp /home/weijie/redis-5.0.5/redis.conf ./

修改配置

#修改配置文件
vim redis.conf
#修改端口
port=7001
#关闭保护模式
protected-mode no
#后台启动
daemonize yes
#禁用bind ip 端口
#bind 127.0.0.1 ::1
#开启集群模式
cluster-enabled yes

集群配置准备

cd redis-cluster
 cp -r 7001 7002
 cp -r 7001 7003
 cp -r 7001 7004
 cp -r 7001 7005
 cp -r 7001 7006
 拷贝完后,修改其他redis.conf对应的端口号,其他参数不用动

配置启动脚本

cd redis-cluster
vim start.sh

start.sh内容如下

cd /home/weijie/redis-cluster

cd 7001
./bin/redis-server redis.conf

cd ..
cd 7002
./bin/redis-server redis.conf

cd ..
cd 7003
./bin/redis-server redis.conf

cd ..
cd 7004
./bin/redis-server redis.conf

cd ..
cd 7005
./bin/redis-server redis.conf

cd ..
cd 7006
./bin/redis-server redis.conf

stop.sh内容如下

kill -9 `ps -ef|grep redis-server | awk '{print $2}'

赋脚本写和执行的权限
chmod u+x start.sh
chmod u+x stop.sh

启动脚本:sh start.sh
在这里插入图片描述
启动成功!

创建redis集群:

./redis-cli --cluster create 127.0.0.1:7001 127.0.0.1:7002 127.0.0.1:7003 127.0.0.1:7004 127.0.0.1:7005 127.0.0.1:7006 --cluster-replicas 1

在这里插入图片描述

进入客户端:

cd 7001/bin
# -c 表示集群模式客户端
./redis-cli -h 127.0.0.1 -p 7001 -c
# 查看集群信息
cluster nodes

在这里插入图片描述

写入测试:
在这里插入图片描述
发现数据分片到7003,然后自动调整到7003

集群搭建完成!!!

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值