下文中沒有特別指出的地方,都是兩台伺服器都需要執行的命令,並且由於是雙管理中心配置,其實兩台機器出了一些標識id和ip的配置不同外,其他參數配置都是基本上的
http:// dev.mysql.com/downloads/cluster/
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. -----------------------------------------------------------
1)執行以下指令:
# cd /var/lib/mysql-cluster # vi config.ini
2)設定config.ini文件,如附件
100.218的設定檔:
config.ini
設定資訊:
[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 [mgm] HostName=192.168.100.217 NodeId=61 [ndbd default] NoOfReplicas = 2 DataMemory = 50M IndexMemory = 50M MaxNoOfTables = 1024 MaxNoOfAttributes = 5000000 MaxNoOfOrderedIndexes = 10000 [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的設定檔
config.ini
[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 [mgm] HostName=192.168.100.217 NodeId=61 [ndbd default] NoOfReplicas = 2 DataMemory = 50M IndexMemory = 50M MaxNoOfTables = 1024 MaxNoOfAttributes = 5000000 MaxNoOfOrderedIndexes = 10000 [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
修改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
1)啟動mysql-cluster
執行初次啟動前請先確認將兩台機器的防火牆關閉(service iptables stop 或設定防火牆連接埠可通,兩個連接埠即通訊埠1186、資料埠3306 )
初次啟動mgt console指令: ndb_mgmd -f /var/lib/mysql-cluster/config.ini (初始化需要加--initial)
啟動均衡節點命令: 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('*FD5712039749697406973009730 ,設定完以後,登陸還必須使用密文,那好吧,就用密文進去,進去後使用如下命令,強制使用明文進行登陸
use mysql; delete from user; grant all on *.* to root@'%' identified by "111111" with grant option; flush privileges; quit;然後,可以使用明文密碼登陸了
幾台裝有SQL資料節點的伺服器皆需要執行一遍上述指令;
在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;
如果发现有数据,则表示功能完备
关闭数据节点:# mysqld stop (SQL节点可以用mysqladmin shutdown或别的方式关闭。)
在管理节点上执行:# ndb_mgm -e shutdown
将安全的关闭管理节点和数据节点。
关闭后使用如下的进程检测命令查看一下是否退出来了:
# pgrep mysqld # ps aux | grep nbdb
如果没有,找到对应的pid进行kill 操作即可
kill -9 进程号
启动整个cluster的次序,注意,一些语句已经减去了初始化的内容:
ndb_mgmd -f /var/lib/mysql-cluster/config.ini ndbd mysqld_safe --defaults-file=/usr/my.cnf --explicit_defaults_for_timestamp &
1、mysql安装后,默认会自动启动的,每次启动cluster的时候,都需要先把mysql的服务关闭,太麻烦,于是可以执行如下命令(我出手有点狠):
chkconfig --level 123456 mysql off
2、防火墙问题,偷个懒,我懒得去一一开放端口,干脆把防火墙直接关了(极不推荐的做法)
chkconfig --level 123456 iptables off
以上是MySQL之-Cluster叢集搭建(基於RPM安裝包 雙管理中心)詳解的詳細內容。更多資訊請關注PHP中文網其他相關文章!