docker实现redis主从复制

为什么要使用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]

推荐阅读更多精彩内容