IT博客汇
  • 首页
  • 精华
  • 技术
  • 设计
  • 资讯
  • 扯淡
  • 权利声明
  • 登录 注册

    redis debug命令详解

    ydzhang发表于 2015-06-17 07:39:08
    love 0

    redis debug命令提供了几个非常实用的debug功能,本文介绍下redis-2.8.19下的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
    

    The post redis debug命令详解 appeared first on Yun Notes.



沪ICP备19023445号-2号
友情链接