为什么要使用redis集群模式?
Redis可以说是内存数据库,mysql的数据库是真实存储在硬盘里的,因此,redis的读取速度要比mysql快得多,同时,redis也是最好的cache工具,一般情况下,数据存储量大小不能超过主机的内存,我们说的高并发场景很容易造成,数据溢出乃至性能瓶颈,显然单机无法满足我们的业务需求了,就需要做集群,如果你的网站每天PV两也就几百,几千,几万的话, 那就没必要了!
什么是Redis主从复制集群?
简单理解就是讲Redis主服务器的数据同步到其他的redis服务器上,前者成为主节点(master),后者称之为从节点(Slave),数据的复制都是单向的,因为都是主节点复制到从节点,默认情况下,每台服务器都是主节点,且每个主节点可以有多个从节点,但是每个从节点只能有一个主节点(master)
那么说到redis主从复制有什么作用呢?
数据冗余:主从复制实现了redis的数据的热备份,是持久化之外的数据冗余方式
故障恢复:当主节点故障时,可以由从节点提供服务,快速的故障转移
负载均衡:可以在主从复制的基础上,配合读写分离,由主节点负责写,从节点负责读取数据,从而分担服务器的负载压力,大大提高redis的并发量。
1.首先使用docker启动3个redis容器服务,分别使用到6379、6380、6381端口
docker run -d -p 6379:6379 --name redis-master redis
docker run -d -p 6380:6380 --name redis-salve1 redis
docker run -d -p 6381:6381 --name redis-salve2 redis
2.配置redis集群
使用如下命令查看容器内网的ip地址等信息
docker ps
docker inspect salve2(容器id) 172.17.0.4 b50080ab10dc
docker inspect salve1(容器id) 172.17.0.3 fb6b7d854870
docker inspect master(容器id) 172.17.0.2 1db1517ca75e
3. 在从节点上配置主节点
docker exec -it fb6b7d854870 redis-cli
SLAVEOF 172.17.0.2 6379
docker exec -it b50080ab10dc redis-cli
SLAVEOF 172.17.0.2 6379
查看主节点的配置
docker exec -it 1db1517ca75e redis-cli
info replication
result[
role:master
connected_slaves:2
slave0:ip=172.17.0.3,port=6379,state=online,offset=182,lag=1
slave1:ip=172.17.0.4,port=6379,state=online,offset=182,lag=1
master_replid:820802d97f029a2ed914f1d020e72366708fbbdc
master_replid2:0000000000000000000000000000000000000000
master_repl_offset:182
second_repl_offset:-1
repl_backlog_active:1
repl_backlog_size:1048576
repl_backlog_first_byte_offset:1
repl_backlog_histlen:182
]
以上就是所有docker配置nginx的步骤了。要注意的是docker redis中无默认的redis.conf 如果配置可挂载外部文件以配置形式启动
例如: https://www.jianshu.com/p/fe7c2e1310c9
运行服务
docker run -it --name redis-master -v /root/redis/redis-master.conf:/usr/local/etc/redis/redis.conf -d -p 6300:6379 redis /bin/bash
进入容器
docker exec -it redis-master bash
加载配置
redis-server /usr/local/etc/redis/redis.conf
测试连接
redis-cli -a <master-password>
4 主从复制测试
1⃣️
docker exec -it 1db1517ca75e redis-cli
set name 'zhangkai'
exit
docker exec -it b50080ab10dc redis-cli
get name
"zhangkai"
2⃣️ down 掉主节点
docker stop 1db1517ca75e
1db1517ca75e
result [当我们的主机宕机的时候,从机不会上位。]
3⃣️ 我们重启主机
result[重新作为主节点]
4⃣️如果我们有一台从机宕机了,然后又连接上了,这个时候从机会自动连接到主机嘛?如果连接上了,那主机在从机宕机的这段时间做的写命令,从机会复制过去吗?
result[如果从机宕机,到后来连接成功时,主机在这其中做的写命令,从机会复制过来的,保证数据的一致。这里注意的是得保证配置中该节点仍是master的从节点]
5⃣️我们有6380和6381两台从机连接到一台端口为6379的服务器上,那如果有很多从机都连到一台主机的话,那主机的压力是不是太大啦?那我们试着让6381能不能连到6380上呢?
result[然后在6381里输入 slaveof 172.17.0.3 6380]