shell腳本批量導(dǎo)出redis key-value方式
1 背景
需求:工作中需要導(dǎo)出線上redis數(shù)據(jù),但需避免使用keys命令全量掃描,導(dǎo)致瞬間響應(yīng)卡頓,從而引發(fā)超時等問題
方法:最安全的方式是通過dump.rdb備份文件,在本地redis實例上恢復(fù),然后執(zhí)行shell腳本,使用scan漸進掃描批量導(dǎo)出key-value。
2 詳細(xì)步驟
2.1 本地docker啟動redis
本地通過docker-compose創(chuàng)建redis實例,并掛載配置文件和數(shù)據(jù)目錄
- docker-compose.yml
version: '3'
services:
redis:
image: redis
container_name: redis
restart: always
command: redis-server /etc/redis/redis.conf
ports:
- 46379:6379
environment:
TZ: Asia/Shanghai
LANG: en_US.UTF-8
volumes:
- ./mnt/conf/redis.conf:/etc/redis/redis.conf:rw
- ./mnt/data:/data:rw
- 在宿主機創(chuàng)建配置文件
指定dump恢復(fù)目錄及文件,和redis實例密碼
mkdir -p ./mnt/conf vim ./mnt/conf/redis.conf
requirepass GSef7NOoIH5R dbfilename dump.rdb dir /data
- 將dump.rdb備份文件放在宿主機
./mnt/conf/data下,啟動redis
docker-compose up -d
- 通過日志查看備份恢復(fù)進度
docker logs -f redis
- 驗證恢復(fù)情況
# 進入容器 docker exec -it redis bash # 認(rèn)證 auth GSef7NOoIH5R # 查詢key數(shù)量 dbsize
2.2 shell批量導(dǎo)出腳本
- 進入容器
docker exec -it redis bash
- 為便于后續(xù)操作,在容器安裝vim(也可在宿主機掛載目錄創(chuàng)建shell腳本)
# 換源并安裝vim
sed -i 's/deb.debian.org/mirrors.aliyun.com/g' /etc/apt/sources.list \
&& apt update -y \
&& apt-get install -y vim
# 解決vim中文亂碼
echo -e "syntax on \nset termencoding=utf-8 \nset encoding=utf8 \nset fileencodings=utf8,ucs-bom,gbk,cp936,gb2312,gb18030" >> ~/.vimrc
- 創(chuàng)建shell腳本
使用的scan命令漸進遍歷,相對于keys命令全量遍歷速度慢些,但勝在安全,對redis的負(fù)載低。其中:
- 可通過
CNT參數(shù)設(shè)定迭代元素的數(shù)量來以控制redis負(fù)載 - 獲取value值時,通過
INTERVAL調(diào)整redis-cli的執(zhí)行間隔,來控制redis負(fù)載
vim redis_export.sh
#!/bin/bash
REDIS_HOST=localhost
REDIS_PORT=6379
REDIS_PASSWORD=GSef7NOoIH5R
CNT=1000
KEY_NAME=vc_*
KEY_FILE=key_list.txt
VALUE_FILE=value_list.txt
RESULT_FILE=kv_result.txt
INTERVAL=0.01
redis-cli -h $REDIS_HOST -p $REDIS_PORT -a $REDIS_PASSWORD scan 0 match "$KEY_NAME" count $CNT 2>/dev/null> scan_tmp_result
new_cursor=`sed -n '1p' scan_tmp_result`
sed -n '2,$p' scan_tmp_result > $KEY_FILE
while [ $new_cursor -ne 0 ]
do
redis-cli -h $REDIS_HOST -p $REDIS_PORT -a $REDIS_PASSWORD scan $new_cursor match "$KEY_NAME" count $CNT 2>/dev/null> scan_tmp_result
new_cursor=`sed -n '1p' scan_tmp_result`
echo `cat $KEY_FILE |wc -l`
sed -n '2,$p' scan_tmp_result >> $KEY_FILE
done
TOTAL=`cat $KEY_FILE |wc -l`
echo $TOTAL
> $VALUE_FILE
i=0
for key in `cat $KEY_FILE`
do
i=$(($i+1))
if [[ ${i}%1000 -eq 0 || ${i} -eq $total ]]; then
echo "$i / $TOTAL"
fi
echo "GET $key" | redis-cli $INTERVAL -h $REDIS_HOST -p $REDIS_PORT -a $REDIS_PASSWORD 2>/dev/null >> $VALUE_FILE
done
paste $KEY_FILE $VALUE_FILE > $RESULT_FILE
rm -f scan_tmp_result $VALUE_FILE $KEY_FILE
- 運行腳本
bash ./redis_export.sh
3 附錄
記錄下實踐時的其它方法/功能:
- scan掃描不指定游標(biāo),相比
keys pattern模式不會長時間阻塞redis。(可通過-i調(diào)整執(zhí)行間隔控制負(fù)載)
redis-cli -a GSef7NOoIH5R --scan --pattern "vc_*">/tmp/redis.log
- keys全量掃描(慎用)
echo "KEYS vc_*" | redis-cli -a GSef7NOoIH5R >/tmp/redis.log
總結(jié)
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
淺析對redis?hashtable?的sizemask理解
在?Redis?的哈希表實現(xiàn)中,index?=?hash?&?dict->ht[0].sizemask?是計算鍵值對應(yīng)存儲位置的核心操作,本文給大家介紹redis?hashtable?的sizemask理解,感興趣的朋友一起看看吧2025-03-03
Redis集群模式和常用數(shù)據(jù)結(jié)構(gòu)詳解
Redis集群模式下的運維指令主要用于集群的搭建、管理、監(jiān)控和維護,講解了一些常用的Redis集群運維指令,本文重點介紹了Redis集群模式和常用數(shù)據(jù)結(jié)構(gòu),需要的朋友可以參考下2024-03-03
Redis中5種BitMap應(yīng)用場景及實現(xiàn)介紹
Redis BitMap是一種高效的位操作數(shù)據(jù)結(jié)構(gòu),這種結(jié)構(gòu)在處理海量數(shù)據(jù)的布爾型狀態(tài)時尤其高效,下面小編就來和大家簡單介紹一下5種它的應(yīng)用場景及實現(xiàn)方法吧2025-04-04
redis哈希類型_動力節(jié)點Java學(xué)院整理
這篇文章主要介紹了redis哈希類型的常用方法及原理淺析,感興趣的朋友一起看看吧2017-08-08
Govern Service 基于 Redis 的服務(wù)治理平臺安裝過程詳解
Govern Service 是一個輕量級、低成本的服務(wù)注冊、服務(wù)發(fā)現(xiàn)、 配置服務(wù) SDK,通過使用現(xiàn)有基礎(chǔ)設(shè)施中的 Redis 不用給運維部署帶來額外的成本與負(fù)擔(dān),接下來通過本文給大家分享Govern Service 基于 Redis 的服務(wù)治理平臺的相關(guān)知識,感興趣的朋友一起看看吧2021-05-05
Redis String 類型和 Hash 類型學(xué)習(xí)筆記與總結(jié)
這篇文章主要介紹了Redis String 類型和 Hash 類型學(xué)習(xí)筆記與總結(jié),本文分別對String 類型的一些方法和Hash 類型做了詳細(xì)介紹,需要的朋友可以參考下2015-06-06
Redis+threading實現(xiàn)多線程消息隊列的使用示例
Redis多線程消息隊列是一種使用Redis作為存儲后端的消息隊列實現(xiàn),它利用Redis的線程并發(fā)處理能力來提高消息隊列的處理效率,本文主要介紹了Redis+threading實現(xiàn)多線程消息隊列的使用示例,感興趣的可以了解一下2023-12-12

