欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Redis通過scan查找不過期的 key(方法詳解)

 更新時間:2021年08月18日 15:28:51   作者:__Yoon  
SCAN 命令是一個基于游標的迭代器,每次被調(diào)用之后, 都會向用戶返回一個新的游標, 用戶在下次迭代時需要使用這個新游標作為 SCAN 命令的游標參數(shù), 以此來延續(xù)之前的迭代過程,對Redis scan 查找 key相關(guān)知識感興趣的朋友一起看看吧

Redis Scan 命令用于迭代數(shù)據(jù)庫中的數(shù)據(jù)庫鍵。

SCAN 返回一個包含兩個元素的數(shù)組, 第一個元素是用于進行下一次迭代的新游標, 而第二個元素則是一個數(shù)組, 這個數(shù)組中包含了所有被迭代的元素。如果新游標返回 0 表示迭代已結(jié)束。

相關(guān)命令:

SSCAN 命令用于迭代集合鍵中的元素。
HSCAN 命令用于迭代哈希鍵中的鍵值對。
ZSCAN 命令用于迭代有序集合中的元素(包括元素成員和元素分值)。

# SCAN 命令是一個基于游標的迭代器(cursor based iterator):SCAN 命令每次被調(diào)用之后,都會向用戶返回一個新的游標,用戶在下次迭代時需要使用這個新游標作為 SCAN 命令的游標參數(shù),以此來延續(xù)之前的迭代過程。
# 注意:當 SCAN 命令的游標參數(shù)被設(shè)置為 0 時,服務(wù)器將開始一次新的迭代,而當服務(wù)器向用戶返回值為 0 的游標時,表示迭代已結(jié)束!

# vim redis_no_ttl_key.sh

#!/bin/bash
# Redis 通過 scan 找出不過期的 key
# SCAN 命令是一個基于游標的迭代器(cursor based iterator):SCAN 命令每次被調(diào)用之后,都會向用戶返回一個新的游標,用戶在下次迭代時需要使用這個新游標作為 SCAN 命令的游標參數(shù),以此來延續(xù)之前的迭代過程。
# 注意:當 SCAN 命令的游標參數(shù)被設(shè)置為 0 時,服務(wù)器將開始一次新的迭代,而當服務(wù)器向用戶返回值為 0 的游標時,表示迭代已結(jié)束!

db_ip=10.100.41.148       # redis 連接IP
db_port=6379              # redis 端口
password='IootCdgN05srE'  # redis 密碼
cursor=0                  # 第一次游標
cnt=100                   # 每次迭代的數(shù)量
new_cursor=0              # 下一次游標

redis-cli -c -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  # 獲取 key
cat scan_result |while read line             # 循環(huán)遍歷所有 key
do
    ttl_result=`redis-cli -c -h $db_ip -p $db_port -a $password ttl $line`  # 獲取key過期時間
    if [[ $ttl_result == -1 ]];then
    #if [ $ttl_result -eq -1 ];then          # 判斷過期時間,-1 是不過期
        echo $line >> no_ttl.log             # 追加到指定日志
    fi
done

while [ $cursor -ne $new_cursor ]            # 若游標不為0,則證明沒有迭代完所有的key,繼續(xù)執(zhí)行,直至游標為0
do
    redis-cli -c -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 -c -h $db_ip -p $db_port -a $password ttl $line`
        if [[ $ttl_result == -1 ]];then
        #if [ $ttl_result -eq -1 ];then
            echo $line >> no_ttl.log
        fi
    done
done
rm -rf scan_tmp_result
rm -rf scan_result

到此這篇關(guān)于Redis通過scan查找不過期的 key的文章就介紹到這了,更多相關(guān)Redis scan 查找 key內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • IDEA初次連接Redis配置的實現(xiàn)

    IDEA初次連接Redis配置的實現(xiàn)

    本文主要介紹了IDEA初次連接Redis配置的實現(xiàn),文中通過圖文步驟介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-12-12
  • 解決redis啟動的警告日志問題

    解決redis啟動的警告日志問題

    這篇文章主要介紹了解決redis啟動的警告日志問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-01-01
  • redis.clients.jedis.exceptions.JedisDataException:?NOAUTH?Authentication?required數(shù)據(jù)操作異常的解決方法

    redis.clients.jedis.exceptions.JedisDataException:?NOAUTH?

    本文主要介紹了redis.clients.jedis.exceptions.JedisDataException:?NOAUTH?Authentication?required數(shù)據(jù)操作異常的解決方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2024-05-05
  • 基于Redis實現(xiàn)搶紅包和發(fā)紅包功能

    基于Redis實現(xiàn)搶紅包和發(fā)紅包功能

    搶紅包是我們生活常用的社交功能, 這個功能最主要的特點就是用戶的并發(fā)請求高, 在系統(tǒng)設(shè)計上, 可以使用非常多的辦法來扛住用戶的高并發(fā)請求, 在本文中簡要介紹使用Redis緩存中間件來實現(xiàn)搶紅包算法,需要的朋友可以參考下
    2024-04-04
  • 啟動redis出現(xiàn)閃退情況的解決辦法

    啟動redis出現(xiàn)閃退情況的解決辦法

    最近使用Redis遇到啟動閃退的問題,查閱資料后在一位大神的文章中找到了答案,這篇文章主要給大家介紹了關(guān)于啟動redis出現(xiàn)閃退情況的解決辦法,需要的朋友可以參考下
    2023-11-11
  • Redis事務(wù)涉及的watch、multi等命令詳解

    Redis事務(wù)涉及的watch、multi等命令詳解

    這篇文章主要介紹了Redis事務(wù)涉及的watch、multi等命令,本文給大家介紹的非常詳細,具有一定的參考借鑒價值 ,需要的朋友可以參考下
    2018-10-10
  • 淺談Redis安全策略

    淺談Redis安全策略

    Redis 提供了諸多安全策略,比如為了保證數(shù)據(jù)安全,提供了設(shè)置密碼的功能。本文就詳細的介紹了一下Redis安全策略,具有一定的參考價值,感興趣的可以了解一下
    2021-11-11
  • 如何高效使用Redis作為LRU緩存

    如何高效使用Redis作為LRU緩存

    這篇文章主要介紹了如何高效使用Redis作為LRU緩存,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-08-08
  • 解決redis在linux上的部署的問題

    解決redis在linux上的部署的問題

    這篇文章主要介紹了redis在linux上的部署,本文分步驟給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-02-02
  • 分布式架構(gòu)Redis中有哪些數(shù)據(jù)結(jié)構(gòu)及底層實現(xiàn)原理

    分布式架構(gòu)Redis中有哪些數(shù)據(jù)結(jié)構(gòu)及底層實現(xiàn)原理

    這篇文章主要為大家介紹了分布式架構(gòu)Redis中有哪些數(shù)據(jù)結(jié)構(gòu)及底層的實現(xiàn)原理解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步
    2022-03-03

最新評論