redis debug命令详解



redis debug命令提供了几个非常实用的debug功能,本文介绍下re免费云主机域名dis下的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

相关推荐: Oracle 逻辑管理模式

逻辑空间管理: 本地管理表空间: (默认值) 数据库使用表空间本身中的位图块来管理扩展区。 因此,本地管理空间需要预留表空间的一部分用于位图块,记录区空间的使用情况。 在一个表空间中, 数据库可以使用自动段空间管理(ASSM)或手动段空间管理(MSSM)来管理…

免责声明:本站发布的图片视频文字,以转载和分享为主,文章观点不代表本站立场,本站不承担相关法律责任;如果涉及侵权请联系邮箱:360163164@qq.com举报,并提供相关证据,经查实将立刻删除涉嫌侵权内容。

(0)
打赏 微信扫一扫 微信扫一扫
上一篇 01/01 21:35
下一篇 01/01 21:57