mysql用來開發中小型項目還是挺好用的,從節約成本的方面來考慮的確是個不錯的選擇,但是開發並發瞭比較大的項目顯然還是有些吃力的,前幾年解決這種問題通常是通過讀寫分離來優化資料庫,因此出現瞭amoeba這個東西,現在這個東西已經被棄用瞭反倒是mysql-cluster-gpl用的比較多。但是有關mysql集群的配置還是比較繁瑣,好多人弄不出來就放棄瞭,可怕的是網上很多資料都是轉載別人的,都沒有經過自己實際的驗證,簡直就是太坑爹瞭。這次我打算分享下有關mysql集群的知識。
1 開發準備
下載mysql-cluster-gpl-7.X版本的msi或者exe文件,雙擊後安裝位置隨意,安裝好之後目錄大致如下
2 創建於集群相關的文件目錄
(1)在磁盤上建一個文件夾名稱隨意,在這個文件夾下面建mgm_data、ndb_data、mysqld_data,建好之後從mysql-cluster-gpl的安裝目錄下的bin目錄下面復制ndb_mgm.exe和ndb_mgmd.exe到該目錄下
(2)接著在ndb_data下面建ndb1和ndb2兩個文件夾,並從mysql-cluster安裝目錄下的bin文件夾復制ndbd.exe到ndb1和ndb2文件夾下面
(3)然後在mysqld_data下面建mysqld1和mysqld2兩個文件夾
(4)從mysql-cluster下面復制data、share目錄,並從bin目錄下復制mysqld.exe、mysqladmin.exe到mysqld1和mysqld2文件夾下面
(5)接下來創建兩個my.ini文件內容如下
第一個:
[MYSQLD] ndbcluster datadir=D:/mydatabase/my_cluster/mysqld_data/mysqld1/data basedir=D:/MySQLCluster port=5000
datadir配置的是資料庫的數據目錄,basedir配置的是mysql-cluster的安裝目錄
第二個:
[MYSQLD] ndbcluster datadir=D:/mydatabase/my_cluster/mysqld_data/mysqld2/data basedir=D:/MySQLCluster port=5001
第一個my.ini放在mysqld1文件夾下面,第二個則放在mysqld2文件夾下面
3 在基本目錄下面創建一個名為config.ini的文件內容如下
[MYSQLD] Id=21 [MYSQLD] Id=22 [ndb_mgmd] hostname=localhost datadir=D:/mydatabase/my_cluster/mgm_data id=1 [NDBD DEFAULT] NoOfReplicas=2 DataMemory=80M IndexMemory=18M [ndbd] hostname=localhost id=11 [ndbd] hostname=localhost id=12
datadir配置的是管理節點的目錄,管理節點對數據節點和資料庫服務節點進行統一管理
4 啟動管理節點
命令為:ndb_mgmd.exe -f config.ini –initial
第一次啟動的時候需要加–initial參數,但是後面啟動的時候就不需要瞭
4 啟動數據節點
分別進入每一個數據節點,也就是ndb1和ndb2目錄下執行:ndbd -c localhost:1186
以同樣的方式啟動第二個數據節點
5 啟動mysql服務節點
同樣的進入mysql服務節點目錄也就是mysqld1和mysqld2目錄,執行:mysqld.exe –defaults-file=my.ini
還是以相同的方法啟動第二個mysql服務節點
以防萬一最好進入管理節點輸入:ndb_mgm.exe之後在輸入show回車,看看節點的狀態是否正常
如圖這種情況就說明節點都正常
6 接下來的工作就簡單瞭,隻需打開圖形界面工具,連接5000和5001的資料庫,接在在5000的這個mysql上隨便建一個資料庫並創建一張表,這裡需要註意的是表的引擎應該使用ndb才可以。之後添加幾條數據,我們可以看到在5001的mysql上也可以看到在5000上創建的資料庫,且表的信息一致
為瞭能順利執行各種命令,建議使用管理員身份執行命令,否則很有可能出現命令執行不成功的情況