使用 redis-shake 遷移 redis-cluster
公司主營(yíng)業(yè)務(wù):網(wǎng)站設(shè)計(jì)制作、成都網(wǎng)站制作、移動(dòng)網(wǎng)站開(kāi)發(fā)等業(yè)務(wù)。幫助企業(yè)客戶真正實(shí)現(xiàn)互聯(lián)網(wǎng)宣傳,提高企業(yè)的競(jìng)爭(zhēng)能力。創(chuàng)新互聯(lián)建站是一支青春激揚(yáng)、勤奮敬業(yè)、活力青春激揚(yáng)、勤奮敬業(yè)、活力澎湃、和諧高效的團(tuán)隊(duì)。公司秉承以“開(kāi)放、自由、嚴(yán)謹(jǐn)、自律”為核心的企業(yè)文化,感謝他們對(duì)我們的高要求,感謝他們從不同領(lǐng)域給我們帶來(lái)的挑戰(zhàn),讓我們激情的團(tuán)隊(duì)有機(jī)會(huì)用頭腦與智慧不斷的給客戶帶來(lái)驚喜。創(chuàng)新互聯(lián)建站推出攸縣免費(fèi)做網(wǎng)站回饋大家。
背景:
? ? IDC上云, 有2套redis-cluster需要遷移到云上。 這里我們使用 redis-shake 來(lái)做遷移操作。
模擬機(jī)房集群(圖是我后截的,圖上已經(jīng)有key了):?
模擬云上集群(圖是我后截的,圖上已經(jīng)有key了):?
遷移前, redis-cluster 我們先造點(diǎn)數(shù)據(jù)進(jìn)去到機(jī)房集群去。腳本如下:
for?i?in?{1..10000};?do? ??echo?"set?age$i??$i"?|?redis-cli?-c?-h?172.31.1.133?-p?6391 done
然后,先找出老的redis cluster的master節(jié)點(diǎn)信息, redis-shake遷移要用到。如下:
echo 'cluster nodes' | redis-cli -c -h 172.31.1.133 -p 6391 | egrep master?
1154ebeb83a53ad7ac09d14b49f4ec28af91e1e5?172.31.1.133:6392@16392?master?-?0?1571397581506?13?connected?4097-8193 248a9d4e2ab4da9875c2ff2fb9c222be0b07deb7?172.31.1.134:6393@16393?master?-?0?1571397583018?2?connected?8194-12290 94d42bffd85e4c8acf49c64b182023e9381805aa?172.31.1.134:6352@16352?master?-?0?1571397582508?11?connected?12291-16383 1dd160e9fbfe4bb5d8c251053c9d7b752b23d317?172.31.1.134:6353@16353?master?-?0?1571397582608?10?connected?0-4096
我這里的是如下4個(gè)節(jié)點(diǎn)為master:
172.31.1.133:6392;172.31.1.134:6393;172.31.1.134:6352;172.31.1.134:6353
然后,找出 新的redis cluster 的master節(jié)點(diǎn)信息,redis-shake遷移要用到。如下:
echo 'cluster nodes' | redis-cli -h 172.31.1.133 -p? 6394 | egrep master?
9a81aecf9ad5d2bb6104134107215b528476eec6?172.31.1.134:6397@16397?master?-?0?1571398028000?1?connected?8194-12290 2b1bf7f11258ac363962c6216d19687e2d9e6bbe?172.31.1.133:6397@16397?master?-?0?1571398027348?4?connected?12291-16383 3aec1bed303b228290886eb21af0a9907f4c22c9?172.31.1.134:6396@16396?master?-?0?1571398025000?5?connected?4097-8193 d8173ea22c504639e3102991876edd401ec4f3d9?172.31.1.133:6394@16394?myself,master?-?0?1571398027000?0?connected?0-4096
我這里的是如下4個(gè)節(jié)點(diǎn)為master:
172.31.1.134:6397;172.31.1.133:6397;172.31.1.134:6396;172.31.1.133:6394
然后,編輯 redis-shake 的配置
vim redis-shake.conf? 修改source部分和target部分的內(nèi)容如下:
source.type?=?cluster source.address?=?172.31.1.133:6392;172.31.1.134:6393;172.31.1.134:6352;172.31.1.134:6353 source.password_raw?=? source.auth_type?=?auth target.type?=?cluster target.address?=?172.31.1.134:6397;172.31.1.133:6397;172.31.1.134:6396;172.31.1.133:6394 target.password_raw?= target.auth_type?=?auth target.db?=?-1
啟動(dòng)遷移進(jìn)程:
./redis-shake.linux -type sync -conf redis-shake.conf
下圖是遷移過(guò)程中,redis-shake的日志(最后一行就是寫入到目標(biāo)redis cluster的數(shù)據(jù)量瞬時(shí)值)