1. 程式人生 > >Redis官方ruby指令碼建立cluster雙例項三主三從叢集的bug

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是分片儲存叢集。當然如果redis只是用來做快取資料庫,不使用持久化,問題也就沒那麼大。如果是6臺虛擬機器,就不會出現這種情況;更多數量主從雙例項叢集,比如四主四從的沒有測試過,大家可以回去測試一下。
對於這個問題,我們可以通過純手動建立三主三從的雙例項叢集,不使用官方的redis.trib.rb指令碼。
-----------------------------------------Mark一下--------------------------------------------------