1. Laden Sie MySQL-Cluster 7.3.7 herunter
http://dev.mysql.com/downloads/cluster/
2. Umgebung Reinigung und Installation
1) Bereinigen Sie den MySQL-Dienst, der mit CentOS6.5 geliefert wird. Ich muss den ersten Befehl nicht ausführen. Wenn er auf anderen Systemen nicht funktioniert, wird empfohlen, ihn auszuführen
# yum -y remove mysql # rpm -qa | grep mysql* # rpm -e --nodeps mysql-libs-5.1.71-1.el6.x86_64
2) Umgebungsvorbereitung
Ordner erstellen (unterteilt in die folgenden drei Kategorien, um entsprechende Ordner zu erstellen)
存储节点:# 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 installieren
首先解压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
Achten Sie besonders darauf, dass nach der Installation des Server-GPL-Pakets die folgende Eingabeaufforderungsmeldung angezeigt wird, die uns daran erinnert, dass das erste Superkontokennwort nach der Installation des gesamten Clusters in der Datei /root/.mysql_secret vorhanden ist .
--------------------------------------------------------------------------------------------------------------------- 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. -----------------------------------------------------------
3. Konfigurieren Sie den Verwaltungsknoten
1) Führen Sie den folgenden Befehl aus:
# cd /var/lib/mysql-cluster # vi config.ini
2) Konfigurieren Sie die Datei config.ini angehängte
100.218 Konfigurationsdatei:
config.ini
Konfigurationsinformationen:
[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 Konfigurationsdatei
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
Tatsächlich gibt es keinen großen Unterschied zwischen den beiden Dateien, er liegt lediglich im Namen und der ID in der Computerkonfiguration
Konfiguration von SQL-Knoten und Datenknoten
Ändern Sie die Datei my.cnf und fügen Sie den folgenden Inhalt hinzu:
[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
5. MySQL-Cluster-Erststartbefehl und Anpassung des Benutzerkennworts: (Bitte beginnen Sie streng gemäß der Bestellung)
1) MySQL-Cluster starten
Bevor Sie den ersten Start durchführen, stellen Sie bitte sicher, dass die Firewalls der beiden Maschinen ausgeschaltet sind (Dienst iptables stoppen oder den Firewall-Port so einstellen, dass er zugänglich ist). , die beiden Ports sind Kommunikationsport 1186 und Datenport 3306)
Erster Start-MGT-Konsolenbefehl: NDB_MGMD -F /VAR/Lib/mysql-Cluster/config.ini (bei der Initialisierung muss --initial hinzugefügt werden)
Starten ausgleichbarer Knotenbefehl: NDBD-ITIAL
Startdatenknotenbefehl: MySQLD_SAFE--defaults-file=/usr/my.cnf --explicit_defaults_for_timestamp &
my.cnf befindet sich in einigen Systemen im Verzeichnis etc
Beachten Sie, dass Sie während des Startvorgangs die gesamte Konsolenausgabe überwachen müssen. Wenn Sie Fehlermeldungen finden, müssen Sie diese umgehend entsprechend dem Inhalt des Fehlerprotokolls beheben.
--------------------------------- --- -------------------------------- --- --------
Wenn alles normal ist, verwenden Sie den folgenden Befehl, um die Verwaltungskonsole zu öffnen: ndb_mgm
Ausführen # show
Überprüfen Sie wie folgt, ob jeder Knoten vollständig gestartet wurde , jeder Knoten wurde verbunden. Wenn es einen Knoten gibt, der nicht verbunden ist, wird
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)
angezeigt. Wenn es einen Knoten gibt, der nicht verbunden ist, wird wie unten gezeigt die Zeile mit der ID=81 angezeigt bedeutet, dass keine Verbindung besteht. Überprüfen Sie den Fehlerpunkt
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) Ändern Sie das Passwort
Wenn mysqld normal startet (Sie können pgrep mysqld verwenden, um die Prozess-ID abzurufen), können wir verwenden Verwenden Sie den folgenden Befehl, um es zu ändern:
mysql -u root -p;
Zufälliges Passwort (spezifisch Bitte beziehen Sie sich auf die Datei /root/.mysql_secret, um es zu erhalten). Verwenden Sie nach der Eingabe den folgenden Befehl, um das Passwort zu ändern:
SET PASSWORD = PASSWORD('new password');
Aber dieses neue Passwort muss ein Hash-Wert sein, also verwenden Sie die folgende Methode, um den Hash-Wert der Passwortzeichenfolge zu erhalten
select password('111111' );
Wenn Sie den obigen Befehl ausführen, müssen Sie jedoch zuerst das Passwort festlegen, was frustrierend ist, aber es kommt wieder zurück. Gehen Sie dann zu MySQL und führen Sie es an einer anderen Stelle aus. Fahren Sie fort
Der Hash-Wert von 111111 ist „* FD571203974BA9AFE270FE62151AE967ECA5E0AA"
SET PASSWORD = PASSWORD('*FD571203974BA9AFE270FE62151AE967ECA5E0AA');
So deprimierend, Einstellung. Danach müssen Sie immer noch Chiffretext verwenden, um sich anzumelden, okay? Verwenden Sie einfach ci Geben Sie nach der Eingabe den Phertext ein Befolgen Sie den Befehl, um die Verwendung von Klartext für die Anmeldung zu erzwingen
use mysql; delete from user; grant all on *.* to root@'%' identified by "111111" with grant option; flush privileges; quit;
然后,可以使用明文密码登陆了 几台装有SQL数据节点的服务器皆需要执行一遍上述命令; 6、当上面步奏都操作完成以后,测试cluster是否正常工作 1)简单功能测试 在218上进入mysql后执行如下:
create database clustertest; use clustertest; CREATE TABLE testtable(Count INT) ENGINE=NDBCLUSTER;
Hinweis: Die Engine muss NDBCLUSTER zum Synchronisieren verwenden, andernfalls wird die Synchronisierung nicht fortgesetzt Überprüfen Sie, ob es erfolgreich ist. Gehen Sie zu MySQL und prüfen Sie, ob die Datenbank und die Tabelle automatisch erstellt werden. Wenn dies fehlschlägt, überprüfen Sie bitte die Umgebungskonfiguration.
2) Testen Sie, ob die Daten vorhanden sind befindet sich in der Notfallwiederherstellung Kann synchronisiert werden (wenn eine Datenbank gestoppt wird, werden die verlorenen Daten automatisch wieder aufgefüllt, wenn sie erneut gestartet wird)
Stoppen Sie den MySQL-Dienst auf 217 und führen Sie ihn auf 218 aus
insert into testtable values (1);
select * from testtable;
Auf dem Verwaltungsknoten ausführen: # ndb_mgm -e Shutdown
fährt den Verwaltungsknoten und den Datenknoten sicher herunter.
Verwenden Sie nach dem Schließen den folgenden Prozesserkennungsbefehl, um zu überprüfen, ob er beendet wurde:
# pgrep mysqld # ps aux | grep nbdb
kill -9 Prozessnummer
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 config.ini文件配置详解:
http://note.youdao.com/share/?id=376407a1136d2032afb6ef68aa39fba5&type=note
http://note.youdao.com/share/?id=3906996cbe3298a22fbb5a2196d6cbed&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
以上就是 MySQL之——MySQL Cluster集群搭建详解(基于RPM安装包 双管理中心)的内容,更多相关内容请关注PHP中文网(m.sbmmt.com)!