redis主从复制、读写分离、主从切换

当数据量变得庞大的时候,读写分离还是很有必要的。同时避免一个redis服务宕机,导致应用宕机的情况,我们启用sentinel(哨兵)服务,实现主从切换的功能。

1. Master&Slave是什么?

也就是我们所说的主从复制,主机数据更新后根据配置和策略,自动同步到备机

的master/slaver机制,Master以写为主,Slave以读为主。

2. 它能干嘛?

       1、读写分离;

       2、容灾恢复。

3. 怎么玩?

       1、配从(库)不配主(库);

       2、从库配置:slaveof [主库IP] [主库端口];

           补充:每次slave与master断开后,都需要重新连接,除非你配置进redis.conf文件;

扫描二维码关注公众号,回复: 5758639 查看本文章

                      键入info replication 可以查看redis主从信息。

       3、修改配置文件细节操作


redis提供了一个master,多个slave的服务:

准备三个redis服务,依次命名文件夹子master,slave1,slave2,Slave只能读不能写,这里为在测试机上,不干扰原来的redis服务,我们master使用6000端口。

master配置文件redis.conf:

port 6000
requirepass 123456

slave1修改配置文件redis1.conf:

port 6001
slaveof 127.0.0.1 6000
masterauth 123456
requirepass 123456

slave2修改配置redis2.conf:

port 6002
slaveof 127.0.0.1 6000
masterauth 123456
requirepass 123456

requirepass是认证密码,应该之后要作为主从切换,所以建议所有的密码都一致,masterauth是从机对主机验证时,所需的密码。

启动主机master:

redis-server redis.conf

启动从机slave1,slave2:

redis-server redis1.conf
redis-server redis2.conf

输入:

ps -ef |grep redis
root      6617     1  0 18:34 ?        00:00:01 redis-server *:6000    
root      6647     1  0 18:43 ?        00:00:00 redis-server *:6001     
root      6653     1  0 18:43 ?        00:00:00 redis-server *:6002     
root      6658  6570  0 18:43 pts/0    00:00:00 grep redis

可以看到主从机的redis已经相应启动!


接下来我们来验证下 主从复制和读写分离:

master:

[root@localhost master]# redis-cli -p 6000
127.0.0.1:6000> auth 123456
OK
127.0.0.1:6000> set test chenqm
OK

slave1:

[root@localhost slave2]# redis-cli -p 6001
127.0.0.1:6001> auth 123456
OK
127.0.0.1:6001> get test
"chenqm"

slave2:

[root@localhost slave2]# redis-cli -p 6002
127.0.0.1:6002> auth 123456
OK
127.0.0.1:6002> get test
"chenqm"

可以看到主机执行写命令,从机能同步主机的值,主从复制,读写分离就实现了!


但是万一主机挂了怎么办,这是个麻烦事情,所以redis提供了一个sentinel(哨兵),以此来实现主从切换的功能,类似与zookeeper。

我们配置两个sentinel进程:

vi sentinel.conf:

port 26379
sentinel monitor mymaster 127.0.0.1 6000 2
<br>sentinel auth-pass mymaster 123456

vi sentinel.conf:

port 26479
sentinel monitor mymaster 127.0.0.1 6000 2
sentinel auth-pass mymaster 123456

启动sentinel服务(到对应的目录执行相应的命令):

redis-sentinel sentinel.conf &(&加不加都可)
# 或者
redis-server sentinel.conf --sentinel
[7014] 11 Jan 19:42:30.918 # +monitor master mymaster 127.0.0.1 6000 quorum 2
[7014] 11 Jan 19:42:30.923 * +slave slave 127.0.0.1:6002 127.0.0.1 6002 @ mymaster 127.0.0.1 6000
[7014] 11 Jan 19:42:30.925 * +slave slave 127.0.0.1:6001 127.0.0.1 6002 @ mymaster 127.0.0.1 6000

从对应的日志观察到,一个master服务,两个slave服务

我们现在来kill master进程:

[root@localhost slave1]# ps -ef|grep redis
root      6960     1  0 19:29 ?        00:00:02 redis-server *:6000   
root      6968     1  0 19:30 ?        00:00:01 redis-server *:6001    
root      6975     1  0 19:30 ?        00:00:01 redis-server *:6002    
root      7014  6570  0 19:42 pts/0    00:00:01 redis-server *:26479                
root      7017  6789  0 19:42 pts/5    00:00:01 redis-server *:26379                
root      7021  6729  0 19:46 pts/3    00:00:00 grep redis
[root@localhost slave1]# kill -9 6960

 我们观察日志:

[7014] 11 Jan 19:43:41.463 # +sdown master mymaster 127.0.0.1 6000
[7014] 11 Jan 19:46:42.379 # +switch-master mymaster 127.0.0.1 6000 127.0.0.1 6001

master切换了,当6000端口的这个服务重启的时候,他会变成6001端口服务的slave!

因为sentinel在切换master的时候,会把对应的sentinel.conf和redis.conf文件的配置修改。

1、上一个Slave可以是下一个Slave的Master,Slave同样可以接收其他slaves的连接和同步请求,那么该slave作为了链条中下一个slave的Master,如此可以有效减轻Master的写压力。如果slave中途变更转向,会清除之前的数据,重新建立最新的。

2、当Master挂掉后,Slave可键入命令 slaveof no one使当前redis停止与其他Master redis数据同步,转成Master redis。

期间我们还需要关注的一个问题:sentinel服务本身也不是万能的,也会宕机,所以我们还得部署sentinel集群,象我这样多启动几个sentinel。

关注这个配置:

# 后面数字2,是指当有两个及以上的sentinel服务检测到master宕机,才会去执行主从切换的功能,slave投票看让谁接替成为主机,得票数多少后成为主机。
sentinel monitor mymaster(被监控数据库名) 127.0.0.1 6000 2

猜你喜欢

转载自blog.csdn.net/hjing123/article/details/88641746