Maison développement back-end tutoriel php Comment implémenter la réplication maître-esclave de la base de données MySQL en PHP

Comment implémenter la réplication maître-esclave de la base de données MySQL en PHP

May 17, 2023 am 08:18 AM
mysql php 主从复制

Avec le développement rapide d'Internet, les applications Web intègrent de plus en plus les opérations de bases de données. MySQL est un système de base de données relationnelle de renommée mondiale et largement utilisé. Dans les applications Web hautement concurrentes, la réplication maître-esclave MySQL est un moyen important d'améliorer les performances et la disponibilité des bases de données. Cet article explique comment utiliser PHP pour implémenter la réplication maître-esclave de la base de données MySQL.

1. Qu'est-ce que la réplication maître-esclave MySQL ?

La réplication maître-esclave MySQL fait référence à la copie des données d'un serveur de base de données MySQL vers un autre serveur pour maintenir la cohérence des données des deux serveurs MySQL. L'un des serveurs est appelé serveur maître et est responsable de la mise à jour des données en temps réel ; l'autre serveur est appelé serveur esclave et est responsable de la synchronisation des données du serveur maître. La réplication maître-esclave peut améliorer l'évolutivité et la tolérance aux pannes du système. Par exemple, lorsque le serveur principal tombe en panne, le serveur esclave peut reprendre le travail du serveur principal pour assurer le fonctionnement normal de l'entreprise.

2. Le principe de mise en œuvre de la réplication maître-esclave

Le principe de mise en œuvre de la réplication maître-esclave est le suivant :

  1. Le serveur maître enregistre l'opération de mise à jour dans le journal binaire (Binary Log).
  2. Connectez le serveur esclave au serveur maître, demandez à obtenir le journal binaire qui doit être synchronisé et copiez-le dans son propre journal.
  3. Le serveur esclave exécute les opérations de mise à jour du journal binaire du serveur maître dans sa propre base de données pour garantir la cohérence des données des deux bases de données.

3. Comment implémenter la réplication maître-esclave en PHP

  1. Configurez le journal binaire du serveur principal

Le serveur principal doit activer la fonction de journal binaire dans le fichier de configuration my.cnf. Ouvrez le fichier my.cnf et ajoutez la configuration suivante dans la section [mysqld] :

server-id=1
log-bin=/var/log/mysql/mysql-bin.log
Copier après la connexion

Parmi eux, server-id est utilisé pour identifier le serveur principal et log-bin est utilisé pour spécifier le chemin du fichier journal.

  1. Configurez les informations du serveur maître du serveur esclave

Le serveur esclave doit ajouter les informations de connexion du serveur maître dans le fichier de configuration my.cnf. Ouvrez le fichier my.cnf et ajoutez la configuration suivante dans la section [inisd_client] :

server-id=2
master-host=10.0.0.1
master-user=repl_user
master-password=repl_password
master-port=3306
Copier après la connexion

Parmi eux, server-id est utilisé pour identifier le serveur esclave, master-host précise l'adresse IP du serveur maître, master-user et master-password spécifient le maître Le nom d'utilisateur et le mot de passe du serveur, master-port spécifie le numéro de port du serveur maître.

  1. Créer un utilisateur de réplication

Créez un utilisateur sur le serveur maître pour la réplication des données et autorisez l'utilisateur à lire le journal binaire. Ouvrez le client MySQL et exécutez la commande suivante :

mysql> CREATE USER 'repl_user'@'%' IDENTIFIED BY 'repl_password';
mysql> GRANT REPLICATION SLAVE ON *.* TO 'repl_user'@'%';
Copier après la connexion
  1. Démarrez le processus de réplication dans le serveur esclave

Exécutez la commande suivante dans le client MySQL du serveur esclave pour démarrer le processus de réplication :

mysql> CHANGE MASTER TO MASTER_HOST='10.0.0.1', 
  MASTER_USER='repl_user', MASTER_PASSWORD='repl_password', 
  MASTER_LOG_FILE='mysql-bin.000001', MASTER_LOG_POS=107;
mysql> START SLAVE;
Copier après la connexion

Parmi eux, MASTER_LOG_FILE et MASTER_LOG_POS peuvent être dans la recherche principale dans le journal binaire du serveur.

Après avoir terminé les étapes ci-dessus, le serveur esclave copiera les données du serveur maître pour maintenir la cohérence des données dans les deux bases de données.

4. Résumé

La réplication maître-esclave MySQL est une technologie importante pour améliorer les performances et la disponibilité du système. Il est très simple d'implémenter la réplication maître-esclave MySQL à l'aide de PHP. Il vous suffit d'activer le journal binaire sur le serveur maître, de configurer les informations du serveur maître sur le serveur esclave, de créer un utilisateur de réplication et de démarrer le processus de réplication. Dans les environnements de production réels, il convient de veiller à l'utilisation de moyens techniques appropriés pour faciliter l'exploitation et la maintenance des bases de données afin de garantir la stabilité et la sécurité des services de bases de données.

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 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)
2 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Repo: Comment relancer ses coéquipiers
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: Comment obtenir des graines géantes
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Combien de temps faut-il pour battre Split Fiction?
3 Il y a quelques semaines By DDD

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)

Guide d'installation et de mise à niveau de PHP 8.4 pour Ubuntu et Debian Guide d'installation et de mise à niveau de PHP 8.4 pour Ubuntu et Debian Dec 24, 2024 pm 04:42 PM

PHP 8.4 apporte plusieurs nouvelles fonctionnalités, améliorations de sécurité et de performances avec une bonne quantité de dépréciations et de suppressions de fonctionnalités. Ce guide explique comment installer PHP 8.4 ou mettre à niveau vers PHP 8.4 sur Ubuntu, Debian ou leurs dérivés. Bien qu'il soit possible de compiler PHP à partir des sources, son installation à partir d'un référentiel APT comme expliqué ci-dessous est souvent plus rapide et plus sécurisée car ces référentiels fourniront les dernières corrections de bogues et mises à jour de sécurité à l'avenir.

Téléchargement de fichiers CakePHP Téléchargement de fichiers CakePHP Sep 10, 2024 pm 05:27 PM

Pour travailler sur le téléchargement de fichiers, nous allons utiliser l'assistant de formulaire. Voici un exemple de téléchargement de fichiers.

Discuter de CakePHP Discuter de CakePHP Sep 10, 2024 pm 05:28 PM

CakePHP est un framework open source pour PHP. Il vise à faciliter grandement le développement, le déploiement et la maintenance d'applications. CakePHP est basé sur une architecture de type MVC à la fois puissante et facile à appréhender. Modèles, vues et contrôleurs gu

Comment corriger les erreurs mysql_native_password non chargé sur MySQL 8.4 Comment corriger les erreurs mysql_native_password non chargé sur MySQL 8.4 Dec 09, 2024 am 11:42 AM

L'un des changements majeurs introduits dans MySQL 8.4 (la dernière version LTS en 2024) est que le plugin « MySQL Native Password » n'est plus activé par défaut. De plus, MySQL 9.0 supprime complètement ce plugin. Ce changement affecte PHP et d'autres applications

Comment configurer Visual Studio Code (VS Code) pour le développement PHP Comment configurer Visual Studio Code (VS Code) pour le développement PHP Dec 20, 2024 am 11:31 AM

Visual Studio Code, également connu sous le nom de VS Code, est un éditeur de code source gratuit – ou environnement de développement intégré (IDE) – disponible pour tous les principaux systèmes d'exploitation. Avec une large collection d'extensions pour de nombreux langages de programmation, VS Code peut être c

Guide rapide CakePHP Guide rapide CakePHP Sep 10, 2024 pm 05:27 PM

CakePHP est un framework MVC open source. Cela facilite grandement le développement, le déploiement et la maintenance des applications. CakePHP dispose d'un certain nombre de bibliothèques pour réduire la surcharge des tâches les plus courantes.

Comment analysez-vous et traitez-vous HTML / XML dans PHP? Comment analysez-vous et traitez-vous HTML / XML dans PHP? Feb 07, 2025 am 11:57 AM

Ce tutoriel montre comment traiter efficacement les documents XML à l'aide de PHP. XML (Language de balisage extensible) est un langage de balisage basé sur le texte polyvalent conçu à la fois pour la lisibilité humaine et l'analyse de la machine. Il est couramment utilisé pour le stockage de données et

Ressources utiles CakePHP Ressources utiles CakePHP Sep 10, 2024 pm 05:27 PM

Les ressources suivantes contiennent des informations supplémentaires sur CakePHP. Veuillez les utiliser pour obtenir des connaissances plus approfondies à ce sujet.

See all articles