Maison Tutoriel système Linux Comment résoudre le retard maître-esclave MySQL

Comment résoudre le retard maître-esclave MySQL

Mar 19, 2024 am 09:28 AM
linux linux教程 红帽 linux系统 linux命令 网络问题 certification Linux chapeau rouge Linux vidéo Linux

Comment résoudre le retard maître-esclave MySQL

Les capacités de réplication intégrées de MySQL constituent la base de la création de grandes applications hautes performances. Distribuez les données MySQL sur plusieurs systèmes. Ce mécanisme distribué est obtenu en copiant les données d'un certain hôte MySQL vers d'autres hôtes esclaves et en les réexécutant.
Lors de la réplication, un serveur agit en tant que maître et un ou plusieurs autres serveurs en tant qu'esclaves. Le maître écrit des mises à jour dans les fichiers journaux binaires et maintient un index des fichiers pour suivre la rotation des journaux. Ces journaux enregistrent les mises à jour envoyées aux serveurs esclaves. Lorsqu'un esclave se connecte au maître, il informe le maître de l'emplacement de la dernière mise à jour réussie lue par l'esclave dans le journal. Le serveur esclave reçoit toutes les mises à jour survenues depuis, puis bloque et attend que le serveur maître les informe des mises à jour.
Problèmes avec la réplication maître-esclave MySQL :

  • Une fois la base de données principale indisponible, les données peuvent être perdues
  • La bibliothèque esclave n'a qu'un seul thread SQL, la bibliothèque principale est soumise à une forte pression d'écriture et la réplication risque d'être retardée
Voici quatre façons pratiques de résoudre le délai maître-esclave MySQL
1. Principe de délai de synchronisation maître-esclave de la base de données MySQL.

Réponse : Lorsque nous parlons du principe du délai de synchronisation maître-esclave dans la base de données MySQL, nous devons commencer par le principe de la réplication maître-esclave de la base de données MySQL. La réplication maître-esclave de Mysql est une opération à thread unique. La base de données principale génère un binlog. pour tous les DDL et DML, Binlog est une écriture de séquence, donc l'efficacité est très élevée ; le thread Slave_IO_Running de l'esclave ira dans la bibliothèque principale pour obtenir le journal, et l'efficacité sera relativement élevée. Opérations DDL et DML de la bibliothèque principale sur l'esclave. Les opérations d'E/S de DML et DDL sont aléatoires et non séquentielles, le coût sera donc très élevé. D'autres requêtes sur l'esclave peuvent également provoquer un conflit de verrouillage. Puisque Slave_SQL_Running est également monothread, une carte maître DDL doit s'exécuter 10 fois. minutes, tous les DDL suivants attendront la fin de leur exécution avant de continuer, ce qui entraînera des retards. Certains amis demanderont : « Le même DDL sur la bibliothèque principale doit également être exécuté pendant 10 minutes. Pourquoi l'esclave est-il retardé ? » La réponse est que le maître peut s'exécuter simultanément, mais pas le thread Slave_SQL_Running.

2. Comment se produit le délai de synchronisation maître-esclave dans la base de données MySQL ?

Réponse : lorsque la concurrence TPS de la bibliothèque principale est élevée, le nombre de DDL générés dépasse la plage qu'un thread SQL de l'esclave peut supporter, et un retard se produit alors. Bien sûr, il peut également y avoir une attente de verrouillage avec celui de l'esclave. grande instruction de requête.

3.Solution de délai de synchronisation maître-esclave de la base de données MySQL

Réponse : La solution la plus simple pour réduire le délai de synchronisation des esclaves est d'optimiser l'architecture et d'essayer de faire exécuter rapidement le DDL de la bibliothèque principale. Il y a aussi le fait que la bibliothèque principale est écrite avec une sécurité de données élevée, telle que sync_binlog=1, innodb_flush_log_at_trx_commit = 1 et d'autres paramètres. Cependant, l'esclave n'a pas besoin d'une sécurité de données aussi élevée. Vous pouvez définir sync_binlog sur 0 ou. désactiver binlog. innodb_flushlog peut également être défini sur 0 pour améliorer l'efficacité de l'exécution SQL. L'autre consiste à utiliser un meilleur périphérique matériel que la bibliothèque principale comme esclave.

4. Facteurs provoquant le retard de synchronisation maître-esclave dans la base de données MySQL.

1. Retard du réseau
2. charge principale
3. charge d'esclave
L'approche générale consiste à utiliser plusieurs esclaves pour distribuer les demandes de lecture, puis à utiliser un serveur dédié à partir de ces esclaves uniquement pour la sauvegarde sans aucune autre opération, afin que l'exigence de « temps réel » puisse être atteinte au maximum

.

De plus, introduisons 2 paramètres supplémentaires qui peuvent réduire le délai
–slave-net-timeout=secondes
Signification du paramètre : lorsque l'esclave ne parvient pas à lire les données du journal de la base de données principale, combien de temps attendre pour rétablir la connexion et obtenir les données
L'unité de slave_net_timeout est la seconde. Le paramètre par défaut est 3600 secondes
. |esclave_net_timeout | 3600
–master-connect-retry=secondes
Signification du paramètre : lors du rétablissement de la connexion maître-esclave, si la connexion ne parvient pas à être établie, combien de temps faudra-t-il pour réessayer.
L'unité de master-connect-retry est la seconde. Le paramètre par défaut est 60 secondes
. Habituellement, la configuration des 2 paramètres ci-dessus peut réduire le délai de synchronisation des données maître-esclave causé par des problèmes de réseau

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)
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Où trouver la courte de la grue à atomide atomique
1 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)

Entrée de la version Web Deepseek Entrée du site officiel Deepseek Entrée de la version Web Deepseek Entrée du site officiel Deepseek Feb 19, 2025 pm 04:54 PM

Deepseek est un puissant outil de recherche et d'analyse intelligent qui fournit deux méthodes d'accès: la version Web et le site officiel. La version Web est pratique et efficace et peut être utilisée sans installation; Que ce soit des individus ou des utilisateurs d'entreprise, ils peuvent facilement obtenir et analyser des données massives via Deepseek pour améliorer l'efficacité du travail, aider la prise de décision et promouvoir l'innovation.

Comment installer Deepseek Comment installer Deepseek Feb 19, 2025 pm 05:48 PM

Il existe de nombreuses façons d'installer Deepseek, notamment: Compiler à partir de Source (pour les développeurs expérimentés) en utilisant des packages précompilés (pour les utilisateurs de Windows) à l'aide de conteneurs Docker (pour le plus pratique, pas besoin de s'inquiéter de la compatibilité), quelle que soit la méthode que vous choisissez, veuillez lire Les documents officiels documentent soigneusement et les préparent pleinement à éviter des problèmes inutiles.

Comment résoudre le problème des autorisations rencontré lors de la visualisation de la version Python dans le terminal Linux? Comment résoudre le problème des autorisations rencontré lors de la visualisation de la version Python dans le terminal Linux? Apr 01, 2025 pm 05:09 PM

Solution aux problèmes d'autorisation Lors de la visualisation de la version Python dans Linux Terminal Lorsque vous essayez d'afficher la version Python dans Linux Terminal, entrez Python ...

Installation officielle du site officiel de Bitget (Guide du débutant 2025) Installation officielle du site officiel de Bitget (Guide du débutant 2025) Feb 21, 2025 pm 08:42 PM

Bitget est un échange de crypto-monnaie qui fournit une variété de services de trading, notamment le trading au comptant, le trading de contrats et les dérivés. Fondée en 2018, l'échange est basée à Singapour et s'engage à fournir aux utilisateurs une plate-forme de trading sûre et fiable. Bitget propose une variété de paires de trading, notamment BTC / USDT, ETH / USDT et XRP / USDT. De plus, l'échange a une réputation de sécurité et de liquidité et offre une variété de fonctionnalités telles que les types de commandes premium, le trading à effet de levier et le support client 24/7.

Obtenez le package d'installation Gate.io gratuitement Obtenez le package d'installation Gate.io gratuitement Feb 21, 2025 pm 08:21 PM

Gate.io est un échange de crypto-monnaie populaire que les utilisateurs peuvent utiliser en téléchargeant son package d'installation et en l'installant sur leurs appareils. Les étapes pour obtenir le package d'installation sont les suivantes: Visitez le site officiel de Gate.io, cliquez sur "Télécharger", sélectionnez le système d'exploitation correspondant (Windows, Mac ou Linux) et téléchargez le package d'installation sur votre ordinateur. Il est recommandé de désactiver temporairement les logiciels antivirus ou le pare-feu pendant l'installation pour assurer une installation fluide. Une fois terminé, l'utilisateur doit créer un compte Gate.io pour commencer à l'utiliser.

Le package d'installation OUYI OKX est directement inclus Le package d'installation OUYI OKX est directement inclus Feb 21, 2025 pm 08:00 PM

OUYI OKX, le premier échange mondial d'actifs numériques, a maintenant lancé un package d'installation officiel pour offrir une expérience de trading sûre et pratique. Le package d'installation OKX de OUYI n'a pas besoin d'être accessible via un navigateur. Le processus d'installation est simple et facile à comprendre.

Comment définir automatiquement les autorisations d'UnixSocket après le redémarrage du système? Comment définir automatiquement les autorisations d'UnixSocket après le redémarrage du système? Mar 31, 2025 pm 11:54 PM

Comment définir automatiquement les autorisations d'UnixSocket après le redémarrage du système. Chaque fois que le système redémarre, nous devons exécuter la commande suivante pour modifier les autorisations d'UnixSocket: sudo ...

OUYI Exchange Télécharger le portail officiel OUYI Exchange Télécharger le portail officiel Feb 21, 2025 pm 07:51 PM

Ouyi, également connu sous le nom d'OKX, est une plate-forme de trading de crypto-monnaie de pointe. L'article fournit un portail de téléchargement pour le package d'installation officiel d'Ouyi, qui facilite les utilisateurs pour installer le client Ouyi sur différents appareils. Ce package d'installation prend en charge les systèmes Windows, Mac, Android et iOS. Une fois l'installation terminée, les utilisateurs peuvent s'inscrire ou se connecter au compte OUYI, commencer à négocier des crypto-monnaies et profiter d'autres services fournis par la plate-forme.

See all articles