Mysql Cluster搭建

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/

image.png

我這里選擇了通用的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
image.png

這里我因為是已經(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
image.png

將箭頭配置的目錄替換你安裝的目錄

  • 初始化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
image.png

5.配置mysql密碼艾凯,并且可以遠(yuǎn)程登錄

/usr/local/mysql/mysql-cluster/bin/mysql -uroot -p

輸入開始獲取的密碼進入


image.png

GRANT ALL PRIVILEGES ON. TO 'root'@'%' IDENTIFIED BY '123456' WITH GRANT OPTION;
配置mysql密碼創(chuàng)建用戶都和普通的mysql一樣的

這樣整個搭建算是完成了,讀者可以用客戶端自行測試節(jié)點的數(shù)據(jù)是否可以同步(記住mysql cluster集群只能同步ndb引擎的表)

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末懂傀,一起剝皮案震驚了整個濱河市趾诗,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌蹬蚁,老刑警劉巖恃泪,帶你破解...
    沈念sama閱讀 217,907評論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異犀斋,居然都是意外死亡贝乎,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,987評論 3 395
  • 文/潘曉璐 我一進店門叽粹,熙熙樓的掌柜王于貴愁眉苦臉地迎上來糕非,“玉大人,你說我怎么就攤上這事球榆⌒喾剩” “怎么了?”我有些...
    開封第一講書人閱讀 164,298評論 0 354
  • 文/不壞的土叔 我叫張陵持钉,是天一觀的道長衡招。 經(jīng)常有香客問我,道長每强,這世上最難降的妖魔是什么始腾? 我笑而不...
    開封第一講書人閱讀 58,586評論 1 293
  • 正文 為了忘掉前任州刽,我火速辦了婚禮,結(jié)果婚禮上浪箭,老公的妹妹穿的比我還像新娘穗椅。我一直安慰自己,他們只是感情好奶栖,可當(dāng)我...
    茶點故事閱讀 67,633評論 6 392
  • 文/花漫 我一把揭開白布匹表。 她就那樣靜靜地躺著,像睡著了一般宣鄙。 火紅的嫁衣襯著肌膚如雪袍镀。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,488評論 1 302
  • 那天冻晤,我揣著相機與錄音苇羡,去河邊找鬼。 笑死鼻弧,一個胖子當(dāng)著我的面吹牛设江,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播攘轩,決...
    沈念sama閱讀 40,275評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼绣硝,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了撑刺?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,176評論 0 276
  • 序言:老撾萬榮一對情侶失蹤握玛,失蹤者是張志新(化名)和其女友劉穎够傍,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體挠铲,經(jīng)...
    沈念sama閱讀 45,619評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡冕屯,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,819評論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了拂苹。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片安聘。...
    茶點故事閱讀 39,932評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖瓢棒,靈堂內(nèi)的尸體忽然破棺而出浴韭,到底是詐尸還是另有隱情,我是刑警寧澤脯宿,帶...
    沈念sama閱讀 35,655評論 5 346
  • 正文 年R本政府宣布念颈,位于F島的核電站,受9級特大地震影響连霉,放射性物質(zhì)發(fā)生泄漏榴芳。R本人自食惡果不足惜嗡靡,卻給世界環(huán)境...
    茶點故事閱讀 41,265評論 3 329
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望窟感。 院中可真熱鬧讨彼,春花似錦、人聲如沸柿祈。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,871評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽谍夭。三九已至黑滴,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間紧索,已是汗流浹背袁辈。 一陣腳步聲響...
    開封第一講書人閱讀 32,994評論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留珠漂,地道東北人晚缩。 一個月前我還...
    沈念sama閱讀 48,095評論 3 370
  • 正文 我出身青樓,卻偏偏與公主長得像媳危,于是被迫代替她去往敵國和親荞彼。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,884評論 2 354

推薦閱讀更多精彩內(nèi)容