redis bigKey问题

bigKey的产生

1、使用String存储了大文件的二进制。

2、使用集合没有考虑到数据的规模,或者规模的增长。

3、哈希中冗余了大量键值对。

bigKey问题

1、操作大key时会阻塞线程:redis是单线程。

2、网络阻塞:在网络中占用大量网络流量。

3、阻塞工作线程:其他命令不能正常执行。

如何查看?

1、使用自带的--bigkeys,但是会影响主线程。

2、使用自带的scan命令。

3、使用开源工具redis-rdb-tools等分析RDB文件。

如何处理?

1、分割:将一个大的key分成多个小key。

2、手动清理:redis4.0之后使用unlink 启动异步线程去清理一个或多个指定key。

3、采用合适的数据结构。

相关推荐
whm27775 分钟前
Visual Basic 建立数据库
开发语言·数据库·visual studio
檀越剑指大厂26 分钟前
【数据库系列】倒排索引(Inverted Index)
数据库·inverted-index
闲人编程32 分钟前
权限系统设计与RBAC实现
java·网络·数据库·rbac·权限·codecapsule
花月C36 分钟前
基于Redis的BitMap数据结构实现签到业务
数据结构·数据库·redis
hgz071038 分钟前
数据库事务
数据库·mysql
老华带你飞44 分钟前
二手商城|基于springboot 二手商城系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·后端·spring
@小码农1 小时前
6547网:2025年9月 Python等级考试(三级)真题及答案
服务器·数据库·python
梦里不知身是客111 小时前
redis的缓存击穿原因
redis·缓存·bootstrap
老华带你飞1 小时前
酒店预约|基于springboot 酒店预约系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·后端·spring
会飞的土拨鼠呀1 小时前
如何查询MySQL的CPU使用率突然变高
数据库·mysql