Maison >base de données >tutoriel mysql >La différence entre le cluster MySQL et le maître-esclave
La différence entre cluster et maître-esclave dans mysql : la cohérence des données est assurée entre maître et esclave via la réplication mysql par rapport à la méthode de synchronisation des données du cluster mysql, elle est asynchrone. Comme il est asynchrone, il peut y avoir un léger retard dans la copie des données entre le maître et l'esclave, et des incohérences peuvent survenir.
Cours recommandé : Tutoriel MySQL.
La cohérence des données est assurée entre maître et esclave grâce à la réplication mysql. Par rapport à la méthode de synchronisation des données du cluster mysql, elle est asynchrone.
Le cluster utilise PXC (Percona XtraDB Cluster), les données multi-nœuds sont synchronisées en temps réel (lecture et écriture)
A propos de maître-esclave
Maître-esclave peut assurer la séparation de la lecture et de l'écriture, c'est-à-dire que l'opération d'écriture est sur le maître et l'opération de lecture est sur l'esclave. Il existe également plusieurs modes maître-esclave. ne parlez que d'un maître et de plusieurs esclaves.
Par exemple, il existe deux modules commerciaux. Un module écrit en continu les enregistrements de commandes, etc., et l'autre module génère des rapports. Si la séparation de lecture et d'écriture n'est pas adoptée à ce moment, les opérations de lecture et d'écriture le seront. entrer en collision, ce qui peut provoquer des conflits et affecter les performances, si la lecture et l'écriture sont séparées, il n'est pas nécessaire d'envisager de lire et d'écrire la même table pour affecter les performances, et plusieurs esclaves peuvent bien partager la pression sur le serveur et réduire la pression sur un une seule machine.
Le maître et l'esclave utilisent la réplication MySQL pour assurer la cohérence des données. Par rapport à la méthode de synchronisation des données du cluster, elle est asynchrone. En raison de l'asynchrone, il peut y avoir un léger retard dans la copie des données entre le maître et l'esclave. . Des retards et des incohérences se produiront.
Réplication : le nœud maître doit activer binlog, définir un identifiant de serveur unique (unique dans le réseau local), définir l'identifiant de serveur du nœud esclave, et le binlog enregistre toutes les informations sur le maître. L'opération sera copiée dans le relaylog du nœud esclave et relue sur le nœud esclave.
Mais le maître-esclave présente également des inconvénients. L'un est qu'il ne répond pas à la haute disponibilité. Le maître est en panne et doit être commuté manuellement. L'activité sera interrompue et n'est pas autorisée. 🎜>L'autre est que les données sont incohérentes et non cohérentes. Il existe de nombreuses raisons possibles. Voici quelques-unes des plus courantes
À propos du clusterLe plus grand avantage du cluster est le temps réel synchronisation des données, haute disponibilité et les données de chaque nœud sont synchronisées. Cohérent, contrairement au maître-esclave, où une incohérence des données se produit parfois, et haute disponibilité, tout temps d'arrêt du nœud n'affectera pas l'entreprise.
Mais l'inconvénient est la performance, la performance d'écriture. Chaque opération d'écriture sera synchronisée entre tous les nœuds. Il y a des gains et des pertes, ce qui garantit une haute disponibilité et la cohérence des données.
Dans le cluster, il y a un nœud de gestion et plusieurs nœuds SQL et nœuds de données. La réplication synchrone est utilisée entre les nœuds de données pour garantir la cohérence des données entre les nœuds. Généralement, elle est soumise en deux étapes. est la suivante
Si le maître reçoit un message ABORT d'un esclave, il envoie un message ABORT à tous les esclaves, indiquant à l'esclave d'abandonner la transaction.
Si l'Esclave reçoit une demande d'annulation, il annulera toutes les modifications et libérera les ressources qu'il occupe, annulant ainsi la transaction, puis enverra à Masterv la confirmation que le la transaction a été interrompue.
Lorsque le maître recevra la confirmation de tous les esclaves, il signalera que la transaction a été validée (ou abandonnée), puis passera à la transaction suivante
Étant donné que la réplication synchrone nécessite un total de 4 transferts de messages, la vitesse de mise à jour des données du cluster mysql est plus lente que celle du mysql autonome. Par conséquent, le cluster MySQL doit fonctionner dans un réseau local supérieur au Gigabit. Les nœuds peuvent utiliser deux cartes réseau et les groupes de nœuds sont directement connectés pour garantir la vitesse de mise à jour des 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!