开发者社区> 怀听> 正文

阿里云Redis集群子实例Key查看

简介: 摘要: 阿里云Redis集群有多个节点,用户需要查看每个子节点具体有哪些key 。本文主要介绍了如何使用阿里云云数据库Redis特有的iscan命令查看子节点上所有key的情况。 阿里云Redis集群有多个节点,用户需要查看每个子节点具体有哪些key。
+关注继续查看

阿里云Redis集群有多个节点,用户需要查看每个子节点具体有哪些key。使用keys命令容易导致业务受影响,而scan命令由于集群版的架构问题无法很好的支持。目前阿里云Redis提供了iscan命令用于查看某个节点的key信息。

如果只是想查看每个子实例总的内存和key数目情况可见:阿里云Redis集群子实例内存和key数目查看

安装python客户端

下载python客户端

wget “https://pypi.python.org/packages/68/44/5efe9e98ad83ef5b742ce62a15bea609ed5a0d1caf35b79257ddb324031a/redis-2.10.5.tar.gz#md5=3b26c2b9703b4b56b30a1ad508e31083”

解压安装

tar -xvf redis-2.10.5.tar.gz
cd redis-2.10.5
sudo python setup.py install

命令介绍

# idx为节点的id,从0开始,16到64gb的集群实例为8个节点故idx为0到7,128g 256gb的为16个节点
# 其余参数与官方scan命令含义一致
ISCAN idx cursor [MATCH pattern] [COUNT count]

扫描脚本

import sys
import redis
import time

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 = r.info()['nodecount']
  for node in range(0, nodecount):
     print "============ node ", str(node), " ================"
     cursor = -1
     loop = 0
     while cursor != 0:
       if cursor == -1:
         cursor = 0
       if loop > 10000:
         time.sleep(0.1)
         loop = 0
       loop = loop + 1

       info = r.execute_command("iscan", str(node), str(cursor))
       cursor = info[0]
       key_list = info[1]
       for key in key_list:
         print key

执行脚本

python check_sharding_db host port password > keys.txt 

tail -f keys.txt可以看到其中出现有如下内容:

============ node  0  ================
具体的key1
具体的key2
...

============ node  1  =================

...

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
阿里云ECI如何6秒扩容3000容器实例?
2021年云栖大会现场,阿里云工程师演示了在6秒时间内成功启动3000个ECI,并全部进入到Running状态。本文将为你揭开阿里云ECI是如何做到极速扩容的。
329 0
如何查看pid和key
说明:   PID就是我们partner的简称,以2088开头   KEY就是MD5密钥 1.开放平台查看方式,   选择:[url]https://openhome.alipay.com/platform/keyManage.
540 0
阿里云Redis实例慢查剖析
Redis常见超时原因分析
2606 0
阿里云GPU云服务器抢占式实例大幅度降低GPU云服务器实例成本
阿里云GPU云服务器可以选择抢占式实例(原竞价实例),可以降低GPU服务器成本
114 0
阿里云服务器(Ubuntu)--查看固定程序的进程
1.下面查看java和go语言的程序进程: ps -ef | grep java ps -ef | grep go 2.后台运行go语言程序,并查看go语言进程: nohup go run main.
3284 0
Redis 集群之Redis+Twemproxy方案
Twemproxy 是 Twtter 开源的一个 Redis 和 Memcache 代理服务器,主要用于管理 Redis 和 Memcached 集群,减少与Cache 服务器直接连接的数量。
2173 0
查看远程Redis服务器的版本
版权声明:本文为博主chszs的原创文章,未经博主允许不得转载。 https://blog.csdn.net/chszs/article/details/46379701 查看远程Redis服务器的版本 如何查看远程Redis服务器的版本 作者:chszs,转载需注明。
522 0
阿里云容器服务新建集群优化方案
前言 选择阿里云的容器服务,主要原因是公司主要业务基本都运行在阿里云上。相较自建 kubernetes 集群,容器服务的优势在于部署相对简单,与阿里云 VPC 完美兼容,网络的配置相对简单,而如果使用 kubeadmin 安装部署 kubernetes 集群,除了众所周知的科学上网问题,还有一系列的问题,包括 etcd 、 scheduler 和 controller-manager 的高可用问题等。
1349 0
阿里云部署Hbase集群
安装环境 主机 ip 操作系统 master 10.30.45.239 centos7.4 slave1 10.31.155.33 centos7.4 slave2 10.81.233.67 centos7.4 阿里云3台ecs搭建一个小型的hbase分布式数据存储(这里的ip都是内网)。
1578 0
+关注
怀听
阿里云Redis
11
文章
0
问答
来源圈子
更多
阿里云数据库:帮用户承担一切数据库风险,给您何止是安心!支持关系型数据库:MySQL、SQL Server、PostgreSQL、PPAS(完美兼容Oracle)、自研PB级数据存储的分布式数据库Petadata、自研金融级云数据库OceanBase支持NoSQL数据库:MongoDB、Redis、Memcache更有褚霸、丁奇、德哥、彭立勋、玄惭、叶翔等顶尖数据库专家服务。
+ 订阅
相关文档: 云数据库 OceanBase 版 可信账本数据库 云原生关系型数据库 PolarDB PostgreSQL引擎
文章排行榜
最热
最新
相关电子书
更多
OceanBase 入门到实战教程
立即下载
阿里云图数据库GDB,加速开启“图智”未来.ppt
立即下载
实时数仓Hologres技术实战一本通2.0版(下)
立即下载