Heim > Datenbank > MySQL-Tutorial > Hauptteil

MySQL – Detaillierte Erläuterung der MySQL-Cluster-Clusterkonstruktion (basierend auf dem RPM-Installationspaket)

黄舟
Freigeben: 2017-01-21 11:56:41
Original
1158 Leute haben es durchsucht

1. Laden Sie MySQL-Cluster 7.3.7 herunter

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

2. Umgebungsreinigung und Installation

1) Bereinigen Sie den mit CentOS6.5 gelieferten MySQL-Dienst. Wenn dies auf anderen Systemen nicht möglich ist, 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
Nach dem Login kopieren

2) Umgebungsvorbereitung

Ordner erstellen (unterteilt in die folgenden 3 Kategorien, um entsprechende Ordner zu erstellen)

存储节点:# mkdir /var/lib/mysql/data   
管理节点:# mkdir /var/lib/mysql-cluster    SQL节点:可不用  文件夹授权  
进程DIR:# mkdir /var/run/mysqld
Nach dem Login kopieren
使用如下的命令来变更权限保证可写入:  
# chmod -R 1777 /var/lib/mysql  
# chmod -R 1777 /var/run/mysqld  
# chmod -R 1777 /var/lib/mysql-cluster
Nach dem Login kopieren

3) MySQL-Cluster installieren


Entpacken Sie zuerst 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
Nach dem Login kopieren

Führen Sie dann den folgenden Befehl aus, um <🎜 zu installieren >

# 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
Nach dem Login kopieren
Besondere Achtung: Nach der Installation des Server-GPL-Pakets wird die folgende Eingabeaufforderungsmeldung angezeigt, die uns daran erinnert, dass das erste Superkontokennwort nach der Installation des gesamten Clusters in der Datei /root/ vorhanden ist. mysql_secret.

---------------------------------------------------------------------------------------------------------------------  
A RANDOM PASSWORD HAS BEEN SET FOR THE MySQL root USER !  
 You will find that password in &#39;/root/.mysql_secret&#39;.  
 You must change that password on your first connect,  
 no other statement but &#39;SET PASSWORD&#39; will be accepted.  
 See the manual for the semantics of the &#39;password expired&#39; 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.  
 -----------------------------------------------------------
Nach dem Login kopieren
2. Konfigurieren Sie den Verwaltungsknoten

1) Führen Sie den folgenden Befehl aus:

# cd /var/lib/mysql-cluster  
# vi config.ini
Nach dem Login kopieren
2) Konfigurieren Sie die Datei 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  
 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
Nach dem Login kopieren
3. 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  
 [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
Nach dem Login kopieren
4. Anpassung des MySQL-Cluster-Erststarts: (Bitte halten Sie sich strikt an die Startreihenfolge)

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 stoppt oder stellt den Firewall-Port auf passierbar ein). . Die beiden Ports sind Kommunikationsport 1186 und Datenport 3306)
MGT-Konsolenbefehl zum ersten Mal starten: ndb_mgmd -f /var/lib/mysql-cluster/config.ini
Balancing-Knotenbefehl starten: ndbd --initial
Befehl zum Starten des Datenknotens: mysqld_safe --defaults -file=/etc/my.cnf --explicit_defaults_for_timestamp &
Beachten Sie, dass die gesamte Konsolenausgabe während des Startvorgangs überwacht werden muss Werden Fehler gefunden, müssen diese umgehend und entsprechend dem Inhalt des Fehlerprotokolls behoben werden.
--------------------------------- --- -------------------------------- --- --------
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)  
[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)
Nach dem Login kopieren
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 das Problem und 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)  
[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)
Nach dem Login kopieren
2) Ändern Sie das Passwort

Wenn mysqld normal startet (Sie können pgrep mysqld verwenden, um die Prozess-ID abzurufen), werden wir Sie können den folgenden Befehl zum Ändern verwenden:

mysql -u root -p;
Nach dem Login kopieren
Zufälliges Passwort (siehe /root/ für Details) .mysql_secret-Datei), verwenden Sie den folgenden Befehl, um das Passwort nach der Eingabe zu ändern:


SET PASSWORD = PASSWORD(&#39;新密码&#39;);
Nach dem Login kopieren
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(&#39;111111&#39;);
Nach dem Login kopieren
Bei der Ausführung des obigen Befehls werden Sie jedoch gefragt Zuerst ein Passwort festlegen, was frustrierend ist und dann zurückkommt. Dann gehen Sie und führen Sie es anderswo auf MySQL aus

Der Hash-Wert von 111111 ist „* FD571203974BA9AFE270FE62151AE967ECA5E0AA“
SET PASSWORD = PASSWORD('*FD571203974BA9AFE270FE6 2151AE967ECA5E0AA');
Es ist so frustrierend. Nach der Einrichtung müssen Sie sich immer noch mit Chiffretext anmelden. Verwenden Sie einfach den folgenden Befehl: Erzwingen Sie die Verwendung von Klartext zum Anmelden

use mysql;  
delete from user;  
grant all on *.* to root@&#39;%&#39; identified by "111111" with grant option;  
flush privileges;  
quit;
Nach dem Login kopieren
Dann können Sie sich mit dem Klartextkennwort anmelden.

Mehrere Server mit SQL-Datenknoten müssen den obigen Befehl einmal ausführen.
5. Befolgen Sie die obigen Schritte. Nachdem alle Vorgänge abgeschlossen sind, testen Sie, ob der Cluster funktioniert funktioniert normal
1) Einfacher Funktionstest
Führen Sie nach der Eingabe von MySQL auf 218 Folgendes aus:

create database clustertest;  
use clustertest;   
CREATE TABLE testtable(Count INT) ENGINE=NDBCLUSTER;
Nach dem Login kopieren
Hinweis: ENGINE=NDBCLUSTER; Die Engine muss NDBCLUSTER verwenden. Andernfalls wird die Synchronisierung nicht durchgeführt.

Überprüfen Sie auf 217, ob die Datenbank und die Tabelle automatisch erstellt wurden. Wenn dies fehlschlägt, überprüfen Sie bitte die Umgebungskonfiguration
2) Testen Sie, ob Daten in Notfallwiederherstellungssituationen synchronisiert werden können (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);
Nach dem Login kopieren
Starten Sie den MySQL-Dienst von 217, bestätigen Sie mit show, dass der Datenbankknoten von 217 verbunden wurde, und führen Sie die folgende Anweisung aus


select * from testtable;
Nach dem Login kopieren
Wenn Daten gefunden werden, werden sie angezeigt bedeutet, dass die Funktion abgeschlossen ist

6. Cluster herunterfahren: (muss in strikter Übereinstimmung mit der Reihenfolge ausgeführt werden)
Datenknoten herunterfahren: # mysqld stop (SQL-Knoten können mit mysqladmin Shutdown heruntergefahren werden oder andere Methoden. )
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
Nach dem Login kopieren
Wenn nicht, suchen Sie die entsprechende PID und führen Sie den Kill-Vorgang aus

kill -9 Prozessnummer
7. Starten Sie den Cluster-Plan erneut:
Starten Sie die gesamte Cluster-Sequenz. Beachten Sie, dass einige Anweisungen vom Initialisierungsinhalt abgezogen wurden:

ndb_mgmd -f /var/lib/mysql-cluster/config.ini  
ndbd  
mysqld_safe --defaults-file=/etc/my.cnf --explicit_defaults_for_timestamp &
Nach dem Login kopieren

备注:
1、mysql安装后,默认会自动启动的,每次启动cluster的时候,都需要先把mysql的服务关闭,太麻烦,于是可以执行如下命令(我出手有点狠):
    chkconfig --level 123456 mysql off
2、防火墙问题,偷个懒,我懒得去一一开放端口,干脆把防火墙直接关了
    chkconfig --level 123456 mysql off

以上就是MySQL之——MySQL Cluster集群搭建详解(基于RPM安装包)的内容,更多相关内容请关注PHP中文网(www.php.cn)!


Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage
Über uns Haftungsausschluss Sitemap
Chinesische PHP-Website:Online-PHP-Schulung für das Gemeinwohl,Helfen Sie PHP-Lernenden, sich schnell weiterzuentwickeln!