mysql分布式資料庫
發布時間: 2025-08-12 15:49:21
1、amoeba相當於一個SQL請求的路由器,目的是為負載均衡、讀寫分離、高可用性提供機制,而不是完全實現它們。用戶需要結合使用MySQL的Replication等機制來實現副本同步等功能。amoeba對底層資料庫連接管理和路由實現也採用了可插撥的機制,第三方可以開發更高級的策略類來替代作者的實現。這個程序總體上比較符合KISS的思想。
2、由上一條,建議使用MySQL的Replication機制建立Master-Slave來做副本。我一開始理解有誤,使用了amoeba的virtual DB(負載均衡pool)做writePool,結果使得本應插入同一個表中的數據被拆分地寫入了不同的物理資料庫中。這樣自然與副本的語義不符了。
3、amoeba已經實現了數據的垂直切分與水平切分。水平切分方面,粒度是行。使用SQLJEP語句可以設計出復雜的切分規則,個人認為是比較強大的。垂直切分的粒度是表,可以把針對不同表的請求發送到不同的節點上執行,但不能以列作為分片粒度。從作者的說法看,amoeba不做SQL解析和重寫。在目前的機制下似乎是難以實現同一個表不同的列在不同節點上的分布。不過對開發人員來說,設計良好的表結構應該可以實現簡單的基於關系屬性的負載均衡的。
熱點內容