Redis官方ruby腳本創建cluster雙實例三主三從集羣的bug

使用三臺虛擬機創建Redis雙實例部署cluster三主三從集羣,並且主從之間要交叉成對,避免主從都出現在同一臺虛擬機上的情況。
這是我們搭建三組三從的一個目標之一,剛開始我使用的是官網的ruby腳本redis.trib.rb來創建集羣,後來發現一個大坑,雙實例的三主三從你在使用redis.trib.rb腳本創建集羣時無論怎麼排序,最後都是會有一對主從是落在同一虛擬機上的。
比如下面查看到的狀態(觀察實例的ID):
192.168.1.33:6379 192.168.1.34:6380
192.168.1.35:6379 192.168.1.35:6380
192.168.1.34:6379 192.168.1.33:6380

cluster nodes
d3cf7c72d3118f2bdd39e3581d0cc4c52e7c03c3 192.168.1.33:6379 myself,master - 0 0 1 connected 0-5460
cba6c37028119adof59c589f3863716faac67721 192.168.1.34:6380 s1ave d3cf7c72d3118f2bdd39e3581d0cc4c52e7c03c3 0 1543825541203 4 connected
f2336c17830c43d449cf2b6d1384b4891f9d7c2f 192.168.1.35:6380 slave 8e6c05671c098ffa09004bd450ea5292930b2481 0 1543825542205 6 connected
8e6c05671c098ffa09004bd450ea5292930b2481 192.168.1.35:6379 master - 0 1543825540700 5 connected 10923-16383
65f50d0f1117fd70278bb5d66bcb95048da8b0e5 192.168.1.34:6379 master - 0 1543825541704 3 connected 5461-10922
a12b13d5044059e7bfb95b83d8d091a626a95261 192.168.1.33:6380 s1ave 65f50d0f1117fd70278bb5d66bcb95048da8b0e5 0 1543825540700 3 connected

那麼這就問題大了,如果192.168.1.35這臺設備掛了,那麼整個redis集羣就無法訪問了,因爲redis cluster是分片存儲集羣。如果是6臺虛擬機,就不會出現這種情況;更多數量主從雙實例集羣,比如四主四從的沒有測試過,大家可以回去測試一下。
對於這個問題,我們可以通過純手動創建三主三從的雙實例集羣,不使用官方的redis.trib.rb腳本。
-----------------------------------------Mark一下--------------------------------------------------

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章