Maison Opération et maintenance exploitation et maintenance Linux Comment utiliser l'équilibrage de charge haproxy MySQL

Comment utiliser l'équilibrage de charge haproxy MySQL

Sep 15, 2018 pm 03:54 PM
haproxy linux

Le contenu de cet article explique comment utiliser l'équilibrage de charge haproxy mysql. Il a une certaine valeur de référence. Les amis dans le besoin peuvent s'y référer.

Le système est un modèle à un maître et à plusieurs esclaves. La séparation de la lecture et de l'écriture est implémentée au niveau de l'application. Insérez, supprimez, mettez à jour et modifiez, accédez à la bibliothèque principale et sélectionnez. la bibliothèque des esclaves. Ensuite, j'ai effectué l'équilibrage de charge pour la bibliothèque esclave et utilisé keepalived pour combiner haproxy.

Comment utiliser léquilibrage de charge haproxy MySQL

Sans plus tarder, commençons.

Environnement système : centos7

Cela dit, je ne sais pas quand le site officiel de la communauté de haproxy a été bloqué... Hélas, vous pouvez télécharger la dernière version stable de haproxy via ce adresse.

# wget https://www.haproxy.org/download/1.8/src/haproxy-1.8.9.tar.gz
Copier après la connexion

Il est recommandé à vos amis de lire le fichier Lisez-moi avant l'installation

# cat /usr/src/haproxy-1.8.9/README
Copier après la connexion

Installez haproxy, où le mot-clé de préfixe PREFIX est spécifié Le répertoire d'installation est en majuscules. Pour l'installation générale du code source, ajoutez l'option "--prefix" après la commande configure pour distinguer

# tar -zxf haproxy-1.8.9.tar.gz -C /usr/src/
# cd /usr/src/haproxy-1.8.9/
# make TARGET=linux2628 USE_PCRE=1 USE_OPENSSL=1 USE_ZLIB=1 PREFIX=/usr/local/haproxy
# make install  PREFIX=/usr/local/haproxy
Copier après la connexion

Créer un utilisateur du programme haproxy et un répertoire de fichiers de configuration

# useradd -M -s /sbin/nologin haproxy
# mkdir /etc/haproxy
Copier après la connexion

Le fichier de configuration haproxy ne fournit pas d'exemple dans cette version du package et doit être créé manuellement

# touch /etc/haproxy/haproxy.cfg
# more /etc/haproxy/haproxy.cfg
#global    log  /dev/log   local0 info    log  /dev/log 
  local1 notice    pidfile   
    /var/run/haproxy.pid    maxconn     400000  
      user        haproxy    group    
         haproxy    nbproc      1    daemon
#defaults    mode   http    log   global 
   option http-server-close    option            
         redispatch    retries          
      0    timeout http-request  
        10s    timeout queue     
              1m    timeout connect     
                  10s    timeout client      
                      1m    timeout server     
                           1m    timeout http-keep-alive  300s  
             timeout check           10s    maxconn    
                   100000
listen mysql_select  bind *:3306  mode tcp  balance roundrobin 
 #balance source  #option mysql-check user haproxy  timeout server  15s  
 timeout connect 15s  server mysql162 192.168.5.162:3306 check port 3306 inter 5000 fall 5 
  server mysql163 192.168.5.163:3306 check port 3306 inter 5000 fall 5  
  server mysql164 192.168.5.164:3306 check port 3306 inter 5000 fall 5
listen stats        mode http        bind 0.0.0.0:7979        stats enable            stats hide-version        stats uri /haproxy?hello        stats realm Haproxy\ Statistics        stats auth qkc:pwd@123        stats admin if TRUE
Copier après la connexion


Les journaux haproxy sont sortis par défaut dans le syslog du système, ce qui n'est pas très pratique à visualiser. Afin de mieux gérer les journaux haproxy

, nous les définissons généralement indépendamment dans la chaîne de production. comme suit :

(1) Modifiez les options de configuration des journaux dans haproxy.cfg, ajoutez la configuration suivante à global et enregistrez les journaux d'informations et de notifications dans différents fichiers.

log  /dev/log   local0 info
log  /dev/log   local1 notice
Copier après la connexion

(2) Modifier la configuration de rsyslog

Afin de faciliter la gestion, les configurations liées à haproxy sont définies indépendamment dans /etc/rsyslog.d/haproxy .conf . Cette partie de la configuration enregistre les journaux d'informations et de notifications dans les fichiers /var/log/haproxy181/{haproxy181-info.log,haproxy181-notice.log} respectivement, où "& ~" signifie qu'une fois le journal écrit dans le fichier journal, rsyslog Arrêtez de traiter ce message. La syntaxe configurée ici est écrite en langage de script rainerscript.

# vim /etc/rsyslog.d/haproxy.conf
if ($programname == 'haproxy' and $syslogseverity-text == 'info')
 then -/var/log/haproxy181/haproxy181-info.log& ~if 
 ($programname == 'haproxy' and $syslogseverity-text == 'notice') 
 then -/var/log/haproxy181/haproxy181-notice.log& ~
Copier après la connexion

Vérifiez si la syntaxe du fichier de configuration haproxy.cfg est correcte

# /usr/local/haproxy/sbin/haproxy -f /etc/haproxy/haproxy.cfg -c
Copier après la connexion

S'il n'y a pas de problème, supprimez l'option -c et démarrez haproxy

# /usr/local/haproxy/sbin/haproxy -f /etc/haproxy/haproxy.cfg
Copier après la connexion
[root@server181 haproxy]# ss -antulp | grep haproxy
tcp    LISTEN   0  128   *:3306     *:*    users:(("haproxy",pid=3315,fd=4))
tcp    LISTEN   0  128    *:7979   *:*    users:(("haproxy",pid=3315,fd=6))
Copier après la connexion

Configurez haproxy pour qu'il démarre automatiquement au démarrage

# chmod +x /etc/rc.d/rc.local
# echo '/usr/local/haproxy/sbin/haproxy -f /etc/haproxy/haproxy.cfg' >> /etc/rc.d/rc.local
Copier après la connexion

Connectez haproxy pour les tests

# for i in $(seq 1 10); do mysql -utest -p123456 -h192.168.5.181 -e 'select @@server_id;'; done | egrep '[0-9]'
3306164
3306162
3306163
3306164
3306162
3306163
3306164
3306162
3306163
3306164
Copier après la connexion

Utilisez ensuite un autre serveur pour faire haroxy et intégrer keepalived. Le système distant utilise le client MySQL pour se connecter au VIP d'équilibrage de charge, puis effectue un contrôle de santé, un basculement et d'autres tests de projet un par un.

Résumé :

haproxy a une charge CPU très faible sur des charges de taille moyenne, et même dans des scénarios de charge très élevée, 5 % d'occupation de l'espace utilisateur et 95 % de l'utilisation de l'espace système est également un très phénomène courant, ce qui signifie que la consommation du processus haproxy est plus de 20 fois inférieure à la consommation d'espace du système. Par conséquent, l’optimisation des performances du système d’exploitation est très importante. Même si le taux d'occupation de l'espace utilisateur est doublé, son taux d'occupation CPU n'est que de 10 %, ce qui explique aussi pourquoi le traitement de couche 7 a un impact limité sur les performances. En conséquence, les performances de couche 7 de haproxy peuvent facilement dépasser celles des périphériques d'équilibrage de charge matériel sur les systèmes haut de gamme.

La fonctionnalité de haproxy qui prend en charge le proxy TCP lui permet également d'effectuer un équilibrage de charge pour la bibliothèque de lecture MySQL, et il peut fonctionner assez bien.

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)
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Commandes de chat et comment les utiliser
4 Il y a quelques semaines 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)

Comment démarrer Nginx dans Linux Comment démarrer Nginx dans Linux Apr 14, 2025 pm 12:51 PM

Étapes pour démarrer Nginx dans Linux: Vérifiez si Nginx est installé. Utilisez SystemCTL Start Nginx pour démarrer le service NGINX. Utilisez SystemCTL Activer Nginx pour activer le démarrage automatique de Nginx au démarrage du système. Utilisez SystemCTL Status Nginx pour vérifier que le démarrage est réussi. Visitez http: // localhost dans un navigateur Web pour afficher la page de bienvenue par défaut.

Comment vérifier si Nginx est démarré Comment vérifier si Nginx est démarré Apr 14, 2025 pm 01:03 PM

Comment confirmer si Nginx est démarré: 1. Utilisez la ligne de commande: SystemCTl Status Nginx (Linux / Unix), netStat -ano | Findstr 80 (Windows); 2. Vérifiez si le port 80 est ouvert; 3. Vérifiez le message de démarrage NGINX dans le journal système; 4. Utilisez des outils tiers, tels que Nagios, Zabbix et Icinga.

Comment démarrer le serveur Nginx Comment démarrer le serveur Nginx Apr 14, 2025 pm 12:27 PM

Le démarrage d'un serveur Nginx nécessite différentes étapes en fonction des différents systèmes d'exploitation: Système Linux / Unix: Installez le package NGINX (par exemple, en utilisant Apt-Get ou Yum). Utilisez SystemCTL pour démarrer un service NGINX (par exemple, sudo systemctl start nginx). Système Windows: téléchargez et installez les fichiers binaires Windows. Démarrer Nginx à l'aide de l'exécutable Nginx.exe (par exemple, nginx.exe -c conf \ nginx.conf). Peu importe le système d'exploitation que vous utilisez, vous pouvez accéder au serveur IP

Comment résoudre l'erreur Nginx403 Comment résoudre l'erreur Nginx403 Apr 14, 2025 pm 12:54 PM

Le serveur n'a pas l'autorisation d'accéder à la ressource demandée, ce qui donne une erreur NGINX 403. Les solutions incluent: vérifier les autorisations de fichiers. Vérifiez la configuration .htaccess. Vérifiez la configuration de Nginx. Configurez les autorisations Selinux. Vérifiez les règles du pare-feu. Dépanner d'autres causes telles que les problèmes de navigateur, les défaillances du serveur ou d'autres erreurs possibles.

Comment résoudre nginx403 Comment résoudre nginx403 Apr 14, 2025 am 10:33 AM

Comment corriger l'erreur interdite Nginx 403? Vérifier les autorisations de fichier ou de répertoire; 2. Vérifier le fichier .htaccess; 3. Vérifiez le fichier de configuration NGINX; 4. Redémarrer Nginx. D'autres causes possibles incluent les règles de pare-feu, les paramètres de Selinux ou les problèmes d'application.

Comment résoudre l'erreur Nginx304 Comment résoudre l'erreur Nginx304 Apr 14, 2025 pm 12:45 PM

Réponse à la question: 304 Erreur non modifiée indique que le navigateur a mis en cache la dernière version de ressource de la demande du client. Solution: 1. Effacer le cache du navigateur; 2. Désactiver le cache du navigateur; 3. Configurer Nginx pour permettre le cache client; 4. Vérifier les autorisations du fichier; 5. Vérifier le hachage du fichier; 6. Désactiver le CDN ou le cache proxy inversé; 7. Redémarrez Nginx.

Comment vérifier si Nginx est démarré? Comment vérifier si Nginx est démarré? Apr 14, 2025 pm 12:48 PM

Dans Linux, utilisez la commande suivante pour vérifier si Nginx est démarré: SystemCTL Status Nginx Juges Basé sur la sortie de la commande: si "Active: Active (Running)" s'affiche, Nginx est démarré. Si "Active: Inactive (Dead)" est affiché, Nginx est arrêté.

Comment nettoyer le journal d'erreur Nginx Comment nettoyer le journal d'erreur Nginx Apr 14, 2025 pm 12:21 PM

Le journal d'erreur est situé dans / var / log / nginx (linux) ou / usr / local / var / log / nginx (macOS). Utilisez la ligne de commande pour nettoyer les étapes: 1. Sauvegarder le journal d'origine; 2. Créez un fichier vide en tant que nouveau journal; 3. Redémarrez le service Nginx. Le nettoyage automatique peut également être utilisé avec des outils tiers tels que Logrotate ou configurés.

See all articles