单纯的master-slave不能称之为集群,只能叫做读写分离。此案例只针对master为单点服务,且程序端写死master为可写,slave为只读。若master宕机则不可用,若主从未开启持久化,不要立刻重启master否则会flush掉slave的数据。此方案适用于master需要停机而不让内存的数据丢失。

若集群为高可用方案如sentinel,则无需手动切换,sentinel自动触发故障转移,无需客户端触发操作。

环境描述:

主redis:119.29.36.237 6379

主redis:119.29.36.237 6380

一、主从配置

1、将主从redis配置文件redis.conf中的aemonize no 改为 yes

daemonize yes
pidfile /var/run/redis_6379.pid
port 6379

dir /var/redis/6379

2、修改从redis配置文件redis.conf中的port 6379 改为 6380,添加slaveof 119.29.36.237  6379

daemonize yes
slaveof 119.29.36.237 6379
pidfile /var/run/redis_6380.pid
port 6380

创建文件   mkdir  -p  /var/redis/6379  /var/redis-slave/6380

3、启动主从服务

主redis:

redis-server  /etc/redis/6379.conf

从redis:

redis-server  /etc/redis/slave.conf

4、测试数据同步

主redis:

redis-cli  -p 6379
127.0.0.1:6379> KEYS *
(empty list or set)
127.0.0.1:6379> set name  bat
OK
127.0.0.1:6379> get name
"bat"

从redis:

redis-cli -h 127.0.0.1 -p 6380
127.0.0.1:6380> get name
"bat"

5、默认是读写分离的

在从redis:

127.0.0.1:6380> set car bmw
(error) READONLY You can't write against a read only slave.

二、主从切换

1、停止主redis

#ps aux |grep  redis
root      2931  0.0  0.1  35088  1816 ?        Ssl  11:05   0:00 redis-server *:6379              
root      2937  0.0  0.1  35088  1808 ?        Ssl  11:05   0:00 redis-server *:6380               
root      2947  0.0  0.0  10800   968 pts/2    S+   11:07   0:00 redis-cli -p 6379
root      2951  0.0  0.0  10800   972 pts/0    S+   11:08   0:00 redis-cli -h 127.0.0.1 -p 6380
root      2956  0.0  0.0   5504   724 pts/3    S+   11:09   0:00 grep redis
#kill  2931

#redis-cli -p 6379
Could not connect to Redis at 127.0.0.1:6379: Connection refused

2、将在从上将从redis设成主redis

# redis-cli -p 6380 slaveof NO ONE
OK

3、测试从redis是否切换从主redis

#redis-cli -p 6380

127.0.0.1:6380> KEYS *
1) "name"
127.0.0.1:6380> get name
"bat"
127.0.0.1:6380> set car bmw

OK

127.0.0.1:6380> set  person  man
OK
127.0.0.1:6380> kEYS *
1) "name"
2) "person"
3) "car"

4、原来的主redis恢复正常了,要重新切换回去

1)将现在的主redis的数据进行保存

#redis-cli -p 6380

127.0.0.1:6380> KEYS *
1) "name"
2) "person"
3) "car"
127.0.0.1:6380> save
OK

2)将现在的主redis根目录下dump.rdb文件拷贝覆盖到原来主redis的根目录

cp  /var/redis-slave/6380/dump.rdb   /var/redis/6379/
cp: overwrite `/var/redis/6379/dump.rdb'? y

3)启动原来的主redis

redis-server  /etc/redis/6379.conf

4)在现在的主redis中切换

# redis-cli -p 6380 slaveof 119.29.36.237 6379
OK

测试是否切换成功

redis-cli  -p 6379
127.0.0.1:6379> KEYS *
1) "person"
2) "car"
3) "name"
127.0.0.1:6379> set test  master
OK
127.0.0.1:6379> KEYS *
1) "person"
2) "car"
3) "name"
4) "test"


127.0.0.1:6380> kEYS *
1) "test"
2) "name"
3) "car"
4) "person"
127.0.0.1:6380> set test slave
(error) READONLY You can't write against a read only slave.

redis 非集群的主从配置及切换的更多相关文章

  1. redis集群(主从配置)

    市面上太多kv的缓存,最常用的就属memcache了,但是memcache存在单点问题,不过小日本有复制版本,但是使用的人比较少,redis的出现让kv内存存储的想法成为现实.今天主要内容便是redi ...

  2. Redis Cluster集群搭建与配置

    Redis Cluster是一种服务器sharding分片技术,关于Redis的集群方案应该怎么做,请参考我的另一篇博客http://www.cnblogs.com/xckk/p/6134655.ht ...

  3. redis搭建集群和主从

    说明 Redis集群至少需要3个节点,来支持投票容错机制,每个节点都有从节点,所有最少是6个服务(3个主3个从) 因为集群内置了16384个slot(哈希槽),并且把所有的物理节点映射到了这16384 ...

  4. Redis 集群_主从配置_哨兵模式

    首先:slaveof 可以在[从]服务器启动一个service服务,直接将[从]服务器定义为[从Redis] redis-server --slaveof <master-ip> < ...

  5. Redis集群_主从配置

    链接地址http://www.2cto.com/database/201502/377069.html 收藏备用. Redis主从配置(Master-Slave) 一. Redis Replicati ...

  6. Redis cluster 集群部署和配置

    目录 一.集群简介 cluster介绍 cluster原理 cluster特点 应用场景 二.集群部署 环境介绍 节点部署 启动集群 三.集群测试 一.集群简介 cluster介绍 redis clu ...

  7. MySql集群FAQ----mysql主从配置与集群区别、集群中需要多少台计算机呢?为什么? 等

    抽取一部分显示在这里,如下, What's the difference in using Clustervs using replication? 在复制系统中,一个MySQL主服务器会更新一个或多 ...

  8. 【Spring系列】Spring mvc整合redis(非集群)

    一.在pom.xml中增加redis需要的jar包 <!--spring redis相关jar包--> <dependency> <groupId>redis.cl ...

  9. MongoDB ReplacaSet & Sharding集群安装 配置 和 非集群情况的安装 配置 -摘自网络

    单台机器做sharding --单机配置集群服务(Sharding) --shard1_1 mongod --install --serviceName MongoDBServerShard1 --s ...

随机推荐

  1. U3D自定义Inspector项未触发保存事件的解决方案

    1.问题描述与解决方案 1.1.说明 应该只有起步做U3D编辑器插件的部分同行需要了解本文. 该问题源于在做UI插件的时候,发现Inspector面板上手动修改值后,没有触发U3D编辑器本身的修改事件 ...

  2. 自己通过Cygwin编译的windows下的redis3.2.6

    采用方法:https://my.oschina.net/maxid/blog/186506 方法中在3.2.6未找到src/redis.h文件 未修改 方法中 /deps/hiredis/net.c ...

  3. 【JS复习笔记】03 继承

    关于继承 好吧,说到底JS还是原型继承的,而不是类继承.所以在这个上面要经常用到prototype去继承另一个对象. 所有的构造器函数都约定命名为首字母大写的形式,并且不以首字母大写的形式拼写任何其它 ...

  4. u-boot移植总结(三)(转)S3C2440对Nand Flash操作和电路原理(基于K9F2G08U0A)

    S3C2440对Nand Flash操作和电路原理(基于K9F2G08U0A) 转载自:http://www.cnblogs.com/idle_man/archive/2010/12/23/19153 ...

  5. 安全协议:SSL、TSL、SSH概述

    SSL(Secure Socket Layer--安全套接字层):为网络通信安全以及数据完整性提供保障的一种安全协议,在TCP/IP的传输层对网络连接进行加密: TSL(Transport Layer ...

  6. mysql存储过程性能监控和分析

    公司当前版本的系统大量的使用了存储过程,有些复杂的过程套过程,一个主调用者可能最多调用其它几十个小的业务逻辑和判断,不要说这么做很不合理,在大陆,目前至少30%的证券交易系统代码都是用存储过程写业务逻 ...

  7. 【GOF23设计模式】命令模式

    来源:http://www.bjsxt.com/ 一.[GOF23设计模式]_命令模式.数据库事务机制底层架构实现.撤销和回复 package com.test.command; public cla ...

  8. 桂电在linux、Mac OS环境下使用出校器(支持2.14)

    这是guetsec学长在三院科协学长所抓包逆向分析1.81版出校器的基础上,用python写的一款为Mac和linux环境开发的出校器. 最后我做了略微修改,支持暂时最新版本2.14.下面有直接从源码 ...

  9. (九)play之yabe项目【发表博文】

    (九)play之yabe项目[发表博文] 博客分类: 框架@play framework   发表一篇博文 填充管理页面 从主页链接到管理页面时,只简单显示了登陆用户的名称 现在对显示的内容加以丰富 ...

  10. Jquery学习—jquery的事件

    1.Jquery事件1:one 1)one() 方法是为所选的元素绑定一个仅出发一次的处理函数,调用格式 one(type,[data],fn) 2)其中参数type是事件类型,即需要触发什么类型的事 ...