Heim Datenbank MySQL-Tutorial MySQL - Detaillierte Erläuterung des MySQL-Cluster-Clusteraufbaus (basierend auf dem RPM-Installationspaket Dual Management Center)

MySQL - Detaillierte Erläuterung des MySQL-Cluster-Clusteraufbaus (basierend auf dem RPM-Installationspaket Dual Management Center)

Jan 21, 2017 pm 12:01 PM

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

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

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

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.  
-----------------------------------------------------------
Nach dem Login kopieren

3. 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 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
Nach dem Login kopieren

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

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

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)
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 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)
Nach dem Login kopieren

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;
Nach dem Login kopieren
然后,可以使用明文密码登陆了
几台装有SQL数据节点的服务器皆需要执行一遍上述命令;

6、当上面步奏都操作完成以后,测试cluster是否正常工作
1)简单功能测试
在218上进入mysql后执行如下:
Nach dem Login kopieren
create database clustertest;  
use clustertest;   
CREATE TABLE testtable(Count INT) ENGINE=NDBCLUSTER;
Nach dem Login kopieren

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);
Nach dem Login kopieren
Starten Sie den MySQL-Dienst 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, bedeutet dies, dass die Funktion abgeschlossen ist



7. Fahren Sie den Cluster herunter: (muss in strikter Übereinstimmung mit der Reihenfolge ausgeführt werden)

Schließen Sie den Datenknoten: # mysqld stop (SQL Knoten können mit mysqladmin Shutdown oder anderen Methoden heruntergefahren werden. )

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


8 Starten Sie den Clusterplan erneut:

Beachten Sie, dass einige Anweisungen vom Initialisierungsinhalt abgezogen wurden:

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

备注:

1、mysql安装后,默认会自动启动的,每次启动cluster的时候,都需要先把mysql的服务关闭,太麻烦,于是可以执行如下命令(我出手有点狠):

chkconfig --level 123456 mysql off
Nach dem Login kopieren

2、防火墙问题,偷个懒,我懒得去一一开放端口,干脆把防火墙直接关了(极不推荐的做法)

chkconfig --level 123456 iptables off
Nach dem Login kopieren

参考相关文档:

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中文网(www.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

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

MySQL: Einfache Konzepte für einfaches Lernen MySQL: Einfache Konzepte für einfaches Lernen Apr 10, 2025 am 09:29 AM

MySQL ist ein Open Source Relational Database Management System. 1) Datenbank und Tabellen erstellen: Verwenden Sie die Befehle erstellte und creatEtable. 2) Grundlegende Vorgänge: Einfügen, aktualisieren, löschen und auswählen. 3) Fortgeschrittene Operationen: Join-, Unterabfrage- und Transaktionsverarbeitung. 4) Debugging -Fähigkeiten: Syntax, Datentyp und Berechtigungen überprüfen. 5) Optimierungsvorschläge: Verwenden Sie Indizes, vermeiden Sie ausgewählt* und verwenden Sie Transaktionen.

Wie man phpmyadmin öffnet Wie man phpmyadmin öffnet Apr 10, 2025 pm 10:51 PM

Sie können PhpMyAdmin in den folgenden Schritten öffnen: 1. Melden Sie sich beim Website -Bedienfeld an; 2. Finden und klicken Sie auf das Symbol phpmyadmin. 3. Geben Sie MySQL -Anmeldeinformationen ein; 4. Klicken Sie auf "Login".

MySQL: Eine Einführung in die beliebteste Datenbank der Welt MySQL: Eine Einführung in die beliebteste Datenbank der Welt Apr 12, 2025 am 12:18 AM

MySQL ist ein Open Source Relational Database Management -System, das hauptsächlich zum schnellen und zuverlässigen Speicher und Abrufen von Daten verwendet wird. Sein Arbeitsprinzip umfasst Kundenanfragen, Abfragebedingungen, Ausführung von Abfragen und Rückgabergebnissen. Beispiele für die Nutzung sind das Erstellen von Tabellen, das Einsetzen und Abfragen von Daten sowie erweiterte Funktionen wie Join -Operationen. Häufige Fehler umfassen SQL -Syntax, Datentypen und Berechtigungen sowie Optimierungsvorschläge umfassen die Verwendung von Indizes, optimierte Abfragen und die Partitionierung von Tabellen.

Warum MySQL verwenden? Vorteile und Vorteile Warum MySQL verwenden? Vorteile und Vorteile Apr 12, 2025 am 12:17 AM

MySQL wird für seine Leistung, Zuverlässigkeit, Benutzerfreundlichkeit und Unterstützung der Gemeinschaft ausgewählt. 1.MYSQL bietet effiziente Datenspeicher- und Abruffunktionen, die mehrere Datentypen und erweiterte Abfragevorgänge unterstützen. 2. Übernehmen Sie die Architektur der Client-Server und mehrere Speichermotoren, um die Transaktion und die Abfrageoptimierung zu unterstützen. 3. Einfach zu bedienend unterstützt eine Vielzahl von Betriebssystemen und Programmiersprachen. V.

So verwenden Sie ein einzelnes Gewinde -Redis So verwenden Sie ein einzelnes Gewinde -Redis Apr 10, 2025 pm 07:12 PM

Redis verwendet eine einzelne Gewindearchitektur, um hohe Leistung, Einfachheit und Konsistenz zu bieten. Es wird E/A-Multiplexing, Ereignisschleifen, nicht blockierende E/A und gemeinsame Speicher verwendet, um die Parallelität zu verbessern, jedoch mit Einschränkungen von Gleichzeitbeschränkungen, einem einzelnen Ausfallpunkt und ungeeigneter Schreib-intensiver Workloads.

MySQL und SQL: Wesentliche Fähigkeiten für Entwickler MySQL und SQL: Wesentliche Fähigkeiten für Entwickler Apr 10, 2025 am 09:30 AM

MySQL und SQL sind wesentliche Fähigkeiten für Entwickler. 1.MYSQL ist ein Open -Source -Relational Database Management -System, und SQL ist die Standardsprache, die zum Verwalten und Betrieb von Datenbanken verwendet wird. 2.MYSQL unterstützt mehrere Speichermotoren durch effiziente Datenspeicher- und Abruffunktionen, und SQL vervollständigt komplexe Datenoperationen durch einfache Aussagen. 3. Beispiele für die Nutzung sind grundlegende Abfragen und fortgeschrittene Abfragen wie Filterung und Sortierung nach Zustand. 4. Häufige Fehler umfassen Syntaxfehler und Leistungsprobleme, die durch Überprüfung von SQL -Anweisungen und Verwendung von Erklärungsbefehlen optimiert werden können. 5. Leistungsoptimierungstechniken umfassen die Verwendung von Indizes, die Vermeidung vollständiger Tabellenscanning, Optimierung von Join -Operationen und Verbesserung der Code -Lesbarkeit.

Mysqls Platz: Datenbanken und Programmierung Mysqls Platz: Datenbanken und Programmierung Apr 13, 2025 am 12:18 AM

Die Position von MySQL in Datenbanken und Programmierung ist sehr wichtig. Es handelt sich um ein Open -Source -Verwaltungssystem für relationale Datenbankverwaltung, das in verschiedenen Anwendungsszenarien häufig verwendet wird. 1) MySQL bietet effiziente Datenspeicher-, Organisations- und Abruffunktionen und unterstützt Systeme für Web-, Mobil- und Unternehmensebene. 2) Es verwendet eine Client-Server-Architektur, unterstützt mehrere Speichermotoren und Indexoptimierung. 3) Zu den grundlegenden Verwendungen gehören das Erstellen von Tabellen und das Einfügen von Daten, und erweiterte Verwendungen beinhalten Multi-Table-Verknüpfungen und komplexe Abfragen. 4) Häufig gestellte Fragen wie SQL -Syntaxfehler und Leistungsprobleme können durch den Befehl erklären und langsam abfragen. 5) Die Leistungsoptimierungsmethoden umfassen die rationale Verwendung von Indizes, eine optimierte Abfrage und die Verwendung von Caches. Zu den Best Practices gehört die Verwendung von Transaktionen und vorbereiteten Staten

Überwachen Sie Redis Tröpfchen mit Redis Exporteur Service Überwachen Sie Redis Tröpfchen mit Redis Exporteur Service Apr 10, 2025 pm 01:36 PM

Eine effektive Überwachung von Redis -Datenbanken ist entscheidend für die Aufrechterhaltung einer optimalen Leistung, die Identifizierung potenzieller Engpässe und die Gewährleistung der Zuverlässigkeit des Gesamtsystems. Redis Exporteur Service ist ein leistungsstarkes Dienstprogramm zur Überwachung von Redis -Datenbanken mithilfe von Prometheus. In diesem Tutorial führt Sie die vollständige Setup und Konfiguration des Redis -Exporteur -Dienstes, um sicherzustellen, dass Sie nahtlos Überwachungslösungen erstellen. Durch das Studium dieses Tutorials erhalten Sie voll funktionsfähige Überwachungseinstellungen

See all articles