分享

redis debug命令介绍

yuwenge 发表于 2015-6-22 16:27:00 [显示全部楼层] 回帖奖励 阅读模式 关闭右栏 0 13279
问题导读

1.下面介绍了哪些debug命令?
2.总结debug的作用是什么?





redis debug命令提供了几个非常实用的debug功能,本文介绍下redis-2.8.19下的debug命令。
debug segment
让redis发生段错误,如果开启了coredump,则会产生core文件。这个命令实现很简单,直接往一个非法地址上写数据。
[mw_shl_code=bash,true]*((char*)-1) = 'x';[/mw_shl_code]

debug oom
申请一大片内存,直接让zmalloc触发oom错误
[mw_shl_code=bash,true]void *ptr = zmalloc(ULONG_MAX); /* Should trigger an out of memory. */
zfree(ptr);
addReply(c,shared.ok);[/mw_shl_code]

debug assert
不多解释
[mw_shl_code=bash,true]redisAssertWithInfo(c,c->argv[0],1 == 2);[/mw_shl_code]

debug reload
save当前的rdb文件,并清空当前数据库,重新加载rdb,加载与启动时加载类似,加载过程中只能服务部分只读请求(比如info、ping等)
[mw_shl_code=bash,true]rdbSave();
emptyDb();
rdbLoad();[/mw_shl_code]

debug loadaof
清空当前数据库,重新从aof文件里加载数据库
[mw_shl_code=bash,true]emptyDb();
loadAppendOnlyFile();[/mw_shl_code]

debug object
查看一个key内部信息,比如refcount、encoding、serializedlength等,结果如下
[mw_shl_code=bash,true]Value at:0x7f21b9479850 refcount:1 encoding:raw serializedlength:6 lru:8462202 lru_seconds_idle:215[/mw_shl_code]

debug sdslen
查看某个sds当前的信息,当前sds长度,以及可用内存长度,结果如下
[mw_shl_code=bash,true]key_sds_len:3, key_sds_avail:0, val_sds_len:5, val_sds_avail:0[/mw_shl_code]

debug populate
测试利器,快速产生大量的key
[mw_shl_code=bash,true]127.0.0.1:6379> debug populate 10000
OK
127.0.0.1:6379> dbsize
(integer) 10000[/mw_shl_code]

debug digest
对整个数据库的数据,产生一个摘要,可用于验证两个redis数据库数据是否一致
[mw_shl_code=bash,true]127.0.0.1:6379> debug digest
7164ae8b6730c8bcade46532e5e4a8015d4cccfb
127.0.0.1:6379> debug digest
7164ae8b6730c8bcade46532e5e4a8015d4cccfb[/mw_shl_code]

debug sleep
测试利器,用于模拟某个时间开销的命令,比如debug sleep 0.1就相当于执行了一条开销为100ms的命令。
[mw_shl_code=bash,true]127.0.0.1:6379> debug sleep 1
OK
(1.00s)[/mw_shl_code]

debug error
测试利器,模拟一条命令执行失败,发送debug error,redis直接会返回一个错误应答
[mw_shl_code=bash,true]127.0.0.1:6379> debug error "test"
(error) test[/mw_shl_code]





没找到任何评论,期待你打破沉寂

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

关闭

推荐上一条 /2 下一条