MySQL 搭建負載平衡群集方法詳解(1/4)

來源:互聯網
上載者:User

本文我們的每個節點使用Debian Sarge Linux系統。其它Linux發行版本的安裝可能一點點
區別。MySQL的版本我們使用5.0.19。如果你不想使用MySQL 5,你也可以使用MySQL 4.1,盡
管我還沒有測試過。

本文是一篇實踐應用指導;它沒有涉及太多的理論。關於群集的理論你可以在網上找到很多。

一 伺服器

我使用下面的Debian伺服器,它們都在同一個網段(本例如:192.168.0.x):
sql1.test.com: 192.168.0.101 MySQL 叢集節點 1
sql2.test.com: 192.168.0.102 MySQL 叢集節點 2
loadb1.test.com: 192.168.0.103 負載平衡 1 / MySQL 群集管理伺服器
loadb2.test.com: 192.168.0.104 負載平衡 2
另外我們需要一個虛擬IP地址:192.168.0.105。它會安排給這個MySQL群集的負載平衡,以便於
應用程式通過統一單獨的IP地址來訪問群集。

儘管我們想在MySQL群集中使用兩個節點,但是我們仍然需要第三個節點,MySQL群集管理伺服器
,主要的一個原因是:如果其中一個MySQL叢集節點壞了,而MySQL群集管理伺服器沒有運行,那
麼兩個叢集節點上的資料將會不一致(“split brain”)。我們需要它來配置MySQL群集.

因此我們的安裝一般需要五台機器:

2個MySQL叢集節點 + 1個群集管理伺服器 + 2個負載平衡 = 5

因為群集管理伺服器沒有使用多少資源,系統將會空著什麼都不做,所以我們可以把我們的第一
個負載平衡和它一起放在同一台機器上,這樣可以節約我們一台伺服器,所以最好我們只需要四台
機器。

二 配置MySQL群集管理伺服器

首先我們要下載MySQL 5.0.19,並安裝群集管理伺服器(ndb_mgmd)和群集管理用戶端 (ndb_mgm - 它
可以用來監控群集的運行情況). 下面的步驟是在loadb1.test.com (192.168.0.103)上進行的:

 代碼如下 複製代碼

loadb1.test.com:

mkdir /usr/src/mysql-mgm
cd /usr/src/mysql-mgm
wget http://dev.mysql.com/get/Downloads/MySQL-5.0/mysql-max-5.0.19-linux-i686-
glibc23.tar.gz/from/http://www.mirrorservice.org/sites/ftp.mysql.com/
tar xvfz mysql-max-5.0.19-linux-i686-glibc23.tar.gz
cd mysql-max-5.0.19-linux-i686-glibc23
mv bin/ndb_mgm /usr/bin
mv bin/ndb_mgmd /usr/bin
chmod 755 /usr/bin/ndb_mg*
cd /usr/src
rm -rf /usr/src/mysql-mgm

下一步,我們必須建立群集的設定檔,/var/lib/mysql-cluster/config.ini:

 代碼如下 複製代碼

loadb1.test.com:

mkdir /var/lib/mysql-cluster
cd /var/lib/mysql-cluster
vi config.ini

———-
[NDBD DEFAULT]
NoOfReplicas=2
[MYSQLD DEFAULT]
[NDB_MGMD DEFAULT]
[TCP DEFAULT]
# Section for the cluster management node
[NDB_MGMD]
# IP address of the management node (this system)
HostName=192.168.0.103
# Section for the storage nodes
[NDBD]
# IP address of the first storage node
HostName=192.168.0.101
DataDir= /var/lib/mysql-cluster
[NDBD]
# IP address of the second storage node
HostName=192.168.0.102
DataDir=/var/lib/mysql-cluster
# one [MYSQLD] per storage node
[MYSQLD]
[MYSQLD]

———-
實際應用中請將檔案中的IP地址換成你相應的IP。
然後我們啟動群集管理伺服器:

 代碼如下 複製代碼

loadb1.test.com:

ndb_mgmd -f /var/lib/mysql-cluster/config.ini

我們應該也需要在伺服器啟動時能夠自動啟動管理伺服器,所以我們建立了一個非常簡單的初始化
指令碼和相應的啟動串連:

 代碼如下 複製代碼

loadb1.test.com:

echo ‘ndb_mgmd -f /var/lib/mysql-cluster/config.ini’ > /etc/init.d/ndb_mgmd
chmod 755 /etc/init.d/ndb_mgmd
update-rc.d ndb_mgmd defaults

首頁 1 2 3 4 末頁

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.