怎么在Redis里按模式删除数据
发表于:2024-09-23 作者:千家信息网编辑
千家信息网最后更新 2024年09月23日,小编给大家分享一下怎么在Redis里按模式删除数据,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!一台Redis服务器在很短
千家信息网最后更新 2024年09月23日怎么在Redis里按模式删除数据
小编给大家分享一下怎么在Redis里按模式删除数据,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!
一台Redis服务器在很短的时间里消耗了几十个G的内存,最终因为SWAP而宕机。因为这台服务器的社会背景比较复杂,所以一时无法判断犯罪嫌疑人到底是谁。
最开始的直觉是认为肯定有人保存了大体积的数据,于是问题就变成了找出哪些键占用的空间比较大,DBA同事用了redis-rdb-tools等工具来分析数据文件。可惜的是虽然找到了一些大体积的键,但最终都排除了嫌疑,问题似乎陷入了僵局。
在被直觉带入死胡同之后,我们开始调整调查的角度:即便一个键本身占用的空间并不大,但是如果相同模式的键数量很多的话,那么合计起来一样会占用大量空间,于是问题就变成了找出哪些相同模式的键占用的空间比较大。这次我不想用什么工具,而是打算在测试服务器上一边删除可疑键一边查看内存变化情况:
shell> /path/to/redis-cli keys foo:* | xargs /path/to/redis-cli del
悲催的是一运行这个命令服务器就挂了!因为数据太多了,所以KEYS受不了。此时应该使用SCAN,它有游标的概念,每次迭代只涉及很少的数据。
直接在命令行使用SCAN有些麻烦,于是我用了PHP:
setOption(Redis::OPT_SCAN, Redis::SCAN_RETRY);$match = 'foo:*';$count = 10000;while ($keys = $redis->scan($it, $match, $count)) { $redis->del($keys);}?>
在删除的同时注意监控内存变化情况,就能确认问题了:
shell> watch -d -n 1 '/path/to/redis-cli info | grep memory'
至于可疑键的获取,我是瞎蒙的,简单通过MONITOR或者SCAN获取采样数据即可,另外从此案例看,监控键总数的变化幅度是很重要的,从INFO里能拿到它。
以上是"怎么在Redis里按模式删除数据"这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注行业资讯频道!
数据
模式
服务器
空间
问题
服务
内存
篇文章
变化
相同
可疑
体积
内容
命令
工具
情况
直觉
监控
复杂
重要
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
南非服务器租用
数据库实验报告怎么写
成都域百果科技互联网公司
防疫和网络安全视频
数据库的底层存储
外文文献在哪个数据库
连云港游戏软件开发有限公司
组织抽查评估网络安全
深圳无限空间网络技术有限
信号安全工程师和网络安全工程师
网络技术的负面效应
u8数据库服务器失败
河北企业软件开发质量放心可靠
数据库组复制
数据库wow
计算机网络技术主编陈代武
人渣服务器建家
福州天睿网络技术
周村染厂管理软件开发公司
网络技术员前景
神武服务器开多少会出限制
酷狗直播无法连接到服务器
系统版本和数据库版本不一致
奉贤区通用软件开发服务商有哪些
数据库 分类与标签
大公司服务器配置
软件开发 工作能力 专长
宝鸡软件开发市场价
软件开发的美工需要的软件
数据库所在盘符满了