Maison base de données tutoriel mysql Comment obtenir une haute disponibilité de base de données et une reprise après sinistre dans MySQL ?

Comment obtenir une haute disponibilité de base de données et une reprise après sinistre dans MySQL ?

Jul 30, 2023 am 10:10 AM
mysql 高可用性 灾备

Comment obtenir une haute disponibilité de base de données et une reprise après sinistre dans MySQL ?

Avec le développement rapide d'Internet, les bases de données sont devenues un élément indispensable des applications modernes. En termes de simultanéité élevée, de haute disponibilité et de reprise après sinistre, la stabilité et la fiabilité de la base de données sont devenues plus importantes. MySQL est l'une des bases de données relationnelles les plus couramment utilisées et les plus matures. Cet article explique comment obtenir une haute disponibilité et une reprise après sinistre de la base de données dans MySQL.

1. Réplication maître-esclave
La réplication maître-esclave est une solution courante dans MySQL pour obtenir une haute disponibilité de base de données. Grâce à la réplication maître-esclave, nous pouvons copier les données de la base de données maître vers une ou plusieurs bases de données esclaves, réalisant ainsi la sauvegarde des données et la séparation de la lecture et de l'écriture.

Dans MySQL, la configuration de la réplication maître-esclave se divise principalement selon les étapes suivantes :

  1. Sur le serveur maître, recherchez le fichier de configuration my.cnf (généralement situé dans /etc/mysql ou /etc/my.cnf) , ajoutez La configuration suivante : Le paramètre

    [mysqld]
    log_bin=mysql-bin
    server_id=1
    Copier après la connexion

    log_bin est utilisé pour permettre aux journaux binaires d'enregistrer toutes les opérations de mise à jour sur le serveur principal. Le paramètre server_id est utilisé pour identifier un serveur maître unique. log_bin参数用于开启二进制日志,用于记录主服务器上的所有更新操作。server_id参数用于标识唯一的主服务器。

  2. 重启MySQL服务,使配置生效。

    sudo service mysql restart
    Copier après la connexion
  3. 创建一个新用户,用于从服务器进行访问主服务器。打开MySQL命令行并执行以下命令:

    CREATE USER 'replication'@'%' IDENTIFIED BY 'password';
    GRANT REPLICATION SLAVE ON *.* TO 'replication'@'%';
    Copier après la connexion

    其中,replication是自定义的用户名,password是密码。请根据实际情况进行设置。

  4. 在主服务器上,执行以下命令,查看主服务器状态,并记录File和Position的值(将会在从服务器配置时使用):

    SHOW MASTER STATUS;
    Copier après la connexion
  5. 在从服务器上,找到my.cnf配置文件,添加以下配置:

    [mysqld]
    server_id=2
    Copier après la connexion

    server_id参数用于标识唯一的从服务器。

  6. 重启MySQL服务,使配置生效。
  7. 在从服务器上,打开MySQL命令行并执行以下命令,进行主从复制的配置:

    CHANGE MASTER TO MASTER_HOST='主服务器IP地址', MASTER_USER='replication', MASTER_PASSWORD='password', MASTER_LOG_FILE='从步骤4中的File值', MASTER_LOG_POS=从步骤4中的Position值;
    Copier après la connexion

    其中,主服务器IP地址需替换为实际的主服务器IP地址,replicationpassword需替换为从步骤3中创建的用户和密码,从步骤4中的File值从步骤4中的Position值分别替换为主服务器状态的File和Position的值。

  8. 启动从服务器的复制进程:

    START SLAVE;
    Copier après la connexion
  9. 查看从服务器复制状态:

    SHOW SLAVE STATUS G;
    Copier après la connexion

    如果成功配置,可以通过观察Slave_IO_RunningSlave_SQL_Running两个字段来确认状态是否正常。

二、主从切换(Failover)
主从复制可以实现数据的备份和读写分离,但当主服务器宕机时,需要手动切换到从服务器上。为了实现自动切换,我们可以结合其他工具,如MHA(MySQL High Availability)或者ProxySQL来进行主从切换。

MHA是一个专门用于MySQL高可用性和灾备配置的工具。我们可以通过以下步骤来实现主从切换:

  1. 安装MHA工具包:

    sudo apt-get install mha4mysql-node
    Copier après la connexion
  2. 创建一个MHA的配置文件,如/etc/mha/app1.cnf,内容如下:

    [server default]
    manager_workdir=/var/log/masterha/app1
    manager_log=/var/log/masterha/app1/manager.log
    
    [server1]
    hostname=主服务器IP地址
    candidate_master=1
    recovery_user=replication
    recovery_password=password
    
    [server2]
    hostname=从服务器IP地址
    candidate_master=1
    recovery_user=replication
    recovery_password=password
    Copier après la connexion

    其中,主服务器IP地址从服务器IP地址需替换为实际的IP地址。

  3. 执行以下命令,在从服务器上运行MHA的管理工具:

    masterha_manager --conf=/etc/mha/app1.cnf --remove_dead_master_conf
    Copier après la connexion

    该命令将会监听主服务器,并在主服务器宕机时进行主从切换。

三、数据备份和恢复(Backup and Recovery)
除了主从复制和主从切换,定期进行数据备份也是确保数据库可用性和灾备的重要方式。在MySQL中,我们可以使用mysqldump命令进行数据备份和恢复。

  1. 备份数据库:

    mysqldump -u 用户名 -p 数据库名 > 备份文件.sql
    Copier après la connexion

    其中,用户名数据库名需替换为实际的用户名和数据库名,备份文件.sql为备份文件的路径和文件名。

  2. 恢复数据库:

    mysql -u 用户名 -p 数据库名 < 备份文件.sql
    Copier après la connexion

    其中,用户名数据库名需替换为实际的用户名和数据库名,备份文件.sql

Redémarrez le service MySQL pour que la configuration prenne effet.

rrreee

Créez un nouvel utilisateur pour accéder au serveur principal depuis le serveur. Ouvrez la ligne de commande MySQL et exécutez la commande suivante :
    rrreee
  1. Où, replication est le nom d'utilisateur personnalisé et password est le mot de passe. Veuillez le définir en fonction de la situation réelle.
Sur le serveur maître, exécutez la commande suivante pour afficher l'état du serveur maître, et enregistrez les valeurs de Fichier et Position (seront utilisées lors de la configuration du serveur esclave) : 🎜rrreee🎜🎜🎜Sur le serveur esclave, recherchez le fichier de configuration my.cnf, ajoutez la configuration suivante : 🎜rrreee🎜 Le paramètre server_id est utilisé pour identifier le serveur esclave unique. 🎜🎜🎜Redémarrez le service MySQL pour que la configuration prenne effet. 🎜🎜🎜Sur le serveur esclave, ouvrez la ligne de commande MySQL et exécutez la commande suivante pour configurer la réplication maître-esclave : 🎜rrreee🎜Parmi eux, Adresse IP du serveur maître doit être remplacé par le maître réel L'adresse IP du serveur réplication et le mot de passe doivent être remplacés par l'utilisateur et le mot de passe créés à l'étape 3, à partir de la valeur du fichier à l'étape 4 et from step La valeur Position en 4 est remplacée respectivement par les valeurs File et Position de l'état du serveur principal. 🎜🎜🎜🎜Démarrez le processus de réplication à partir du serveur esclave : 🎜rrreee🎜🎜🎜Affichez l'état de la réplication à partir du serveur esclave : 🎜rrreee🎜Si la configuration est réussie, vous pouvez observer le Slave_IO_Running et le Champ Slave_SQL_Running pour confirmer si l'état est normal. 🎜🎜🎜🎜 2. Commutation maître-esclave (Failover) 🎜La réplication maître-esclave peut réaliser une sauvegarde des données et une séparation lecture-écriture, mais lorsque le serveur maître tombe en panne, vous devez basculer manuellement vers le serveur esclave. Afin d'obtenir une commutation automatique, nous pouvons combiner d'autres outils, tels que MHA (MySQL High Availability) ou ProxySQL pour effectuer la commutation maître-esclave. 🎜🎜MHA est un outil spécifiquement utilisé pour la configuration de la haute disponibilité et de la reprise après sinistre de MySQL. Nous pouvons implémenter la commutation maître-esclave en suivant les étapes suivantes : 🎜🎜🎜🎜Installez la boîte à outils MHA : 🎜rrreee🎜🎜🎜Créez un fichier de configuration MHA, tel que /etc/mha/app1.cnf, contenu Comme suit : 🎜rrreee🎜 Parmi eux, l'Adresse IP du serveur maître et l'Adresse IP du serveur esclave doivent être remplacées par des adresses IP réelles. 🎜🎜🎜🎜Exécutez la commande suivante pour exécuter l'outil de gestion MHA sur le serveur esclave : 🎜rrreee🎜Cette commande surveillera le serveur maître et effectuera la commutation maître-esclave lorsque le serveur maître tombe en panne. 🎜🎜🎜🎜3. Sauvegarde et récupération des données🎜En plus de la réplication maître-esclave et de la commutation maître-esclave, la sauvegarde régulière des données est également un moyen important de garantir la disponibilité de la base de données et la reprise après sinistre. Dans MySQL, nous pouvons utiliser la commande mysqldump pour la sauvegarde et la récupération des données. 🎜🎜🎜🎜Base de données de sauvegarde : 🎜rrreee🎜 Parmi eux, le nom d'utilisateur et le nom de la base de données doivent être remplacés par le nom d'utilisateur et le nom de la base de données réels, fichier de sauvegarde .sql code> est le chemin et le nom du fichier de sauvegarde. 🎜🎜🎜🎜Restaurer la base de données : 🎜rrreee🎜 Parmi eux, le <code>nom d'utilisateur et le nom de la base de données doivent être remplacés par le nom d'utilisateur et le nom de la base de données réels, fichier de sauvegarde .sql code> est le fichier de sauvegarde qui doit être restauré. 🎜🎜🎜🎜Ce qui précède est une brève introduction sur la manière d'obtenir une haute disponibilité de base de données et une reprise après sinistre dans MySQL. Grâce à la réplication maître-esclave, à la commutation maître-esclave et à la sauvegarde des données, nous pouvons garantir la stabilité et la disponibilité de la base de données pour mieux répondre aux besoins des applications modernes. Bien entendu, MySQL propose également d'autres solutions de haute disponibilité et de reprise après sinistre, que les lecteurs peuvent choisir et configurer en fonction de leurs besoins réels. 🎜🎜Références : 🎜🎜🎜Réplication MySQL - Configuration de la réplication : https://dev.mysql.com/doc/refman/8.0/en/replication.html🎜🎜MHA : https://code.google.com/ archive /p/mysql-master-ha/wikis/GettingStarted.wiki🎜🎜

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)
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
1 Il y a quelques mois 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.

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.

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.

Pourquoi utiliser MySQL? Avantages et avantages Pourquoi utiliser MySQL? Avantages et avantages Apr 12, 2025 am 12:17 AM

MySQL est choisi pour ses performances, sa fiabilité, sa facilité d'utilisation et son soutien communautaire. 1.MySQL fournit des fonctions de stockage et de récupération de données efficaces, prenant en charge plusieurs types de données et opérations de requête avancées. 2. Adoptez l'architecture client-serveur et plusieurs moteurs de stockage pour prendre en charge l'optimisation des transactions et des requêtes. 3. Facile à utiliser, prend en charge une variété de systèmes d'exploitation et de langages de programmation. 4. Avoir un solide soutien communautaire et fournir des ressources et des solutions riches.

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.

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.

See all articles