您好,登錄后才能下訂單哦!
本篇內容介紹了“redis遷移數據到redis-cluster的方法是什么”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!
不管是單節點還是集群都可以用以下的思路遷移至cluster集群中去
方案步驟 1)獲取原單實例節點D的持久化AOF(rdb)文件,如果是集群就先將所有的solt移動到一臺機器上 2)新準備三個節點A,B,C,建立集群,目前集群為空 3)把節點B,C上的slots,全部分配給A,關閉新的集群(記住:一定要關閉新的集群) 4)把1)中獲取的rdb文件SCP到A上 5)重啟A節點,把數據全部加載到內存,再啟動BC節點 6)把A節點上的slots再均勻分配給B,C 7)新準備A1,B1,C1,分別作為A,B,C的slave加入到集群 8)驗證數據的完整性和集群狀態
步驟中的第6步分配時可能報以下的錯誤
[ERR] Calling MIGRATE ERR Syntax error, try CLIENT (LIST | KILL | GETNAME | SETNAME | PAUSE | REPLY)
解決辦法:
ruby gem安裝的redis庫,版本不能使用最新的4.0,否則redis-trib.rb reshard 127.0.0.1:7000 重新分片時會報語法錯誤。 1、卸載最新redis庫,gem uninstall redis 2、安裝3.x版本,gem install redis -v 3.3.5 測試3.2.1到3.3.5都可以,4.x以上的分片報錯。
reshard失敗之后如果check要是有如下錯誤
[WARNING] Node 192.168.0.11:6380 has slots in migrating state (5461). [WARNING] The following slots are open: 5461 可以使用redis命令取消slots遷移(5461為slot的ID): cluster setslot 5461 stable 需要注意,須登錄到192.168.0.11:6380上執行redis的setslot子命令。
遷移方式二:
只有在無密碼的情況下才好用(單節點>>>集群) /usr/local/src/redis-4.0.8/src/redis-trib.rb.bak import --from 172.31.47.95:6381 --copy 172.31.32.223:6379 查看 每個節點的size 127.0.0.1:6379> dbsize (integer) 466 127.0.0.1:6379> dbsize (integer) 478 127.0.0.1:6379> dbsize (integer) 441 所有的key已經自動幫忙分到不同的slot去了
“redis遷移數據到redis-cluster的方法是什么”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。