Maison> base de données> tutoriel mysql> le corps du texte

Comment configurer le double maître Mysql

WBOY
Libérer: 2023-05-26 13:04:31
avant
3238 Les gens l'ont consulté

    Avant-propos

    Caractéristiques : Dans une configuration à double maître, deux serveurs MySQL font office de nœuds maître-esclave l'un pour l'autre. Le nœud A et le nœud B sont les nœuds maîtres l'un de l'autre.

    Ignorez les étapes pour installer mysql

    1. Fichier de configuration Mysql

    (1) Configuration du nœud A

    # 设置server-id,两节点必须不一样 server-id = 100 # 开启bin_log,模式为ROW,允许最大日志为1G log_bin = mysql-bin binlog_format = ROW max_binlog_size = 1024M # mysql5.7的版本不需要配置log-slave-updates=1 # log-slave-updates = 1 # 实现数据库宕机恢复后,自动同步缺少的数据 relay_log = mysql-relay-bin # 设置自增ID初始值为2,每次自增量为2。即都是偶数2,4,6,8,... auto_increment_offset = 2 auto_increment_increment = 2 # 开启gtid gtid_mode = ON enforce_gtid_consistency = 1 # 忽略不需要同步的schema replicate-ignore-db = mysql replicate-ignore-db = information_schema replicate-ignore-db = performance_schema replicate-ignore-db = sys
    Copier après la connexion

    (2) Configuration du nœud B

    Seules les configurations différentes du nœud A sont répertoriées

    # 设置server-id,两节点必须不一样 server-id = 200 # 设置自增ID初始值为1,每次自增量为2。即都是奇数1,3,5,7,... auto_increment_offset = 1 auto_increment_increment = 2
    Copier après la connexion

    2. le nœud A est le maître du nœud B (mode maître-esclave)

    Le nœud A est le maître et le nœud B est l'esclave.

    (1) Connectez-vous au nœud A et créez un compte pour l'esclave (nœud B).

    # 在节点A上创建账号repl_user,允许从任意IP访问,密码为slave@100, grant replication slave on *.* to 'repl_user'@'%' identified by 'slave@100'; flush privileges;
    Copier après la connexion

    (2) Afficher les informations principales du nœud A

    Comme le montre la figure ci-dessous, le journal bin_log du nœud A est mysql-bin.000001 et l'emplacement est 154

    # 清空master信息。初次配置可以使用,若已运行了同步,切记不要使用! reset master; # 查看master信息 show master status; +------------------+----------+--------------+------------------+---------------------------------------------+ | File | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set | +------------------+----------+--------------+------------------+---------------------------------------------+ | mysql-bin.000001 | 154 | | | c2cf218e-2317-11ec-a36f-5cf9dd4fd6a8:1-5 | +------------------+----------+--------------+------------------+---------------------------------------------+
    Copier après la connexion

    (3) Connectez-vous au nœud B et définissez le maître du nœud B comme nœud A

    # 停止节点B上的slave stop slave; # 将节点B的master设为节点A,以下的配置信息均表示节点A # MASTER_LOG_FILE和MASTER_LOG_POS,是在第(2)步中查看节点A的master信息 CHANGE MASTER TO MASTER_HOST='127.0.0.1', MASTER_PORT=3307, MASTER_USER='repl_user', MASTER_PASSWORD='slave@100', MASTER_LOG_FILE='mysql-bin.000001', MASTER_LOG_POS=154; # 开启节点B上的slave start slave;
    Copier après la connexion

    (4) Confirmez si l'esclave du nœud B s'exécute avec succès. Lorsque Slave_IO_Running et Slave_SQL_Running sont tous deux OUI dans le résultat renvoyé, cela indique un succès. S'il s'agit de NON ou de connexion, veuillez vérifier le fichier journal se terminant par .err dans le répertoire de données MySQL pour trouver le journal de niveau [ERREUR]. Habituellement, les problèmes de configuration initiale sont principalement causés par des problèmes de configuration de my.ini ou de création de compte de synchronisation.

    # 在节点B中查看slave状态 show slave status\G; *************************** 1. row *************************** Slave_IO_State: Waiting for master to send event Master_Host: 127.0.0.1 Master_User: repl_user Master_Port: 3307 Connect_Retry: 60 Master_Log_File: mysql-bin.000001 Read_Master_Log_Pos: 2207 Relay_Log_File: mysql-relay-bin.000002 Relay_Log_Pos: 1143 Relay_Master_Log_File: mysql-bin.000001 Slave_IO_Running: Yes Slave_SQL_Running: Yes ......
    Copier après la connexion

    (5) Si la configuration de l'esclave est anormale, vous pouvez utiliser l'instruction suivante pour la réinitialiser

    reset slave all;
    Copier après la connexion

    3 Terminez la configuration double maître

    À ce stade, le mode maître-esclave du nœud A et du nœud B. a été configuré avec succès, c'est-à-dire que le nœud A est le maître du nœud B. Ensuite, répétez l'opération de la troisième étape, mais inversez les opérations des nœuds A et B, c'est-à-dire créez un compte de synchronisation sur le nœud B, affichez les informations du maître et définissez le nœud B comme maître sur le nœud A. Une fois la configuration terminée, vérifiez également l'état d'esclave du nœud A pour voir si Slave_IO_Running et Slave_SQL_Running sont tous deux OUI.

    4. Testez

    Ajoutez ou supprimez un schéma, une table ou des données dans le nœud A et vérifiez s'il y a une synchronisation correcte dans le nœud B.

    Testez si les données de clé primaire à incrémentation automatique ajoutées sur le nœud A et le nœud B correspondent au fichier de configuration. Un est un nombre impair et un est un nombre pair. Lors de l’ajout ou de la suppression de données, y aura-t-il un conflit de clé primaire ?

    5. Contrôlez la bibliothèque ou la table synchronisée

    Obtenu en modifiant my.ini

    (1) Contrôle côté maître

    Binlog-do-db Base de données de journalisation Binlog (pour plusieurs bases de données, séparées)

    Binlog -ignore -db Ignorer la base de données dans le journal binlog (pour plusieurs bases de données, séparées)

    Seules les tables enregistrées dans le binlog peuvent être synchronisées avec la base de données esclave

    # binlog中记录这两个表 binlog-do-db=db_1,db_2 # binlog中不记录这两个表 binlog-ignore-db=db_3,db_4
    Copier après la connexion

    (2) Contrôle côté esclave

    répliquer-do- db Définit la base de données à répliquer
    replicate-ignore-d ’'' ‐‐‐‐‐‐‐‐‐‐‐'''' -do -table a la même fonction que la réplication -do-table, et des caractères génériques peuvent être ajoutés
    ; replique-wild-ignore-table a la même fonction que replication-ignore-table, et des caractères génériques peuvent être ajoutés


    Remarque : la configuration ignorée est toujours dans le journal de relais du bibliothèque esclave Il y a des informations, mais la synchronisation n'est pas effectuée.

    # 执行同步的库 replicate-do-db=db_1 replicate-do-db=db_2 # 忽略同步的库 replicate-ignore-db=db_3 # 执行同步的表 replicate-do-table=db_1.table_a replicate-do-table=db_2.table_b # 忽略同步的表 replicate-ignore-table=db_2.table_c # 只复制哪个库的哪个表 replicate-wild-do-table=db_4.% # 忽略哪个库的哪个表 replicate-wild-ignore-table=mysql.%
    Copier après la connexion
    6. Un compte avec plusieurs IP

    Lorsqu'un serveur MySQL sert de nœud maître et que N serveurs servent de nœuds esclaves, il sera très fastidieux d'ajouter un compte à chaque nœud esclave. Vous pouvez créer un compte dans le nœud maître et associer plusieurs adresses IP à ce compte pour réduire le nombre de comptes à ajouter.

    La méthode spécifique consiste à exécuter la déclaration de création de compte plusieurs fois, avec une IP différente à chaque fois.

    # 创建一个账号名,为此账号设置多个ip grant replication slave on *.* to 'repl_user'@'192.168.5.10' identified by 'slave@100'; grant replication slave on *.* to 'repl_user'@'192.168.5.20' identified by 'slave@100'; FLUSH PRIVILEGES
    Copier après la connexion

    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!

    Étiquettes associées:
    source:yisu.com
    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
    Derniers téléchargements
    Plus>
    effets Web
    Code source du site Web
    Matériel du site Web
    Modèle frontal
    À propos de nous Clause de non-responsabilité Sitemap
    Site Web PHP chinois:Formation PHP en ligne sur le bien-être public,Aidez les apprenants PHP à grandir rapidement!