標籤:
本文將搭建一個最簡化的MySQL Cluster系統,配置方法中的所有命令都是以root賬戶運行。這個MySQL Cluster包含一個管理結點、兩個資料結點、兩個SQL結點,這五個結點會分別安裝在五個虛擬機器上,虛擬機器的名稱和IP如下所示:
| 管理結點 |
mysql-mgm |
192.168.124.141 |
| 資料結點 1 |
mysql-ndbd-1 |
192.168.124.142 |
| 資料結點 2 |
mysql-ndbd-2 |
192.168.124.143 |
| SQL 結點1 |
mysql-sql-1 |
192.168.124.144 |
| SQL 結點2 |
mysql-sql-2 |
192.168.124.145 |
一、公用配置請在三個虛擬機器上分別配置此處的配置項。
1. 安裝虛擬機器虛擬機器作業系統安裝CentOS 6.4的x86_64版本,使用NAT網路,並且還要安裝vmware-tools,具體安裝方法此處不詳述。
2. 拷貝mysql cluster下載以下版本的MySQL-Cluster:http://cdn.mysql.com/Downloads/MySQL-Cluster-7.3/mysql-cluster-gpl-7.3.4-linux-glibc2.5-x86_64.tar.gz 下載得到的壓縮包拷貝至虛擬機器的/root/Downloads目錄,然後在shell中運行以下命令:
| cd /root/Downloads tar -xvzf mysql-cluster-gpl-7.3.4-linux-glibc2.5-x86_64.tar.gz mv mysql-cluster-gpl-7.3.4-linux-glibc2.5-x86_64 /usr/local/mysql |
3. 關閉安全性原則關閉iptables防火牆(或者開啟防火牆的1186、3306連接埠),在Shell中運行以下命令:
| chkconfig --level 35 iptables off |
關閉SELinux,在Shell中運行以下命令:
| gedit /etc/selinux/config |
將config檔案中的SELINUX項改為disabled,修改後的config檔案的內容如下:
| # This file controls the state of SELinux on the system. # SELINUX= can take one of these three values: # enforcing - SELinux security policy is enforced. # permissive - SELinux prints warnings instead of enforcing. # disabled - No SELinux policy is loaded. SELINUX=disabled # SELINUXTYPE= can take one of these two values: # targeted - Targeted processes are protected, # mls - Multi Level Security protection. SELINUXTYPE=targeted |
最後重啟系統
二、組態管理結點(192.168.124.141)
1. 配置config.ini設定檔在shell中運行以下命令:
| mkdir /var/lib/mysql-clustercd /var/lib/mysql-clustergedit config.ini |
設定檔config.ini內容如下:
[ndbd default] NoOfReplicas=2 DataMemory=80M IndexMemory=18M [ndb_mgmd] NodeId=1 hostname=192.168.124.141 datadir=/var/lib/mysql-cluster [ndbd] NodeId=2 hostname=192.168.124.142 datadir=/usr/local/mysql/data[ndbd] NodeId=3 hostname=192.168.124.143 datadir=/usr/local/mysql/data[mysqld] NodeId=4 hostname=192.168.124.144 [mysqld] NodeId=5 hostname=192.168.124.145 |
2. 安裝管理結點安裝管理節點,不需要mysqld二進位檔案,只需要MySQL Cluster服務端程式(ndb_mgmd)和監聽用戶端程式(ndb_mgm)。在shell中運行以下命令:
| cp /usr/local/mysql/bin/ndb_mgm* /usr/local/bin cd /usr/local/bin chmod +x ndb_mgm* |
三、配置資料結點(192.168.124.142、192.168.124.143)
1. 添加mysql組和使用者在shell中運行以下命令:
| groupadd mysql useradd -g mysql mysql |
2. 配置my.cnf設定檔在shell中運行以下命令:
設定檔my.cnf的內容如下:
[mysqld] basedir=/usr/local/mysql datadir=/usr/local/mysql/data socket=/usr/local/mysql/sock/mysql.sock user=mysql # Disabling symbolic-links is recommended to prevent assorted security risks symbolic-links=0 [mysqld_safe] log-error=/var/log/mysqld.log pid-file=/var/run/mysqld/mysqld.pid [mysql_cluster] ndb-connectstring=192.168.124.141 |
3. 建立系統資料庫在shell中運行以下命令:
| cd /usr/local/mysql mkdir sock scripts/mysql_install_db --user=mysql --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data |
4. 設定資料目錄在shell中運行以下命令:
| chown -R root . chown -R mysql.mysql /usr/local/mysql/data chown -R mysql.mysql /usr/local/mysql/sock chgrp -R mysql . |
5. 配置MySQL服務在shell中運行以下命令:
| cp support-files/mysql.server /etc/rc.d/init.d/ chmod +x /etc/rc.d/init.d/mysql.server chkconfig --add mysql.server |
四、配置SQL結點(192.168.124.144、192.168.124.145)
1. 添加mysql組和使用者在shell中運行以下命令:
| groupadd mysql useradd -g mysql mysql |
2. 配置my.cnf設定檔在shell中運行以下命令:
設定檔my.cnf的內容如下:
[client] socket=/usr/local/mysql/sock/mysql.sock [mysqld] ndbcluster datadir=/usr/local/mysql/data socket=/usr/local/mysql/sock/mysql.sock ndb-connectstring=192.168.124.141 [mysql_cluster] ndb-connectstring=192.168.124.141 |
3. 建立系統資料庫在shell中運行以下命令:
| cd /usr/local/mysql mkdir sock scripts/mysql_install_db --user=mysql --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data |
4. 設定資料目錄在shell中運行以下命令:
| chown -R root . chown -R mysql.mysql /usr/local/mysql/data chown -R mysql.mysql /usr/local/mysql/sock chgrp -R mysql . |
5. 配置MySQL服務在shell中運行以下命令:
| cp support-files/mysql.server /etc/rc.d/init.d/ chmod +x /etc/rc.d/init.d/mysql.server chkconfig --add mysql.server |
五、Cluster環境啟動注意啟動順序:首先是管理節點,然後是資料節點,最後是SQL節點。
1. 啟動管理結點在shell中運行以下命令:
| ndb_mgmd -f /var/lib/mysql-cluster/config.ini |
還可以使用ndb_mgm來監聽用戶端,如下:
2. 啟動資料結點初次開機,則需要添加--initial參數,以便進行NDB節點的初始化工作。在以後的啟動過程中,則是不能添加該參數的,否則ndbd程式會清除在之前建立的所有用於恢複的資料檔案和記錄檔。
| /usr/local/mysql/bin/ndbd --initial |
如果不是初次開機,則執行下面的命令。
| /usr/local/mysql/bin/ndbd |
3. 啟動SQL結點若MySQL服務沒有運行,則在shell中運行以下命令:
| /usr/local/mysql/bin/mysqld_safe --user=mysql & |
4. 啟動測試查看管理節點,啟動成功:
六、叢集測試
1. 測試一現在我們在其中一個SQL結點上進行相關資料庫的建立,然後到另外一個SQL結點上看看資料是否同步。 在SQL結點1(192.168.124.144)上執行:
| shell> /usr/local/mysql/bin/mysql -u root -p mysql>show databases; mysql>create database aa; mysql>use aa; mysql>CREATE TABLE ctest2 (i INT) ENGINE=NDB; //這裡必須指定資料庫表的引擎為NDB,否則同步失敗 mysql> INSERT INTO ctest2 () VALUES (1); mysql> SELECT * FROM ctest2; |
然後在SQL結點2上看資料是否同步過來了 經過測試,在非master上建立資料,可以同步到master上查看錶的引擎是不是NDB,>show create table 表名;
2. 測試二關閉一個資料節點 ,在另外一個節點寫輸入,開啟關閉的節點,看資料是否同步過來。 首先把資料結點1重啟,然後在結點2上添加資料在SQL結點2(192.168.124.145)上操作如下:
| mysql> create database bb; mysql> use bb; mysql> CREATE TABLE ctest3 (i INT) ENGINE=NDB; mysql> use aa; mysql> INSERT INTO ctest2 () VALUES (3333); mysql> SELECT * FROM ctest2; |
等資料結點1啟動完畢,啟動資料結點1的服務
| #/usr/local/mysql/bin/ndbd --initial#service mysqld start |
然後登入進去查看資料
| # /usr/local/mysql/bin/mysql -u root –p |
可以看到資料已經同步過來了,說明資料可以雙向同步了。
七、關閉叢集1. 關閉管理節點和資料節點,只需要在管理節點(ClusterMgm--134)裡執行:
| shell> /usr/local/mysql/bin/ndb_mgm -e shutdown |
顯示
| Connected to Management Server at: localhost:1186 2 NDB Cluster node(s) have shutdown. Disconnecting to allow management server to shutdown. |
2. 然後關閉Sql節點(135,136),分別在2個節點裡運行:
| shell> /etc/init.d/mysql.server stop Shutting down MySQL... SUCCESS! |
注意:要再次啟動叢集,就按照第五部分的啟動步驟即可,不過這次啟動資料節點的時候就不要加”-initial”參數了。
MySQL叢集搭建詳解(三種結點分離)