redis5.0.7主从模式

前言:本文先分享下如何搭建redis的主从模式配置,以及主从模式配置的注意事项。后续会继续分享如何实现一个高可用的redis服务,redis的集群搭建。

环境:

centOS

redis5.0.7

安装:
1yum install gcc-c++

  • 安装环境

2wget http://download.redis.io/releases/redis-5.0.7.tar.gz

  • 获取压缩包
  • 我的安装路径:/usr/local/redis

3tar -zxvf redis-4.0.2.tar.gz

  • 解压

4cd redis-4.0.2

  • 切换到对应目录

5make

自此,redis已经安装成功

6./src/redis-server redis.conf

  • 启动redis,指定配置文件

服务启动成功如下:

7Ctrl+c

  • 退出当前服务
  • 由于不是以守护线程的方式去启动,所以需要Ctrl+c停止服务

8vi redis.conf

  • 修改配置文件
  • daemonize no 修改为 daemonize yes ,以守护线程启动

9./src/redis-server redis.conf

  • 再次启动redis

10ps -ef |grep redis

  • 查看redis服务

11./src/redis-cli

  • 启动客户端链接
  • 键入info,查看当前redis信息
  • 键入shutdown 停止redis服务

单机redis就安装和调试完了。

redis 主从模式配置

主从模式: redis的主从模式,使用异步复制,slave节点异步从master节点复制数据,master节点提供读写服务,slave节点只提供读服务(这个是默认配置,可以通过修改配置文件 slave-read-only 控制)。master节点可以有多个从节点。配置一个slave节点只需要在redis.conf文件中指定 slaveof master-ip master-port 即可。

本示例:一个master节点有两个slave节点

配置:
1cd /usr/local/redis/redis-4.0.2

  • 切换到当前redis安装路径

2 mkdir config

  • 新建一个文件夹,存放redis的配置文件

3,在config下,新建三个配置文件,如下:

cd config

vi master-6739.conf

bind  0.0.0.0(当前主机ip)

port 6379

logfile "6379.log"

dbfilename "dump-6379.rdb"

daemonize yes

rdbcompression yes

vi slave-6380.conf

bind 0.0.0.0

port 6380

logfile "6380.log"

dbfilename "dump-6380.rdb"

daemonize yes

rdbcompression yes

slaveof 192.168.81.135 6379

vi slave-6381.conf

bind 0.0.0.0

port 6381

logfile "6381.log"

dbfilename "dump-6381.rdb"

daemonize yes

rdbcompression yes

slaveof 192.168.81.135 6379

master-6739.conf,为主节点配置文件,slave-6380.confslave-6381.conf为从节点配置文件
在从节点的配置文件中使用:slaveof 指定master节点

4,启动三台reids服务

[root@localhost redis-4.0.2]# ./src/redis-server config/master-6379.conf

[root@localhost redis-4.0.2]# ./src/redis-server config/slave-6380.conf

[root@localhost redis-4.0.2]# ./src/redis-server config/slave-6381.conf

查看一下redis服务

测试主从模式

a,先分别连上三台Redis服务,获取keyname的值,通过-p 指定连接那个端口的redis服务

[root@localhost redis-4.0.2]# ./src/redis-cli -p 6379

127.0.0.1:6379> get name

(nil)

[root@localhost redis-4.0.2]# ./src/redis-cli -p 6380

127.0.0.1:6380> get name

(nil)

[root@localhost redis-4.0.2]# ./src/redis-cli -p 6381

127.0.0.1:6381> get name

(nil)

#获取的值都为空

b,给master节点set一个key

[root@localhost redis-4.0.2]# ./src/redis-cli -p 6379

127.0.0.1:6379> set name cmy

OK

127.0.0.1:6379> get name

"cmy"

cslave节点直接读取keyname的值

[root@localhost redis-4.0.2]# ./src/redis-cli -p 6380

127.0.0.1:6380> get name

"cmy"

[root@localhost redis-4.0.2]# ./src/redis-cli -p 6381

127.0.0.1:6381> get name

"cmy"

dslave节点只提供读服务,不能进行写入操作

127.0.0.1:6381> set age 23

(error) READONLY You can't write against a read only slave.

注意
使用主从模式时应注意matser节点的持久化操作,matser节点在未使用持久化的情况详情下如果宕机,并自动重新拉起服务,从服务器会出现丢失数据的情况。

首先,禁止matser服务持久化

127.0.0.1:6379> CONFIG SET save ""

OK

master节点set一个值

127.0.0.1:6379> set age 23

OK

slave节点可以getage的值

127.0.0.1:6380> get age

"23"

关掉master节点服务

127.0.0.1:6379> shutdown

not connected>

slave节点此时仍可以getage的值

127.0.0.1:6380> get age

"23"

重启master服务,此时获取不到age的值

[root@localhost redis-4.0.2]# ./src/redis-server config/master-6379.conf

[root@localhost redis-4.0.2]# ./src/redis-cli -p 6379

127.0.0.1:6379> get age

(nil)

slave节点此时在获取age的值为空,数据丢失

[root@localhost redis-4.0.2]# ./src/redis-cli -p 6380

127.0.0.1:6380> get age

(nil)

进入cli查看主从信息

info replication

数据丢失的原因:因为master服务挂了之后,重启服务后,slave节点会与master节点进行一次完整的重同步操作,所以由于master节点没有持久化,就导致slave节点上的数据也会丢失掉。所以在配置了Redis的主从模式的时候,应该打开主服务器的持久化功能。

到这,redis的主从模式就已经完成了

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值