真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

幾種redis數(shù)據(jù)導(dǎo)出導(dǎo)入方式-創(chuàng)新互聯(lián)

幾種redis數(shù)據(jù)導(dǎo)出導(dǎo)入方式

目前成都創(chuàng)新互聯(lián)公司已為上千家的企業(yè)提供了網(wǎng)站建設(shè)、域名、網(wǎng)絡(luò)空間、網(wǎng)站托管、企業(yè)網(wǎng)站設(shè)計(jì)、鐵東網(wǎng)站維護(hù)等服務(wù),公司將堅(jiān)持客戶導(dǎo)向、應(yīng)用為本的策略,正道將秉承"和諧、參與、激情"的文化,與客戶和合作伙伴齊心協(xié)力一起成長,共同發(fā)展。

1 環(huán)境說明:

192.168.1.101 node1 redis源實(shí)例
192.168.1.102 node2 redis目標(biāo)實(shí)例
192.168.1.103 node3 任意linux系統(tǒng)

2 redis-dump方式

2.1 安裝RVM

redis-dump這款工具需要用到Ruby,而centos環(huán)境中的yum工具可以安裝的Ruby版本高是2.0的版本,而當(dāng)前Redis最新的4.0版本中需要用到的Ruby >= 2.2版本,所以我們需要先安裝Ruby,而安裝Ruby有一個很好的命令行工具可以幫助我們,這款工具就是RVM,RVM可以提供一個便捷的多版本 Ruby 環(huán)境的管理和切換。

首先到tmp下,用來存放下載的安裝文件
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

2.2 安裝Ruby

查看可以安裝的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

2.3 安裝redis-dump工具

移除gem自帶源(美國服務(wù)器下載慢)

gem sources --remove https://rubygems.org/

添加國內(nèi)源

gem sources -a https://gems.ruby-china.com

查看倉庫源

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

2.4 redis-dump導(dǎo)出

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ù)庫數(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時,需要分別導(dǎo)出所有master的keys;

2.5 redis-load導(dǎo)入命令

[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

3 aof導(dǎo)入方式

3.1 源實(shí)例生成aof數(shù)據(jù)

# 清空上文目標(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

3.2 目標(biāo)實(shí)例導(dǎo)入aof數(shù)據(jù)

# 假設(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

4 rdb文件遷移方式

暫略

5 源實(shí)例db0遷移至目標(biāo)實(shí)例db1

[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

另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)cdcxhl.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價比高”等特點(diǎn)與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。


當(dāng)前名稱:幾種redis數(shù)據(jù)導(dǎo)出導(dǎo)入方式-創(chuàng)新互聯(lián)
網(wǎng)頁網(wǎng)址:http://weahome.cn/article/cscgsc.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部