幾種redis數(shù)據(jù)導(dǎo)出導(dǎo)入方式
10年積累的做網(wǎng)站、成都網(wǎng)站建設(shè)經(jīng)驗(yàn),可以快速應(yīng)對(duì)客戶對(duì)網(wǎng)站的新想法和需求。提供各種問題對(duì)應(yīng)的解決方案。讓選擇我們的客戶得到更好、更有力的網(wǎng)絡(luò)服務(wù)。我雖然不認(rèn)識(shí)你,你也不認(rèn)識(shí)我。但先制作網(wǎng)站后付款的網(wǎng)站建設(shè)流程,更有播州免費(fèi)網(wǎng)站建設(shè)讓你可以放心的選擇與我們合作。
192.168.1.101 node1 redis源實(shí)例
192.168.1.102 node2 redis目標(biāo)實(shí)例
192.168.1.103 node3 任意linux系統(tǒng)
redis-dump這款工具需要用到Ruby,而centos環(huán)境中的yum工具可以安裝的Ruby版本最高是2.0的版本,而當(dāng)前Redis最新的4.0版本中需要用到的Ruby >= 2.2版本,所以我們需要先安裝Ruby,而安裝Ruby有一個(gè)很好的命令行工具可以幫助我們,這款工具就是RVM,RVM可以提供一個(gè)便捷的多版本 Ruby 環(huán)境的管理和切換。
首先到tmp下,用來(lái)存放下載的安裝文件
cd /tmp
mkdir rvm
cd rvm
# 開始安裝RVM
gpg --keyserver hkp://keys.gnupg.net --recv-keys 409B6B1796C275462A1703113804BB82D39DC0E3
curl -O https://raw.githubusercontent.com/rvm/rvm/master/binscripts/rvm-installer
curl -O https://raw.githubusercontent.com/rvm/rvm/master/binscripts/rvm-installer.asc
gpg --verify rvm-installer.asc
bash rvm-installer stable
source /etc/profile.d/rvm.sh
查看可以安裝的Ruby版本
rvm list known
這里我們安裝2.4.1
rvm install ruby 2.4.1
設(shè)置默認(rèn)ruby
rvm use 2.4.1 --default
查看ruby版本
ruby --version
移除gem自帶源(美國(guó)服務(wù)器下載慢)
gem sources --remove https://rubygems.org/
添加國(guó)內(nèi)源
gem sources -a https://gems.ruby-china.com
查看倉(cāng)庫(kù)源
gem sources -l
*** CURRENT SOURCES ***
http://gems.ruby-china.com/
安裝redis-dump
gem install redis-dump -V
安裝redis-dump包括的gem包
drydock-0.6.9.gem
uri-redis-0.4.2.gem
yajl-ruby-1.4.1.gem
redis-dump-0.4.0.gem
redis-dump幫助命令
[root@node3 ~]# redis-dump --help
Try: /usr/local/bin/redis-dump show-commands
Usage: /usr/local/bin/redis-dump [global options] COMMAND [command options]
-u, --uri=S Redis URI (e.g. redis://hostname[:port])
-d, --database=S Redis database (e.g. -d 15)
-a, --password=S Redis password (e.g. -a 'my@pass/word')
-s, --sleep=S Sleep for S seconds after dumping (for debugging)
-c, --count=S Chunk size (default: 10000)
-f, --filter=S Filter selected keys (passed directly to redis' KEYS command)
-b, --base64 Encode key values as base64 (useful for binary values)
-O, --without_optimizations Disable run time optimizations
-V, --version Display version
-D, --debug
--nosafe
[root@node3 ~]#
導(dǎo)出命令
redis-dump -u 192.168.1.101:6379 > 192.168.1.101.json
導(dǎo)出指定數(shù)據(jù)庫(kù)數(shù)據(jù)
redis-dump -u 192.168.1.101:6379 -d 5 > 192.168.1.101.json
如果redis設(shè)有密碼
redis-dump -u :password@192.168.1.101:6379 > 192.168.1.101.json
redis-dump導(dǎo)出當(dāng)前節(jié)點(diǎn)的所有keys;當(dāng)redis 為cluster時(shí),需要分別導(dǎo)出所有master的keys;
[root@node3 ~]# redis-load --help
Try: /usr/local/bin/redis-load show-commands
Usage: /usr/local/bin/redis-load [global options] COMMAND [command options]
-u, --uri=S Redis URI (e.g. redis://hostname[:port])
-d, --database=S Redis database (e.g. -d 15)
-a, --password=S Redis password (e.g. -a 'my@pass/word')
-s, --sleep=S Sleep for S seconds after dumping (for debugging)
-b, --base64 Decode key values from base64 (used with redis-dump -b)
-n, --no_check_utf8
-V, --version Display version
-D, --debug
--nosafe
[root@node3 ~]#
redis-load導(dǎo)入
cat 192.168.1.101.json | redis-load -u 192.168.1.102:6379
# 或者
< 192.168.1.101.json redis-load -u 192.168.1.102:6379
# 清空上文目標(biāo)實(shí)例全部數(shù)據(jù)
[root@node1 ~]# redis-cli -h 192.168.1.102 -a password flushall
OK
# 源實(shí)例開啟aof功能,將在dir目錄下生成appendonly.aof文件
[root@node1 ~]# redis-cli -h 192.168.1.101 -a password config set appendonly yes
OK
# 假設(shè)appendonly.aof就在當(dāng)前路徑下
[root@node1 ~]# redis-cli -h 192.168.1.102 -a password --pipe < appendonly.aof
All data transferred. Waiting for the last reply...
Last reply received from server.
errors: 0, replies: 5
# 源實(shí)例關(guān)閉aof功能
[root@node1 ~]# redis-cli -h 192.168.1.101 -a password config set appendonly no
OK
暫略
[root@node1 ~]# cat redis_mv.sh
#!/bin/bash
redis-cli -h 192.168.1.101 -p 6379 -a password -n 0 keys "*" | while read key
do
redis-cli -h 192.168.1.101 -p 6379 -a password -n 0 --raw dump $key | perl -pe 'chomp if eof' | redis-cli -h 192.168.1.102 -p 6379 -a password -n 1 -x restore $key 0
echo "migrate key $key"
done