前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Redis-脚本-获取某个大key的值

Redis-脚本-获取某个大key的值

作者头像
用户5522200
发布2019-06-02 15:23:52
1.5K0
发布2019-06-02 15:23:52
举报
文章被收录于专栏:lindalinda

1、背景

在redis中,对于一个很大的key,例如hash类型,直接查看其值会非常慢,于是想到写个脚本通过增量迭代来获取

2、具体的脚本如下:

功能:扫描redis某个key里面的所有元素 使用方法:python bigkey_save_values.py "zyyset" "*" 100

3、python脚本实现如下:

代码语言:javascript
复制
#!/usr/bin/env python
# -*- coding: UTF-8 -*-  
#功能:扫描某个key里面的所有元素
#使用方法:python bigkey_save_values.py "zyyset" "m*" 100
#如需获取全部的元素:python bigkey_save_values.py "zyyset" "*" 100
__author__ = "lcl"  
import sys
import redis 
import os 
  
pool=redis.ConnectionPool(host='192.168.225.128',port=6379,db=0)  
r = redis.StrictRedis(connection_pool=pool)  
#指定key
key = sys.argv[1]
#扫描匹配值
match = sys.argv[2]
#每次匹配数量
count = sys.argv[3]
#总数量
total = 0
#获取当前路径
path = os.getcwd()
keytype = r.type(key)
print "key的类型为%s" % (keytype)
#扫描到的key输出的文件
txt = path+"/%s.txt" % (key)

#打开文件
#f = open(txt,"w")
def list_iter(name):
    list_count = r.llen(key)
    for index in range(list_count):
        yield r.lindex(key, index)

if keytype=='list':
    f = open(txt,"w")
    for item in list_iter(key):
#将匹配到对应key中的member/score输出到文件中
        f.write("%s %s" % (item,"\n"))
        total = total+1
    f.close

elif keytype=='hash':
    f = open(txt,"w")
    for item in r.hscan_iter(key,match = match,count = count):
#将匹配到对应key中的member/score输出到文件中
        f.write("%s %s" % (item,"\n"))
        total = total+1
    f.close
 
elif keytype=='set':
    f = open(txt,"w")
    for item in r.sscan_iter(key,match = match,count = count):
        f.write("%s %s" % (item,"\n"))
        total = total+1
    f.close

elif keytype=='zset':
    f = open(txt,"w")
    for item in r.zscan_iter(key,match = match,count = count):
        f.write("%s %s" % (item,"\n"))
        total = total+1
    f.close

else:
    print("key的类型为string,value为:" + r.get(key))

print "key:%s的match:%s的数量为:%d" % (key,match,total)
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1、背景
  • 2、具体的脚本如下:
  • 3、python脚本实现如下:
相关产品与服务
云数据库 Redis
腾讯云数据库 Redis(TencentDB for Redis)是腾讯云打造的兼容 Redis 协议的缓存和存储服务。丰富的数据结构能帮助您完成不同类型的业务场景开发。支持主从热备,提供自动容灾切换、数据备份、故障迁移、实例监控、在线扩容、数据回档等全套的数据库服务。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档