zoukankan      html  css  js  c++  java
  • Redis 通过 scan 找出不过期的 key

    SCAN 命令是一个基于游标的迭代器(cursor based iterator):SCAN 命令每次被调用之后,都会向用户返回一个新的游标,用户在下次迭代时需要使用这个新游标作为 SCAN 命令的游标参数,以此来延续之前的迭代过程。

    注意:当 SCAN 命令的游标参数被设置为 0 时,服务器将开始一次新的迭代,而当服务器向用户返回值为 0 的游标时,表示迭代已结束!
    编写脚本

    #!/bin/bash
    
    db_ip=127.0.0.1      # redis ip
    db_port=6379         # redis 端口
    password=ibalife     # redis 密码
    cursor=0             # 第一次游标
    cnt=100              # 每次迭代的数量
    new_cursor=0         # 下一次游标
    
    redis-cli -h $db_ip -p $db_port -a $password scan $cursor count $cnt > scan_tmp_result
    new_cursor=`sed -n '1p' scan_tmp_result`             # 获取下一次游标
    sed -n '2,$p' scan_tmp_result > scan_result          # 获取 keys
    cat scan_result |while read line                     # 循环遍历所有 keys
    do
        ttl_result=`redis-cli -h $db_ip -p $db_port -a $password ttl $line`      # 获取 key 过期时间
        if [[ $ttl_result == -1 ]];then                  # 判断过期时间,-1 是不过期
            echo $line >> no_ttl.log                     # 追加到指定文件
        fi
    done
    
    
    while [ $cursor -ne $new_cursor ]                    # 若 游标 不为 0 ,则证明没有迭代完所有的 key,继续执行
    do
        redis-cli -h $db_ip -p $db_port -a $password scan $new_cursor count $cnt > scan_tmp_result
        new_cursor=`sed -n '1p' scan_tmp_result`
        sed -n '2,$p' scan_tmp_result > scan_result
        cat scan_result |while read line
        do
            ttl_result=`redis-cli -h $db_ip -p $db_port -a $password ttl $line`
            if [[ $ttl_result == -1 ]];then
                echo $line >> no_ttl.log
            fi
        done
    done
    rm -rf scan_tmp_result
    rm -rf scan_result
    

    注意,若你的 redis 占用内存很大,可以使用 tmux 命令新开一个窗口。最后所有符合的要求的 key 都会保存在 no_ttl.log 文件中

  • 相关阅读:
    sharepoint server 2010 打开网页非常慢
    sharepoint 2010 彻底删除用户
    Exchange2007设置网页OWA访问
    sharepoint 2007 网页内嵌打开pdf
    BAT+VBS、BAT+REG、BAT+HTML 混合编程
    Exchange2007安装后如何添加域账户邮箱
    Outlook2003无法登陆Exchange2007邮箱,提示outlook版本禁止
    Winsock Fix for Windows 7
    Silverlight 3 脱机安装
    WCF问题及解决方案
  • 原文地址:https://www.cnblogs.com/klvchen/p/12071981.html
Copyright © 2011-2022 走看看