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)
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
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/mysqld3) Installer mysql-cluster
使用如下的命令来变更权限保证可写入: # chmod -R 1777 /var/lib/mysql # chmod -R 1777 /var/run/mysqld # chmod -R 1777 /var/lib/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
# 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.rpm2. Configurez le nœud de gestion
--------------------------------------------------------------------------------------------------------------------- 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. -----------------------------------------------------------1) Exécutez la commande suivante :
# cd /var/lib/mysql-cluster # vi 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=82Modifiez 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.2181) 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
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)
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)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;
SET PASSWORD = PASSWORD('新密码');
select password('111111');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
use mysql; delete from user; grant all on *.* to root@'%' identified by "111111" with grant option; flush privileges; quit;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é
create database clustertest; use clustertest; CREATE TABLE testtable(Count INT) ENGINE=NDBCLUSTER;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);
Si des données sont trouvées, elles signifie que la fonction est terminée
select * from testtable;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
# pgrep mysqld # ps aux | grep nbdb7. 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 &
备注:
1、mysql安装后,默认会自动启动的,每次启动cluster的时候,都需要先把mysql的服务关闭,太麻烦,于是可以执行如下命令(我出手有点狠):
chkconfig --level 123456 mysql off
2、防火墙问题,偷个懒,我懒得去一一开放端口,干脆把防火墙直接关了
chkconfig --level 123456 mysql off
以上就是MySQL之——MySQL Cluster集群搭建详解(基于RPM安装包)的内容,更多相关内容请关注PHP中文网(www.php.cn)!