mysql數據庫集群

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上創建的資料庫,且表的信息一致

為瞭能順利執行各種命令,建議使用管理員身份執行命令,否則很有可能出現命令執行不成功的情況

發佈留言

發佈留言必須填寫的電子郵件地址不會公開。 必填欄位標示為 *