redis中bigkey扫描脚本的示例分析
发表于:2025-01-20 作者:千家信息网编辑
千家信息网最后更新 2025年01月20日,这篇文章给大家分享的是有关redis中bigkey扫描脚本的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。我对这个脚本进行了一个压力测试,在redis的内存为15G
千家信息网最后更新 2025年01月20日redis中bigkey扫描脚本的示例分析
这篇文章给大家分享的是有关redis中bigkey扫描脚本的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。
我对这个脚本进行了一个压力测试,在redis的内存为15G,key的数量为2KW,ops为40K到80K之间,在这种情况下,阿里云的脚本完全不能跑成功(估计跑出来的时间以天为单位),主要原因是每确认一个key的情况,就需要与redis交互多次。因此,我对它的脚本进行了改造,加入了pipeline和debug object方法,脚本如下:
import sysimport redis def find_big_key_normal(db_host, db_port, db_password, db_num): client = redis.StrictRedis(host=db_host, port=db_port, password=db_password, db=db_num) i=0 temp = client.scan(cursor=i,count=1000) j =0 while temp[0]>0 : i=temp[0] j=j+len(temp[1]) try: r = client.pipeline(transaction=False) for k in temp[1]: r.debug_object(k) tempA = r.execute() x = 0 for key in tempA: length = key.get("serializedlength") ##type = key.get("encoding") if length > 10240 : type = client.type(temp[1][x]) print temp[1][x], type,length x=x+1 except : print "a execption come" temp = client.scan(cursor=i,count=1000) if __name__ == '__main__': if len(sys.argv) != 4: print 'Usage: python ', sys.argv[0], ' host port password ' exit(1) db_host = sys.argv[1] db_port = sys.argv[2] db_password = sys.argv[3] r = redis.StrictRedis(host=db_host, port=int(db_port), password=db_password) nodecount = 1 keyspace_info = r.info("keyspace") for db in keyspace_info: print 'check ', db, ' ', keyspace_info[db] find_big_key_normal(db_host, db_port, db_password, db.replace("db", ""))
我对上面的脚本同样进行了一个压力测试,在redis的内存为15G,key的数量为2KW,ops为40K到80K之间,在这种情况下:
脚本10分钟跑完,完全可用。
感谢各位的阅读!关于"redis中bigkey扫描脚本的示例分析"这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!
脚本
情况
示例
分析
之间
内存
内容
压力
数量
更多
篇文章
测试
不错
实用
成功
单位
原因
文章
方法
时间
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
网络安全带来的坏处
bvd数据库试用通知
韩国云顶之弈是什么服务器
收购网络安全
软件开发项目实训的目的
stm32软件开发资料
网络安全协议禁用
中级职称单位考核评网络安全
数据库附加错误823
2021网络安全宣传周学习通
nba厂管数据库
金牛区零点软件开发有限公司
三国志2007安卓服务器
5g软件开发工程师做什么
静态方法调用数据库
广东pdu服务器电源价钱多少
python学炒股软件开发
自助购买服务器
我的世界魔光之都服务器
mc龙珠服务器
查看服务器配置的命令
stm32软件开发资料
web服务器安全防御
临海本地软件开发信息推荐
心理网络安全教育教案
淄博华创网络技术有限公司
勘察测绘研究院软件开发
上海树根科技互联网有限公司
网络技术专业测试
深圳软件开发在哪里上班多