温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

redis debug命令详解

发布时间:2020-08-18 23:18:03 来源:ITPUB博客 阅读:265 作者:chenfeng 栏目:关系型数据库

redis debug命令提供了几个非常实用的debug功能,本文介绍下redis下的debug命令。


debug segment

让redis发生段错误,如果开启了coredump,则会产生core文件。这个命令实现很简单,直接往一个非法地址上写数据。


*((char*)-1) = 'x';

debug oom

申请一大片内存,直接让zmalloc触发oom错误


void *ptr = zmalloc(ULONG_MAX); /* Should trigger an out of memory. */

zfree(ptr);

addReply(c,shared.ok);

debug assert

不多解释


redisAssertWithInfo(c,c->argv[0],1 == 2);


debug reload

save当前的rdb文件,并清空当前数据库,重新加载rdb,加载与启动时加载类似,加载过程中只能服务部分只读请求(比如info、ping等)


rdbSave();

emptyDb();

rdbLoad();

debug loadaof

清空当前数据库,重新从aof文件里加载数据库


emptyDb();

loadAppendOnlyFile();

debug object

查看一个key内部信息,比如refcount、encoding、serializedlength等,结果如下


Value at:0x7f21b9479850 refcount:1 encoding:raw serializedlength:6 lru:8462202 lru_seconds_idle:215

debug sdslen

查看某个sds当前的信息,当前sds长度,以及可用内存长度,结果如下


key_sds_len:3, key_sds_avail:0, val_sds_len:5, val_sds_avail:0

debug populate

测试利器,快速产生大量的key


127.0.0.1:6379> debug populate 10000

OK

127.0.0.1:6379> dbsize

(integer) 10000

debug digest

对整个数据库的数据,产生一个摘要,可用于验证两个redis数据库数据是否一致


127.0.0.1:6379> debug digest


7164ae8b6730c8bcade46532e5e4a8015d4cccfb


127.0.0.1:6379> debug digest


7164ae8b6730c8bcade46532e5e4a8015d4cccfb


debug sleep

测试利器,用于模拟某个时间开销的命令,比如debug sleep 0.1就相当于执行了一条开销为100ms的命令。


127.0.0.1:6379> debug sleep 1

OK

(1.00s)

debug error

测试利器,模拟一条命令执行失败,发送debug error,redis直接会返回一个错误应答


127.0.0.1:6379> debug error "test"

(error) test


向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI