Mysql Cluster簡介
MySQL Cluster 是一種技術(shù)赤惊,該技術(shù)允許在無共享的系統(tǒng)中部署“內(nèi)存中”數(shù)據(jù)庫的 Cluster 。通過無共享體系結(jié)構(gòu)凰锡,系統(tǒng)能夠使用廉價的硬件未舟,而且對軟硬件無特殊要求圈暗。此外,由于每個組件有自己的內(nèi)存和磁盤裕膀,不存在單點故障员串。
MySQL Cluster 由一組計算機構(gòu)成,每臺計算機上均運行著多種進程昼扛,包括MySQL服務(wù)器寸齐,NDB Cluster 的數(shù)據(jù)節(jié)點,管理服務(wù)器抄谐,以及(可能)專門的數(shù)據(jù)訪問程序渺鹦。關(guān)于 Cluster 中這些組件的關(guān)系。
“NDB” 是一種“內(nèi)存中”的存儲引擎蛹含,它具有可用性高和數(shù)據(jù)一致性等特點海铆。
MySQL Cluster 能夠使用多種故障切換和負(fù)載平衡選項配置NDB存儲引擎,但在 Cluster 級別上的存儲引擎上做這個最簡單挣惰。MySQL Cluster的NDB存儲引擎包含完整的數(shù)據(jù)集,僅取決于 Cluster本身內(nèi)的其他數(shù)據(jù)殴边。
目前憎茂,MySQL Cluster的 Cluster部分可獨立于MySQL服務(wù)器進行配置。在MySQL Cluster中锤岸, Cluster的每個部分被視為1個節(jié)點竖幔。
管理(MGM)節(jié)點:這類節(jié)點的作用是管理MySQL Cluster內(nèi)的其他節(jié)點,如提供配置數(shù)據(jù)是偷、啟動并停止節(jié)點拳氢、運行備份等。由于這類節(jié)點負(fù)責(zé)管理其他節(jié)點的配置蛋铆,應(yīng)在啟動其他節(jié)點之前首先啟動這類節(jié)點馋评。MGM節(jié)點是用命令“ndb_mgmd”啟動的。
數(shù)據(jù)節(jié)點:這類節(jié)點用于保存 Cluster的數(shù)據(jù)刺啦。數(shù)據(jù)節(jié)點的數(shù)目與副本的數(shù)目相關(guān)留特,是片段的倍數(shù)。例如玛瘸,對于兩個副本蜕青,每個副本有兩個片段,那么就有4個數(shù)據(jù)節(jié)點糊渊。不過沒有必要設(shè)置多個副本右核。數(shù)據(jù)節(jié)點是用命令“ndbd”啟動的。
SQL節(jié)點:這是用來訪問 Cluster數(shù)據(jù)的節(jié)點渺绒。對于MySQL Cluster贺喝,客戶端節(jié)點是使用NDB Cluster存儲引擎的傳統(tǒng)MySQL服務(wù)器菱鸥。通常,SQL節(jié)點是使用命令“mysqld –ndbcluster”啟動的搜变,或?qū)ⅰ皀dbcluster”添加到“my.cnf”后使用“mysqld”啟動采缚。 ——(采摘于百度百科)
搭建準(zhǔn)備
五臺linux服務(wù)器
一臺作為管理節(jié)點,兩臺數(shù)據(jù)節(jié)點挠他,兩臺sql節(jié)點
本次搭建采用1臺centos7.6扳抽, 4臺ubuntu,讀者可以自行選擇合適的系統(tǒng)殖侵。
192.168.69.133(管理節(jié)點)
192.168.69.136(數(shù)據(jù)節(jié)點)
192.168.69.71(數(shù)據(jù)節(jié)點)
192.168.69.111(sql節(jié)點)
192.168.69.202(sql節(jié)點)
1.下載mysql cluster
官方地址https://dev.mysql.com/downloads/cluster/
我這里選擇了通用的Mysql Cluster 7.6.12 用戶可以根據(jù)自己的系統(tǒng)自行選擇
2.安裝配置管理節(jié)點(GMG)
- 上傳并解壓文件
mkdir -p /usr/local/mysql
cd /usr/local/mysql (可用xftp上傳)
tar -zxvf mysql-cluster-gpl-7.6.12-linux-glibc2.12-x86_64.tar
mv mysql-cluster-gpl-7.6.12-linux-glibc2.12-x86_64 mysql-cluster
- 創(chuàng)建管理目錄
mkdir -p /var/log/mysql-cluster
mkdir -p /etc/mysql-cluster
- 配置目錄
vi /etc/mysql-cluster/config.ini
[ndbd default]
NoOfReplicas=2 #數(shù)據(jù)寫入數(shù)量贸呢。2表示兩份,2個數(shù)據(jù)節(jié)點
DataMemory=80M #配置數(shù)據(jù)存儲可使用的內(nèi)存
IndexMemory=18M #索引給100M
[ndb_mgmd]
nodeid=1
datadir=/var/log/mysql-cluster #管理結(jié)點的日志
HostName=192.168.69.133 #管理結(jié)點的IP地址。本機IP
###### data node options: #存儲結(jié)點
[ndbd]
HostName=192.168.69.136
DataDir=/data/mysql #mysql數(shù)據(jù)存儲路徑
nodeid=2
[ndbd]
HostName=192.168.69.71
DataDir=/data/mysql #mysql數(shù)據(jù)存儲路徑
nodeid=3
# SQL node options: #關(guān)于SQL結(jié)點
[mysqld]
HostName=192.168.69.111
nodeid=4
[mysqld]
HostName=192.168.69.202
nodeid=5
- 關(guān)閉防火墻拢军、開啟1186端口
firewall-cmd --zone=public --add-port=1186/tcp --permanent (--permanent永久生效楞陷,沒有此參數(shù)重啟后失效)
重新載入
firewall-cmd --reload
查看
firewall-cmd --zone= public --query-port=80/tcp
關(guān)閉防火墻
systemctl stop firewalld
- 初始化管理節(jié)點
/usr/local/mysql/mysql-cluster/bin/ndb_mgmd -f /etc/mysql-cluster/config.ini
- 查看集群的狀態(tài)
/usr/local/mysql/mysql-cluster/bin/ndb_mgm
ndb_mgm> show
這里我因為是已經(jīng)配置好了所以顯示都連接了,你們的應(yīng)該是只有管理節(jié)點的那個茉唉,其他的都是not connected
3.安裝配置數(shù)據(jù)節(jié)點(NDB)
- 上傳并解壓文件
mkdir -p /usr/local/mysql
cd /usr/local/mysql (可用xftp上傳)
tar -zxvf mysql-cluster-gpl-7.6.12-linux-glibc2.12-x86_64.tar
mv mysql-cluster-gpl-7.6.12-linux-glibc2.12-x86_64 mysql-cluster
- 創(chuàng)建mysql用戶并運行
useradd -M -s /sbin/nologin mysql
- 創(chuàng)建mysql目錄并授權(quán)
mkdir -p /etc/mysql
mkdir -p /data/mysql
chown -R mysql:mysql /data/mysql/
- 配置數(shù)據(jù)節(jié)點
vi /etc/mysql/my.cnf
[mysqld]
datadir=/data/mysql #mysql數(shù)據(jù)存儲路徑
ndbcluster #啟動ndb引擎
ndb-connectstring=192.168.69.133 #管理節(jié)點IP地址
[mysql_cluster]
ndb-connectstring=192.168.69.133 #管理節(jié)點IP地址
- 啟動數(shù)據(jù)節(jié)點
/usr/local/mysql/mysql-cluster/bin/ndbd --initial //只有當(dāng)?shù)谝淮蔚臅r候才有加 --intital 否則數(shù)據(jù)會丟
第二個數(shù)據(jù)節(jié)點同上一樣的配置固蛾。
4.安裝配置SQL節(jié)點(NDB)
- 上傳并解壓文件
mkdir -p /usr/local/mysql
cd /usr/local/mysql (可用xftp上傳)
tar -zxvf mysql-cluster-gpl-7.6.12-linux-glibc2.12-x86_64.tar
mv mysql-cluster-gpl-7.6.12-linux-glibc2.12-x86_64 mysql-cluster
- 創(chuàng)建mysql用戶并運行
useradd -M -s /sbin/nologin mysql
- 創(chuàng)建mysql目錄并授權(quán)
mkdir -p /etc/mysql
mkdir -p /data/mysql
chown -R mysql:mysql /data/mysql/
- 創(chuàng)建SQL節(jié)點配置文件
vi /etc/mysql/my.cnf
[mysqld]
user=mysql
ndbcluster #啟動ndb引擎
ndb-connectstring=192.168.69.133 #管理節(jié)點IP地址
[mysql_cluster]
ndb-connectstring=192.168.69.1333 #管理節(jié)點IP地址
- 配置mysql服務(wù)
cp /usr/local/mysql/mysql-cluster/support-files/mysql.server /etc/init.d/mysqld
chmod +x /etc/init.d/mysqld
update-rc.d mysqld defaults
- 編輯mysqld服務(wù)
vi /etc/init.d/mysqld
將箭頭配置的目錄替換你安裝的目錄
- 初始化mysql數(shù)據(jù)庫
執(zhí)行完命令 記得保存一下隨機產(chǎn)生的密碼
./mysqld --initialize --user=mysql --basedir=/usr/local/mysql/mysql-cluster --datadir=/data/mysql/
如果執(zhí)行./mysqld --initialize 后出現(xiàn)
./bin/mysqld: error while loading shared libraries: libaio.so.1: cannot open shared object file: No such file or directory
原因是沒有安裝libaio.so.1,安裝即可度陆。
Ubuntu下執(zhí)行:
apt-get install libaio1 libaio-dev
Redhat/Fedora/CentOS下執(zhí)行:
yum install libaio
- 啟動mysql服務(wù)
systemctl start mysqld
以下下有些常用命令
打開服務(wù):sudo systemctl start service
關(guān)閉服務(wù):sudo systemctl stop service
重啟服務(wù):sudo systemctl restart service
不中斷正常功能下重新加載服務(wù):sudo systemctl reload service
設(shè)置服務(wù)的開機自啟動:sudo systemctl enable service
關(guān)閉服務(wù)的開機自啟動:sudo systemctl disable service
查看活躍的單元:systemctl list-units
查看某個服務(wù)的狀態(tài):systemctl status service
查看已啟動的服務(wù)列表: systemctl list-unit-files|grep enabled
查看啟動失敗的服務(wù)列表:systemctl --failed
查看集群狀態(tài)
/usr/local/mysql/mysql-cluster/bin/ndb_mgm
ndb_mgm> show
5.配置mysql密碼艾凯,并且可以遠(yuǎn)程登錄
/usr/local/mysql/mysql-cluster/bin/mysql -uroot -p
輸入開始獲取的密碼進入
GRANT ALL PRIVILEGES ON. TO 'root'@'%' IDENTIFIED BY '123456' WITH GRANT OPTION;
配置mysql密碼創(chuàng)建用戶都和普通的mysql一樣的