MySQL叢集搭建詳解(三種結點分離)

來源:互聯網
上載者:User

標籤:

本文將搭建一個最簡化的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中運行以下命令:
gedit /etc/my.cnf
 設定檔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中運行以下命令:
gedit /etc/my.cnf
 設定檔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來監聽用戶端,如下:
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叢集搭建詳解(三種結點分離)

聯繫我們

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