Maison base de données tutoriel mysql MySQL - Explication détaillée de la construction du cluster MySQL Cluster (basée sur le package d'installation RPM)

MySQL - Explication détaillée de la construction du cluster MySQL Cluster (basée sur le package d'installation RPM)

Jan 21, 2017 am 11:56 AM

1. Téléchargez MySQL-cluster 7.3.7

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

2.

1) Nettoyez le service mysql fourni avec CentOS6.5. Je n'ai pas besoin d'exécuter la première commande. Si cela n'est pas possible sur d'autres systèmes, il est recommandé de l'exécuter

<.>2) Préparation de l'environnement
# yum -y remove mysql  
# rpm -qa | grep mysql*  
# rpm -e --nodeps mysql-libs-5.1.71-1.el6.x86_64
Copier après la connexion

Créer des dossiers (divisés dans les 3 catégories suivantes pour créer les dossiers correspondants)

存储节点:# mkdir /var/lib/mysql/data   
管理节点:# mkdir /var/lib/mysql-cluster    SQL节点:可不用  文件夹授权  
进程DIR:# mkdir /var/run/mysqld
Copier après la connexion
3) Installer mysql-cluster
使用如下的命令来变更权限保证可写入:  
# chmod -R 1777 /var/lib/mysql  
# chmod -R 1777 /var/run/mysqld  
# chmod -R 1777 /var/lib/mysql-cluster
Copier après la connexion


Décompressez d'abord MySQL-Cluster-gpl-7.4.2-1.el6.x86_64.rpm-bundle.tar

Ensuite, exécutez la commande suivante pour installer
# tar xvf MySQL-Cluster-gpl-7.4.2-1.el6.x86_64.rpm-bundle.tar
Copier après la connexion


Attention particulière : une fois le package gpl du serveur installé, le message d'invite suivant apparaîtra, nous rappelant que le premier mot de passe du super compte après l'installation de l'ensemble du cluster existe dans le fichier /root/. mysql_secret.
# 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
Copier après la connexion

2. Configurez le nœud de gestion
---------------------------------------------------------------------------------------------------------------------  
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.  
 -----------------------------------------------------------
Copier après la connexion
1) Exécutez la commande suivante :


2) Configurez le fichier config.ini
# cd /var/lib/mysql-cluster  
# vi config.ini
Copier après la connexion


3. Configuration des nœuds SQL et des nœuds de données
[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
Copier après la connexion
Modifiez le fichier my.cnf et ajoutez le contenu suivant :


4. Commande de démarrage initial du cluster MySQL et ajustement du changement de mot de passe utilisateur : (Veuillez suivre strictement l'ordre Démarrer)
[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
Copier après la connexion
1) Démarrez mysql-cluster

Avant d'effectuer le démarrage initial, veuillez confirmer que les pare-feu des deux machines sont désactivés (le service iptables s'arrête ou définit le port du pare-feu pour qu'il soit passable . Les deux ports sont le port de communication 1186 et le port de données 3306)
Démarrez la commande de console mgt pour la première fois : ndb_mgmd -f /var/lib/mysql-cluster/config.ini
Démarrez la commande de nœud d'équilibrage : ndbd. --initial
Commande de démarrage du nœud de données : mysqld_safe --defaults -file=/etc/my.cnf --explicit_defaults_for_timestamp &
Notez que l'intégralité de la sortie de la console doit être surveillée pendant le processus de démarrage en cas de message d'erreur. sont trouvés, ils doivent être résolus à temps et en fonction du contenu du journal des erreurs.
-------------------------------------------------------------- --- ----------------------------------------------- --- --------
Si tout est normal, utilisez la commande suivante pour ouvrir la console de gestion : ndb_mgm
Exécuter # show
Vérifiez si chaque nœud a été complètement démarré, comme suit , chaque nœud a été connecté, s'il y a un nœud qui n'est pas connecté, vous verrez

S'il y a un nœud qui n'est pas connecté, comme indiqué ci-dessous, la ligne avec id=81. signifie qu'il n'y a pas de connexion. Vérifiez le problème et le point de défaut
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)
Copier après la connexion


2) Changez le mot de passe
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)
Copier après la connexion
Lorsque mysqld démarre normalement (vous pouvez utiliser pgrep mysqld pour obtenir l'ID du processus), nous Vous pouvez utiliser la commande suivante pour modifier :


Mot de passe aléatoire (voir /root/ pour plus de détails) fichier .mysql_secret), utilisez la commande suivante pour changer le mot de passe après avoir entré :
mysql -u root -p;
Copier après la connexion


Mais ce nouveau mot de passe doit être une valeur de hachage, utilisez donc la méthode suivante pour obtenir la valeur de hachage de la chaîne du mot de passe
SET PASSWORD = PASSWORD(&#39;新密码&#39;);
Copier après la connexion


Cependant, l'exécution de la commande ci-dessus vous demandera pour définir d'abord un mot de passe, ce qui est frustrant et revient. Ensuite, allez l'exécuter sur mysql ailleurs
select password(&#39;111111&#39;);
Copier après la connexion
La valeur de hachage de 111111 est "* FD571203974BA9AFE270FE62151AE967ECA5E0AA”

SET PASSWORD = PASSWORD('*FD571203974BA9AFE270FE62151AE9. 67ECA5E0AA');
C'est tellement frustrant. Après l'avoir configuré, vous devez toujours utiliser le texte chiffré pour vous connecter. Eh bien, utilisez simplement le texte chiffré pour entrer. Utilisez la commande suivante, Forcez l'utilisation du texte clair pour vous connecter

<🎜. >Ensuite, vous pouvez utiliser le mot de passe en texte clair pour vous connecter

Plusieurs serveurs équipés de nœuds de données SQL doivent exécuter la commande ci-dessus une fois
use mysql;  
delete from user;  
grant all on *.* to root@&#39;%&#39; identified by "111111" with grant option;  
flush privileges;  
quit;
Copier après la connexion
5. Suivez les étapes ci-dessus Une fois toutes les opérations terminées, testez si le cluster ; fonctionne normalement

1) Test fonctionnel simple
Après avoir entré mysql sur 218, exécutez ce qui suit :


Remarque : ENGINE=NDBCLUSTER ; sinon il ne sera pas synchronisé

Vérifiez si c'est réussi. Sur 217, allez sur mysql et vérifiez si la base de données et la table sont automatiquement créées. Si elles sont créées, cela signifie un succès. Si cela échoue, veuillez vérifier la configuration de l'environnement.
create database clustertest;  
use clustertest;   
CREATE TABLE testtable(Count INT) ENGINE=NDBCLUSTER;
Copier après la connexion
2) Testez si les données peuvent être synchronisées dans des conditions de reprise après sinistre (si une base de données est arrêtée, les données perdues seront-elles automatiquement reconstituées lors de son redémarrage)

Arrêtez le service mysql sur 217 et exécutez sur 218


Démarrez le service mysql de 217, utilisez show pour confirmer que le nœud de base de données de 217 a été connecté, exécutez l'instruction suivante

insert into testtable values (1);
Copier après la connexion


Si des données sont trouvées, elles signifie que la fonction est terminée

6. Arrêtez le cluster : (doit être exécuté dans le strict respect de l'ordre)
select * from testtable;
Copier après la connexion
Arrêtez le nœud de données : # mysqld stop (les nœuds SQL peuvent être arrêtés en utilisant mysqladmin shutdown ou d'autres méthodes. )

Exécuter sur le nœud de gestion : # ndb_mgm -e shutdown
arrêtera en toute sécurité le nœud de gestion et le nœud de données.
Après la fermeture, utilisez la commande de détection de processus suivante pour vérifier si elle s'est terminée :


Sinon, recherchez le pid correspondant et effectuez l'opération kill

kill -9 numéro de processus
# pgrep mysqld  
# ps aux | grep nbdb
Copier après la connexion
7. Démarrez à nouveau le plan Cluster :

Démarrez la séquence de cluster entière. Notez que certaines instructions ont été soustraites du contenu d'initialisation :
.

ndb_mgmd -f /var/lib/mysql-cluster/config.ini  
ndbd  
mysqld_safe --defaults-file=/etc/my.cnf --explicit_defaults_for_timestamp &
Copier après la connexion

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

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


Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Commandes de chat et comment les utiliser
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

MySQL: Concepts simples pour l'apprentissage facile MySQL: Concepts simples pour l'apprentissage facile Apr 10, 2025 am 09:29 AM

MySQL est un système de gestion de base de données relationnel open source. 1) Créez une base de données et des tables: utilisez les commandes CreateDatabase et CreateTable. 2) Opérations de base: insérer, mettre à jour, supprimer et sélectionner. 3) Opérations avancées: jointure, sous-requête et traitement des transactions. 4) Compétences de débogage: vérifiez la syntaxe, le type de données et les autorisations. 5) Suggestions d'optimisation: utilisez des index, évitez de sélectionner * et utilisez les transactions.

Comment ouvrir phpmyadmin Comment ouvrir phpmyadmin Apr 10, 2025 pm 10:51 PM

Vous pouvez ouvrir PHPMYADMIN via les étapes suivantes: 1. Connectez-vous au panneau de configuration du site Web; 2. Trouvez et cliquez sur l'icône PHPMYADMIN; 3. Entrez les informations d'identification MySQL; 4. Cliquez sur "Connexion".

Comment créer Navicat Premium Comment créer Navicat Premium Apr 09, 2025 am 07:09 AM

Créez une base de données à l'aide de NAVICAT Premium: Connectez-vous au serveur de base de données et entrez les paramètres de connexion. Cliquez avec le bouton droit sur le serveur et sélectionnez Créer une base de données. Entrez le nom de la nouvelle base de données et le jeu de caractères spécifié et la collation. Connectez-vous à la nouvelle base de données et créez le tableau dans le navigateur d'objet. Cliquez avec le bouton droit sur le tableau et sélectionnez Insérer des données pour insérer les données.

Comment créer une nouvelle connexion à MySQL dans Navicat Comment créer une nouvelle connexion à MySQL dans Navicat Apr 09, 2025 am 07:21 AM

Vous pouvez créer une nouvelle connexion MySQL dans NAVICAT en suivant les étapes: ouvrez l'application et sélectionnez une nouvelle connexion (CTRL N). Sélectionnez "MySQL" comme type de connexion. Entrez l'adresse Hostname / IP, le port, le nom d'utilisateur et le mot de passe. (Facultatif) Configurer les options avancées. Enregistrez la connexion et entrez le nom de la connexion.

MySQL et SQL: Compétences essentielles pour les développeurs MySQL et SQL: Compétences essentielles pour les développeurs Apr 10, 2025 am 09:30 AM

MySQL et SQL sont des compétences essentielles pour les développeurs. 1.MySQL est un système de gestion de base de données relationnel open source, et SQL est le langage standard utilisé pour gérer et exploiter des bases de données. 2.MySQL prend en charge plusieurs moteurs de stockage via des fonctions de stockage et de récupération de données efficaces, et SQL termine des opérations de données complexes via des instructions simples. 3. Les exemples d'utilisation comprennent les requêtes de base et les requêtes avancées, telles que le filtrage et le tri par condition. 4. Les erreurs courantes incluent les erreurs de syntaxe et les problèmes de performances, qui peuvent être optimisées en vérifiant les instructions SQL et en utilisant des commandes Explication. 5. Les techniques d'optimisation des performances incluent l'utilisation d'index, d'éviter la numérisation complète de la table, d'optimiser les opérations de jointure et d'améliorer la lisibilité du code.

Comment utiliser un seul fileté redis Comment utiliser un seul fileté redis Apr 10, 2025 pm 07:12 PM

Redis utilise une architecture filetée unique pour fournir des performances élevées, une simplicité et une cohérence. Il utilise le multiplexage d'E / S, les boucles d'événements, les E / S non bloquantes et la mémoire partagée pour améliorer la concurrence, mais avec des limites de limitations de concurrence, un point d'échec unique et inadapté aux charges de travail à forte intensité d'écriture.

Comment récupérer les données après que SQL supprime les lignes Comment récupérer les données après que SQL supprime les lignes Apr 09, 2025 pm 12:21 PM

La récupération des lignes supprimées directement de la base de données est généralement impossible à moins qu'il n'y ait un mécanisme de sauvegarde ou de retour en arrière. Point clé: Rollback de la transaction: Exécutez Rollback avant que la transaction ne s'engage à récupérer les données. Sauvegarde: la sauvegarde régulière de la base de données peut être utilisée pour restaurer rapidement les données. Instantané de la base de données: vous pouvez créer une copie en lecture seule de la base de données et restaurer les données après la suppression des données accidentellement. Utilisez la déclaration de suppression avec prudence: vérifiez soigneusement les conditions pour éviter la suppression accidentelle de données. Utilisez la clause WHERE: Spécifiez explicitement les données à supprimer. Utilisez l'environnement de test: testez avant d'effectuer une opération de suppression.

MySQL: une introduction à la base de données la plus populaire au monde MySQL: une introduction à la base de données la plus populaire au monde Apr 12, 2025 am 12:18 AM

MySQL est un système de gestion de la base de données relationnel open source, principalement utilisé pour stocker et récupérer les données rapidement et de manière fiable. Son principe de travail comprend les demandes des clients, la résolution de requête, l'exécution des requêtes et les résultats de retour. Des exemples d'utilisation comprennent la création de tables, l'insertion et la question des données et les fonctionnalités avancées telles que les opérations de jointure. Les erreurs communes impliquent la syntaxe SQL, les types de données et les autorisations, et les suggestions d'optimisation incluent l'utilisation d'index, les requêtes optimisées et la partition de tables.

See all articles