正文
redis数据丢失排查,redis 数据丢失
小程序:扫一扫查出行
【扫一扫了解最新限行尾号】
复制小程序
【扫一扫了解最新限行尾号】
复制小程序
Redis常见延迟问题排查手册!附33条优化建议
注意, Redis的主动过期的定时任务,也是在Redis主线程中执行的 ,也就是说如果在执行主动过期的过程中,出现了需要大量删除过期key的情况,那么在业务访问时,必须等这个过期任务执行结束,才可以处理业务请求。
所幸Linux提供了很好的工具来诊断这个问题,所以当延迟疑似是swap引起的,最简单的办法就是使用Linux提供的工具去确诊。
运维层面,我们需要对机器的各项指标增加监控,包括网络流量,在达到阈值时提前报警,及时与业务确认并扩容。
为什么往Redis写入的数据会突然消失了?
1、内部文件损坏。redis是一个keyvalue存储系统,和Memcached类似,在该文件使用过程中,数据无故消失的话,是因为文件包内部文件损坏导致的,出现这种情况的话,应把redis系统文件包重新下载一遍即可。
2、因为 master - slave的复制是异步 的(客户端发送给redis,主节点数据同步到内存中后就返回成功了) 所以可能有部分数据还没复制到slave,master就宕机了,此时master内存中的数据也没了,这些部分数据就丢失了。
3、所以说,这是缓存的一个最基本的概念,数据是会过期的,要么是你自己设置个过期时间,要么是redis自己给干掉。
4、如果在使用Redis时,取出一个Map后发现Map中的数据没有了,可能是以下原因导致: Redis中的Map被误删除:在某些情况下,可能会出现误删除Map的情况,例如在操作时误执行了DEL命令或者使用了错误的键名。
5、持久化 通常,Redis将数据存储于内存中,或被配置为使用虚拟内存。通过两种方式可以实现数据持久化:使用截图的方式,将内存中的数据不断写入磁盘;或使用类似MySQL的日志方式,记录每次更新的日志。
6、而脑裂最直接的影响,就是客户端不知道应该往哪个主节点写入数据,结果就是不同的客户端会往不同的主节点上写入数据。而且,严重的话,脑裂会进一步导致数据丢失。
redis会在一段时间内丢失数据,为什么
因为 master - slave的复制是异步 的(客户端发送给redis,主节点数据同步到内存中后就返回成功了) 所以可能有部分数据还没复制到slave,master就宕机了,此时master内存中的数据也没了,这些部分数据就丢失了。
还有一个问题就是数据明明过期了,怎么还占用着内存?这些问题主要是因为Redis内部的一些机制所导致的,接下来我将展开说说Redis的两个最基础机制。Redis 过期策略 Redis 过期策略是: 定期删除+惰性删除 。
所以说,这是缓存的一个最基本的概念,数据是会过期的,要么是你自己设置个过期时间,要么是redis自己给干掉。
redis数据丢失排查的介绍就聊到这里吧,感谢你花时间阅读本站内容,更多关于redis 数据丢失、redis数据丢失排查的信息别忘了在本站进行查找喔。