关于redis的主从复制
redis主从复制需要注意的一个问题
这两天我朋友在使用redis偶尔会遇见一个问题,就是所有的缓存莫名其妙会不见,找了好久都没找到,他一直以为
有人错误执行了什么命令
他跟我说的时候我估计是主从复制的问题,我没具体使用过redis,我猜想可能是master莫名其妙down掉以后,监控
系统自动重启redis,然后执行了sync命令,导致slave的数据都被冲掉了,回来尝试了一下,果然会有这个问题
具体实验如下:
使用docker启动三台机子,一台172.17.0.2作为slave,一台172.17.0.3作为master,一台172.17.0.4模拟
客户端进行操作
在172.17.0.3启动master
redis-server &
redis-cli
set myky 12 ##插入一段数据
OK
在172.17.0.2启动一个slave redis
redis-server --slaveof 172.17.0.3 6379 ##启动一个server并且座位172.17.0.3的slave
在172.17.0.4启动客户端,连入slave
redis-cli -h 172.17.0.3 -p 6379
get myky
"12"
显示一切正常
这个时候kill掉master
kill -s 9 47
然后再重新启动master
redis-server &
get myky
nil
连入slave
redis-cli -h 172.17.0.2 -p 6379
get myky
(nil)
这个时候就会发现slave没有数据了
因为在master重启的时候跟slave有一次sync操作,而master这个时候是没有数据的
当然数据可能也会存在,因为redis是有备份机制的,具体看自己的设置的,不得不吐槽我朋友公司的开发人员,
估计不看log,也不了解redis的机制
关于redis的主从复制的更多相关文章
- redis的主从复制配置
		
redis的主从复制配置 一. 原理 Redis的主从复制功能非常强大,一个master可以拥有多个slave,而一个slave又可以拥有多个slave,如此下去,形成了强大的多级服务器集群架 ...
 - Redis总结(三)Redis 的主从复制
		
接着上一篇,前面两篇我总结了<Redis总结(一)Redis安装>和<Redis总结(二)C#中如何使用redis> 所以这一篇,会讲讲Redis 的主从复制以及C#中如何调用 ...
 - 实现Redis的主从复制配置
		
实现Redis的主从复制配置比较简单,而且容易明白. 下图是要配置的主从复制结构图: 1.说明 Redis主从复制中一个主服务可以有多个从服务,一个从服务可以有多个从服务. 配置比较简单,只需要更改r ...
 - redis的主从复制部署和使用
		
reids一种key-value的缓存数据库目前非常流行的被使用在很多场景,比如在数据库读写遇到瓶颈时缓存且读写分离会大大提升这块的性能,下面我就说说redis的主从复制 首先需要启动多个redis实 ...
 - redis实现主从复制-单机测试
		
一.redis实现主从复制-单机测试1.安装redis tar -zxvf redis-2.8.4.tar.gzcd redis-2.8.4make && make install2. ...
 - 8. redis的主从复制和sentinal
		
一. redis主从复制(读写分离) redis的主从复制分为两类节点:1个master和多个slave,master进行读写操作,slav进行只读操作 启动步骤: 主节点照常启动,slave节点启动 ...
 - Redis基础学习(五)—Redis的主从复制
		
一.概述 Redis的主从复制策略是通过其持久化的rdb文件来实现的,其过程是先dump出rdb文件,将rdb文件全量传输给slave,然后再将dump后的操作实时同步到slave中.让从服务 ...
 - Redis配置主从复制
		
Redis配置主从复制 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.操作环境介绍 1>.操作系统环境 [root@node101.yinzhengjie.org.cn ...
 - Redis的主从复制(十一)
		
1>什么是主从复制 持久化保证了即使redis服务重启也不会丢失数据,因为redis服务重启后(在使用aof和rdb方式时,如果redis重启,则数据从aof文件加载)会将硬盘上持久化的数据恢复 ...
 - 基于配置文件的redis的主从复制
		
redis中主从复制有很多种配置方法: 1. 使用配置文件即为redis.conf来配置 在随从redis中配置 # slaveof {masterHost} {MastePort} slaveof ...
 
随机推荐
- sudo apt-get install apache2 php7.0 php7.0-mysql mysql-server
			
sudo apt-get install apache2 php7.0 php7.0-mysql mysql-server sudo apt-get install libapache2-mod-ph ...
 - Oracle----SQL语句积累 (Oracle 导入 dmp文件)
			
Oracle----SQL语句积累 (Oracle 导入 dmp文件) Oracle SQL PL 导入dum文件 1.数据库DBA权限: 注意:这个是在cmd命令行中直接输入,不需要进入Oracl ...
 - android view:布局优化
			
今天在图书馆看了一个android性能优化. 关于布局优化有几个小技巧: 1.尽量减少布局的嵌套,而使用相对布局,这样的话会减少布局对象的创建,并且可以再事件传递的时候减少传递嵌套. 2.使用incl ...
 - go语言文件操作,这期资料比较详细( 欢迎加入go语言群: 218160862 )
			
go语言文件操作,这期资料比较详细 欢迎加入go语言群: go语言深圳群 golang深圳 218160862 点击加入 文件操作 func Open(name string) (file *File ...
 - Unity3D–RectTransfrom 记录笔记
			
一.基本要点 部分来源:http://www.2fz1.com/post/unity-ugui-recttransform/ RectTransform继承于Trasnfrom , 在Trasnfor ...
 - cs231n笔记:最优化
			
本节是cs231学习笔记:最优化,并介绍了梯度下降方法,然后应用到逻辑回归中 引言 在上一节线性分类器中提到,分类方法主要有两部分组成:1.基于参数的评分函数.能够将样本映射到类别的分值.2.损失函数 ...
 - 关于 Record & TList 的一点吐槽
			
需求是把record 保存在TList中,并可以随时改变TList中Items的各项值. 代码很简单: MyRec = record MyStr: string; constructor Create ...
 - js传递json格式对象到服务器
			
var message = new Object();message.event = "test";message.params = new Object();message.pa ...
 - jquery里面的循环的用法
			
下面提一下jQuery的each方法的几种常用的用法 Js代码 var arr = [ "one", "two", "three", &qu ...
 - 反射【类Class、成员变量Field、方法Method】
			
Class<?> c = Class.forName("main.Main$MyClass"); //要包名+类名 Object obj = c.newInstance ...