CentOS6.5安裝mysql cluster7.3.7 搭建mysql資料庫叢集環境(雙管理中心),centos6.5安裝mysql

來源:互聯網
上載者:User

CentOS6.5安裝mysql cluster7.3.7 搭建mysql資料庫叢集環境(雙管理中心),centos6.5安裝mysql
MySQL Cluster 是一種技術,該技術允許在無共用的系統中部署“記憶體中”資料庫的 Cluster 。通過無共用體繫結構,系統能夠使用廉價的硬體,而且對軟硬體無特殊要求。此外,由於每個組件有自己的記憶體和磁碟,不存在單點故障。MySQL Cluster 由一組電腦構成,每台電腦上均運行著多種進程,包括MySQL伺服器,NDB Cluster 的資料節點,管理伺服器,以及(可能)專門的資料訪問程式。
下文中沒有特別指出的地方,都是兩台伺服器都需要執行的命令,並且由於是雙管理中心配置,其實兩台機器出了一些標識id和ip的配置不同外,其他參數配置都是基本一樣的
1、下載mysql-cluster 7.3.7

http://dev.mysql.com/downloads/cluster/

2、環境清理及安裝    1)清理CentOS6.5內建的mysql服務,其中第一個命令我不執行也可以,其他系統如果不可以,還是建議執行
# yum -y remove mysql# rpm -qa | grep mysql*# rpm -e --nodeps mysql-libs-5.1.71-1.el6.x86_64
    2)環境準備  
建立檔案夾(分如下3個類來建立對應的檔案夾)
儲存節點:# mkdir /var/lib/mysql/data 
管理節點:# mkdir /var/lib/mysql-cluster    SQL節點:可不用  檔案夾授權
進程DIR:# mkdir /var/run/mysqld              
  
使用如下的命令來變更許可權保證可寫入:
# chmod -R 1777 /var/lib/mysql
# chmod -R 1777 /var/run/mysqld
# chmod -R 1777 /var/lib/mysql-cluster

    3)安裝mysql-cluster
首先解壓MySQL-Cluster-gpl-7.4.2-1.el6.x86_64.rpm-bundle.tar
# tar xvf MySQL-Cluster-gpl-7.4.2-1.el6.x86_64.rpm-bundle.tar
然後執行如下命令安裝
# rpm -ivh MySQL-Cluster-server-gpl-7.3.4-1.el6.x86_64.rpm
# rpm -ivh MySQL-Cluster-client-gpl-7.3.4-1.el6.x86_64.rpm

特別注意,當安裝完畢server gpl包後,將出現如下提示資訊,提醒我們整個cluster安裝後的初次超級賬戶密碼存在/root/.mysql_secret這個檔案當中。
---------------------------------------------------------------------------------------------------------------------
A RANDOM PASSWORD HAS BEEN SET FOR THE MySQL root USER !
 You will find that password in '/root/.mysql_secret'.
 You must change that password on your first connect,
 no other statement but 'SET PASSWORD' will be accepted.
 See the manual for the semantics of the 'password expired' flag.
 Also, the account for the anonymous user has been removed.
 In addition, you can run:
  /usr/bin/mysql_secure_installation
 which will also give you the option of removing the test database.
 This is strongly recommended for production servers.
 -----------------------------------------------------------

2、組態管理節點
1)執行如下命令:
# cd /var/lib/mysql-cluster
# vi config.ini
2)配置config.ini檔案,如附件
100.218的設定檔:
[computer]
 Id=mgr-server-01
 HostName=192.168.100.218


 [mgm default]
 datadir=/var/lib/mysql-cluster


 [mgm]
 HostName=192.168.100.218
 NodeId=60
 ExecuteOnComputer=mgr-server-01
 PortNumber=1186
 ArbitrationRank=2
 
 [mgm]
 HostName=192.168.100.217
 NodeId=61
 ExecuteOnComputer=mgr-server-01
 PortNumber=1186
 ArbitrationRank=2


 [ndbd default]
 NoOfReplicas=2
 DataMemory=500M
 IndexMemory=500M


 [ndbd]
 HostName=192.168.100.217
 DataDir=/var/lib/mysql
 NodeId=1


 [ndbd]
 HostName=192.168.100.218
 DataDir=/var/lib/mysql
 NodeId=2


 [mysqld]
 HostName=192.168.100.217
 NodeId=81


 [mysqld]
 HostName=192.168.100.218
 NodeId=82

100.217的設定檔:
[computer]
 Id=mgr-server-02
 HostName=192.168.100.217


 [mgm default]
 datadir=/var/lib/mysql-cluster


 [mgm]
 HostName=192.168.100.218
 NodeId=60
 ExecuteOnComputer=mgr-server-01
 PortNumber=1186
 ArbitrationRank=2
 
 [mgm]
 HostName=192.168.100.217
 NodeId=61
 ExecuteOnComputer=mgr-server-01
 PortNumber=1186
 ArbitrationRank=2


 [ndbd default]
 NoOfReplicas=2
 DataMemory=500M
 IndexMemory=500M


 [ndbd]
 HostName=192.168.100.217
 DataDir=/var/lib/mysql
 NodeId=1


 [ndbd]
 HostName=192.168.100.218
 DataDir=/var/lib/mysql
 NodeId=2


 [mysqld]
 HostName=192.168.100.217
 NodeId=81


 [mysqld]
 HostName=192.168.100.218
 NodeId=82

其實兩個檔案差別不大,就在於computer配置中的名稱和標識id

3、SQL節點和資料節點的配置
修改my.cnf檔案,添加如下內容: [client] socket=/var/lib/mysql/mysql.sock [mysqld] max_connections=100 datadir=/var/lib/mysql socket=/var/lib/mysql/mysql.sock ndbcluster ndb-connectstring=192.168.100.218,192.168.100.217 [mysqld_safe] log-error=/var/log/mysqld.log #pid-file=/var/run/mysqld/mysqld.pid pid-file=/var/lib/mysql/mysqld.pid
 [mysql_cluster] ndb-connectstring=192.168.100.218,192.168.100.217

4、MySQL Cluster初次啟動命令以及使用者密碼更改調整:(請嚴格按照次序啟動)
1)啟動mysql-cluster
執行初次啟動前請先確認 將兩台機器的防火牆關閉(service iptables stop 或者 設定 防火牆連接埠可通,兩個連接埠即通訊連接埠1186、資料連接埠3306 )
初次啟動mgt console命令:ndb_mgmd -f /var/lib/mysql-cluster/config.ini
啟動均衡節點命令:              ndbd --initial
啟動資料節點命令:              mysqld_safe --defaults-file=/usr/my.cnf --explicit_defaults_for_timestamp &

my.cnf在有些系統中是在etc目錄下
注意在啟動過程中需要監測整個控制台輸出,發現有錯誤資訊需要及時解決,根據錯誤記錄檔內容來解決。
---------------------------------------------------------------------------------------------------------
如果一起正常,使用如下命令將Management console開啟:  ndb_mgm
執行# show
檢查是否各個節點都已經完全啟動,如下,每個節點都已經串連,如果有節點沒串連,會看到
ndb_mgm> show
Connected to Management Server at: 192.168.100.218:1186
Cluster Configuration
---------------------
[ndbd(NDB)] 2 node(s)
id=1 @192.168.100.217 (mysql-5.6.21 ndb-7.4.2, Nodegroup: 0)
id=2 @192.168.100.218 (mysql-5.6.21 ndb-7.4.2, Nodegroup: 0, *)
[ndb_mgmd(MGM)] 1 node(s)
id=60 @192.168.100.218 (mysql-5.6.21 ndb-7.4.2)
id=61 @192.168.100.217 (mysql-5.6.21 ndb-7.4.2)
[mysqld(API)] 2 node(s)
id=81 @192.168.100.217 (mysql-5.6.21 ndb-7.4.2)
id=82 @192.168.100.218 (mysql-5.6.21 ndb-7.4.2)
如果有節點沒串連,如下,id=81一行,表示沒串連,檢查問題故障點
ndb_mgm> show
Cluster Configuration
---------------------
[ndbd(NDB)] 2 node(s)
id=1 @192.168.100.217 (mysql-5.6.21 ndb-7.4.2, Nodegroup: 0)
id=2 @192.168.100.218 (mysql-5.6.21 ndb-7.4.2, Nodegroup: 0, *)
[ndb_mgmd(MGM)] 1 node(s)
id=60 @192.168.100.218 (mysql-5.6.21 ndb-7.4.2)
id=61 @192.168.100.217 (mysql-5.6.21 ndb-7.4.2)
[mysqld(API)] 2 node(s)
id=81 (not connected, accepting connect from 192.168.100.217)
id=82 @192.168.100.218 (mysql-5.6.21 ndb-7.4.2)


2)修改密碼
當mysqld 啟動完畢正常後(可以使用pgrep mysqld來擷取進程ID),我們可以使用如下命令修改:
mysql -u root -p;
隨機密碼(具體請參見/root/.mysql_secret檔案擷取),進入後使用如下指令修改密碼:
SET PASSWORD = PASSWORD('新密碼');
但是這個新密碼,必須是hash值,所以要使用如下方式擷取密碼字串的hash值
select password('111111');
然而執行上面命令,會讓你先設定密碼,鬱悶,又繞回來了,那就去其他地方的mysql上執行下吧111111的hash值是“*FD571203974BA9AFE270FE62151AE967ECA5E0AA”SET PASSWORD = PASSWORD('*FD571203974BA9AFE270FE62151AE967ECA5E0AA');好鬱悶啊,設定完以後,登陸還必須使用密文,那好吧,就用密文進去,進去後使用如下命令,強制使用明文進行登陸use mysql;delete from user;grant all on *.* to root@'%' identified by "111111" with grant option;flush privileges;quit;然後,可以使用純文字密碼登陸了

 

幾台裝有SQL資料節點的伺服器皆需要執行一遍上述命令;

5、當上面步奏都操作完成以後,測試cluster是否正常工作
1)簡易功能測試
在218上進入mysql後執行如下:
create database clustertest;
use clustertest; 
CREATE TABLE testtable(Count INT) ENGINE=NDBCLUSTER; 注意:ENGINE=NDBCLUSTER; 引擎必須使用NDBCLUSTER才可以同步,否則不會進行同步
檢查是否成功,在217上,進去mysql,查看是否自動建立了database和table,如果建立,則表示成功,如果失敗,請檢查環境配置
2)測試災備情況下資料是否可以同步(一台資料庫停掉了,再啟動的時候,是否會將遺失的資料自動補充)
停掉217上的mysql服務,在218上執行
insert into testtable values (1);
啟動217的mysql服務,使用show確認217的資料庫節點已經串連上了,執行如下語句
select * from testtable;
如果發現有資料,則表示功能完備
6、關閉Cluster:(需要嚴格按照次序執行)

關閉資料節點:# mysqld stop  (SQL節點可以用mysqladmin shutdown或別的方式關閉。)

在管理節點上執行:# ndb_mgm -e shutdown

將安全的關閉管理節點和資料節點。

關閉後使用如下的進程檢測命令查看一下是否退出來了:

# pgrep mysqld

# ps aux | grep nbdb 

如果沒有,找到對應的pid進行kill 操作即可

kill -9 進程號

7、再次啟動Cluster方案:
啟動整個cluster的次序,注意,一些語句已經減去了初始化的內容:
ndb_mgmd -f /var/lib/mysql-cluster/config.ini
ndbd
mysqld_safe --defaults-file=/etc/my.cnf --explicit_defaults_for_timestamp &


備忘:1、mysql安裝後,預設會自動啟動的,每次啟動cluster的時候,都需要先把mysql的服務關閉,太麻煩,於是可以執行如下命令(我出手有點狠):
chkconfig --level 123456 mysql off
2、防火牆問題,偷個懶,我懶得去一一開放連接埠,乾脆把防火牆直接關了(極不推薦的做法)
chkconfig --level 123456iptables off

參考相關文檔:MySQL Cluster config.ini檔案配置詳解:    http://note.youdao.com/share/?id=376407a1136d2032afb6ef68aa39fba5&type=note

MySQL Cluster 備份與恢複 http://www.linuxidc.com/Linux/2013-06/85295.htm

MySQL Cluster安裝配置 http://www.linuxidc.com/Linux/2013-07/87705.htm

MySQL Cluster 3台機器搭建叢集環境 DOC http://www.linuxidc.com/Linux/2013-01/78249.htm

MySQL Cluster7.2線上增加資料節點存在重大弊端 http://www.linuxidc.com/Linux/2012-08/67605.htm

搭建MySQL-Cluster叢集架構   http://www.linuxidc.com/Linux/2014-05/102218.htm

著作權聲明:本文為博主原創文章,未經博主允許不得轉載。

相關文章

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.