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

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

黄舟
黄舟original
2017-03-14 16:41:401245parcourir

1. Téléchargez mysql-cluster 7.3.7

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

2. Nettoyage et installation de l'environnement

1) Nettoyer le service MySQL fourni avec CentOS6.5. Je peux le faire sans exécuter la première commande. Si ce n'est pas possible sur d'autres systèmes, c'est le cas. recommandé de l'exécuter

# yum -y remove mysql
# rpm -qa | grep mysql*
# rpm -e --nodeps mysql-libs-5.1.71-1.el6.x86_64

2) Préparation de l'environnement

Créez un dossier (divisez-le 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
使用如下的命令来变更权限保证可写入:
# chmod -R 1777 /var/lib/mysql
# chmod -R 1777 /var/run/mysqld
# chmod -R 1777 /var/lib/mysql-cluster

3) Installez mysql- cluster

Décompressez d'abord 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

Ensuite, exécutez la commande suivante pour installer

# 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

Attention particulière, lorsque le package gpl du serveur est installé, le Le message d'invite suivant apparaîtra pour nous rappeler l'intégralité du mot de passe initial du super compte après l'installation du cluster est stocké dans le fichier /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.
 -----------------------------------------------------------

2. Configurez le nœud de gestion
1) Exécutez la commande suivante :

# cd /var/lib/mysql-cluster
# vi config.ini

2) Configurez le fichier 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

3. Configuration des nœuds SQL et des nœuds de données
Modifiez le fichier my.cnf et ajoutez le contenu suivant :

[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

4. Commande de démarrage initial et changement et ajustement du mot de passe utilisateur : (Veuillez suivre strictement l'ordre pour démarrer)
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 ( service iptables arrête ou définit le port du pare-feu pour qu'il soit passable, afin que les deux machines puissent être connectées) Les deux ports sont le port de communication 1186 et le port de données 3306)
Démarrez la commande de la console mgt pour la première fois : ndb_mgmd -f / var/lib/mysql-cluster/config.ini
Démarrez la commande du nœud d'équilibrage : ndbd --initial
Démarrez la commande 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. Si un message d'erreur est trouvé, il doit être résolu à temps, résolvez-le 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

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)

S'il y a un nœud qui n'est pas connecté, comme indiqué ci-dessous, la ligne avec l'identifiant. =81 signifie qu'il n'y a pas de connexion. Vérifiez le point de défaut

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)

2) Changez le mot de passe
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 :

mysql -u root -p;

Mot de passe aléatoire (voir le fichier /root/.mysql_secret pour plus de détails. Après avoir entré, utilisez la commande suivante pour modifier le mot de passe :
).

SET PASSWORD = PASSWORD('新密码');

Mais ce nouveau mot de passe doit être une valeur de hash, donc pour obtenir la valeur de hachage du mot de passe string

select password('111111');

en utilisant la méthode suivante, cependant, l'exécution de la commande ci-dessus vous fera d'abord définir le mot de passe, ce qui est frustrant, et il revient, puis allez l'exécuter sur mysql ailleurs
La valeur de hachage de 111111 est " *FD571203974BA9AFE270FE62151AE967ECA5E0AA"
SET PASSWORD = PASSWORD('*FD571203974BA9AFE270FE62151AE967ECA5E0AA');
C'est tellement frustrant. Après l'avoir configuré, je dois encore l'utiliser pour me connecter. Texte chiffré, ok, , utilisez simplement le texte chiffré pour saisir . Après avoir entré, utilisez la commande suivante pour forcer l'utilisation du texte brut pour vous connecter

use mysql;
delete from user;
grant all on *.* to root@'%' identified by "111111" with grant option;
flush privileges;
quit;

Ensuite, vous pouvez utiliser le mot de passe en texte brut pour vous connecter.
Plusieurs installations Serveurs avec. Les nœuds de données SQL doivent exécuter la commande ci-dessus une fois ;
5. Une fois les étapes ci-dessus terminées, testez si le cluster fonctionne normalement
1) Test fonctionnel simple
Exécutez après avoir entré mysql sur 218 comme suit :

create database clustertest;
use clustertest; 
CREATE TABLE testtable(Count INT) ENGINE=NDBCLUSTER;

Remarque : ENGINE=NDBCLUSTER ; Le moteur doit utiliser NDBCLUSTER pour se synchroniser, sinon la synchronisation ne sera pas effectuée
Vérifiez si elle est réussie. Sur 217, allez sur mysql et vérifiez. si c'est automatique. La base de données et la table sont créées. Si elles sont créées, cela signifie un succès. En cas d'échec, veuillez vérifier la configuration de l'environnement
2) Testez si les données peuvent être synchronisées dans des situations de reprise après sinistre (si une base de données est arrêtée). , sera-t-il restauré au redémarrage ? Les données manquantes seront automatiquement complétées)
Arrêtez le service mysql le 217 et exécutez le 218

insert into testtable values (1);

启动217的mysql服务,使用show确认217的数据库节点已经连接上了,执行如下语句

select * from testtable;

如果发现有数据,则表示功能完备
6、关闭Cluster:(需要严格按照次序执行)
关闭数据节点:# mysqld stop  (SQL节点可以用mysqladmin shutdown或别的方式关闭。)
在管理节点上执行:# ndb_mgm -e shutdown
将安全的关闭管理节点和数据节点。
关闭后使用如下的进程检测命令查看一下是否退出来了:

# pgrep mysqld
# ps aux | grep nbdb

如果没有,找到对应的pid进行kill 操作即可
kill -9 进程号
7、再次启动Cluster方案:
启动整个cluster的次序,注意,一些语句已经减去了初始化的内容:

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

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

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
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