Maison > Article > base de données > Créez des solutions de bases de données haute fiabilité à l'aide de MySQL et PostgreSQL
Créez des solutions de base de données haute fiabilité à l'aide de MySQL et PostgreSQL
1 Introduction
Dans la société actuelle axée sur les données, la fiabilité de la base de données revêt une importance extrêmement élevée. Afin de garantir le fonctionnement stable et continu du système et la sécurité des données, il est crucial de choisir une solution de base de données appropriée. MySQL et PostgreSQL, en tant que systèmes de gestion de bases de données relationnelles (SGBDR) open source les plus couramment utilisés, ont des fonctions puissantes et de bonnes performances. Cet article explique comment utiliser MySQL et PostgreSQL pour créer une solution de base de données hautement fiable et fournit des exemples de code pertinents à titre de référence.
2.1 Réplication de base de données MySQL
La réplication de base de données MySQL réalise la réplication et la synchronisation des données via le mode maître-esclave. Voici un exemple de code pour la réplication de la base de données MySQL :
Dans la base de données maître, effectuez la configuration suivante dans le fichier my.cnf :
[mysqld] server-id=1 log-bin=mysql-bin binlog-do-db=my_database
Dans la base de données esclave, effectuez la configuration suivante dans le fichier my.cnf fichier :
[mysqld] server-id=2
Dans la base de données maître, créez un utilisateur pour la réplication et accordez les autorisations de réplication :
CREATE USER 'replication_user'@'%' IDENTIFIED BY 'password'; GRANT REPLICATION SLAVE ON *.* TO 'replication_user'@'%';
Dans la base de données esclave, utilisez la commande suivante pour démarrer le processus de réplication :
CHANGE MASTER TO MASTER_HOST='master_host', MASTER_USER='replication_user', MASTER_PASSWORD='password', MASTER_LOG_FILE='mysql-bin.000001', MASTER_LOG_POS=0; START SLAVE;
2.2 Base de données PostgreSQL réplication
La réplication de base de données PostgreSQL utilise la réplication en continu pour répliquer et synchroniser les données. Voici un exemple de code pour la réplication de base de données PostgreSQL :
Dans la base de données principale, ouvrez le fichier postgresql.conf et configurez-le comme suit :
listen_addresses = '*' wal_level = replica archive_mode = on archive_command = 'cp "%p" /path/to/archive/%f' max_wal_senders = 2 wal_keep_segments = 10
Dans la base de données principale, ouvrez le fichier pg_hba.conf et ajoutez une connexion à la base de données esclave Paramètres :
host replication replication_user slave_ip/32 md5
Dans la base de données esclave, créez le fichier recovery.conf et configurez-le comme suit :
standby_mode = on primary_conninfo = 'host=master_ip port=5432 user=replication_user password=password' restore_command = 'cp /path/to/archive/%f "%p"'
Dans la base de données esclave, exécutez la commande suivante pour démarrer la base de données esclave :
pg_ctl start -D /usr/local/pgsql/data
3.1 Haute disponibilité de la base de données MySQL
La haute disponibilité de la base de données MySQL peut être obtenue grâce au mode maître-esclave et au clustering de bases de données.
Mode maître-esclave : basé sur la réplication de base de données, le serveur maître est utilisé pour les opérations de lecture et d'écriture, tandis que le serveur esclave est utilisé pour la sauvegarde et l'équilibrage de charge en lecture. Lorsque le serveur maître tombe en panne, le serveur esclave peut automatiquement basculer vers le serveur maître. Voici un exemple de code pour la haute disponibilité de la base de données MySQL basée sur le mode maître-esclave :
Dans la base de données esclave, créez un déclencheur et surveillez l'état du serveur maître :
mysql> TRIGGER failover_trigger APRÈS INSÉRER SUR le moniteur
-> POUR CHAQUE LIGNE
-> BEGIN
-> DECLARE server_status INT;
-> IF (server_status = 0) THEN
-> -- passer à master
-> END IF;
-> END$$
mysql>
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!