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、采用合适的数据结构。

相关推荐
LSL666_2 小时前
1 概述及简单登录(不涉及数据库)
数据库·servlet
q***06475 小时前
MySQL的UPDATE(更新数据)详解
数据库·mysql
8***B6 小时前
MySQL性能
数据库·mysql
q***72196 小时前
oracle使用PLSQL导出表数据
数据库·oracle
数据库生产实战6 小时前
Oracle DG备库日志切换解析,Private strand flush not complete如何理解?(基础知识)
数据库·oracle
百***75746 小时前
从 SQL 语句到数据库操作
数据库·sql·oracle
i***39586 小时前
SQL 注入详解:原理、危害与防范措施
数据库·sql·oracle
m***56727 小时前
Win10下安装 Redis
数据库·redis·缓存
Warren987 小时前
Python自动化测试全栈面试
服务器·网络·数据库·mysql·ubuntu·面试·职场和发展
闲人编程7 小时前
Python的导入系统:模块查找、加载和缓存机制
java·python·缓存·加载器·codecapsule·查找器