mysql數據庫集群

jopen 10年前發布 | 14K 次閱讀 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的文件內容如下

</div>

  1. [MYSQLD]  
  2. Id=21   
  3. [MYSQLD]  
  4. Id=22  
  5. [ndb_mgmd]   
  6. hostname=localhost   
  7. datadir=D:/mydatabase/my_cluster/mgm_data  
  8. id=1   
  9. [NDBD DEFAULT]   
  10. NoOfReplicas=2    
  11. DataMemory=80M    
  12. IndexMemory=18M    
  13. [ndbd]   
  14. hostname=localhost   
  15. id=11   
  16. [ndbd]   
  17. hostname=localhost   
  18. id=12   
  19. </ol> </div>
    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上創建的數據庫,且表的信息一致

     

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

    來自:http://blog.csdn.net/smartcodekm/article/details/38798835

 本文由用戶 jopen 自行上傳分享,僅供網友學習交流。所有權歸原作者,若您的權利被侵害,請聯系管理員。
 轉載本站原創文章,請注明出處,并保留原始鏈接、圖片水印。
 本站是一個以用戶分享為主的開源技術平臺,歡迎各類分享!