MySQL叢集搭建(所有節點在同一台機子上)

來源:互聯網
上載者:User

標籤:

轉自:http://www.2cto.com/database/201408/328954.html

加了一些遇到的錯誤及其解決方案;

------------------------------------------------華麗的分割線--------------------------------------------------------

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上建立的資料庫,且表的資訊一致

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

 

 

? 根據上述方法搭建好了叢集,但是沒有同步成功,明天看看是什麼原因,再做補充!

 

MySQL叢集搭建(所有節點在同一台機子上)

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.