mysql用來開發中小型項目還是挺好用的,從節約成本的方面來考慮的確是個不錯的選擇,但是開發並發了比較大的項目顯然還是有些吃力的,前幾 年解決這種問題通常是通過讀寫分離來最佳化資料庫,因此出現了amoeba這個東西,現在這個東西已經被棄用了反倒是mysql-cluster-gpl用 的比較多。但是有關mysql叢集的配置還是比較繁瑣,好多人弄不出來就放棄了,可怕的是網上很多資料都是轉載別人的,都沒有經過自己實際的驗證,簡直就 是太坑爹了。這次我打算分享下有關mysql叢集的知識。
1 開發準備
下載mysql-cluster-gpl-7.X版本的msi或者exe檔案,雙擊後安裝位置隨意,安裝好之後目錄大致如下(ps:可以直接下載免安裝版本的)
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]ndbclusterdatadir=D:/mydatabase/my_cluster/mysqld_data/mysqld1/databasedir=D:/MySQLClusterport=5000
datadir配置的是資料庫的資料目錄,basedir配置的是mysql-cluster的安裝目錄
第二個:
[MYSQLD]ndbclusterdatadir=D:/mydatabase/my_cluster/mysqld_data/mysqld2/databasedir=D:/MySQLClusterport=5001
第一個my.ini放在mysqld1檔案夾下面,第二個則放在mysqld2檔案夾下面
3 在基本目錄下面建立一個名為config.ini的檔案內容如下
[MYSQLD]Id=21[MYSQLD]Id=22[ndb_mgmd]hostname=localhostdatadir=D:/mydatabase/my_cluster/mgm_dataid=1[NDBD DEFAULT]NoOfReplicas=2 DataMemory=80M IndexMemory=18M [ndbd]hostname=localhostid=11[ndbd]hostname=localhostid=12
datadir配置的是管理節點的目錄,管理節點對資料節點和資料庫服務節點進行統一管理
4 啟動管理節點
命令為:ndb_mgmd.exe -f config.ini --initial
第一次啟動的時候需要加--initial參數,但是後面啟動的時候就不需要了
PS:啟動管理節點時可能會報錯,不用管它,是因為其他節點還沒有啟起來;
4 啟動資料節點
分別進入每一個資料節點,也就是ndb1和ndb2目錄下執行:ndbd -c localhost:1186
以同樣的方式啟動第二個資料節點
PS:如果提示某檔案夾不存在時,在該目錄下建立好檔案夾即可,然後重新啟動;
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上建立的資料庫,且表的資訊一致
為了能順利執行各種命令,建議使用管理員身份執行命令,否則很有可能出現命令執行不成功的情況
? 根據上述方法搭建好了叢集,但是沒有同步成功,明天看看是什麼原因,再做補充!