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
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.
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.
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.
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!

Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Sujets chauds



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.

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.

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 ...

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.

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.

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. Chaque fois que le système redémarre, nous devons exécuter la commande suivante pour modifier les autorisations d'UnixSocket: sudo ...

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.
