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

坏嘻嘻
坏嘻嘻original
2018-09-15 15:54:592964parcourir

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

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

# cat /usr/src/haproxy-1.8.9/README

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

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

# useradd -M -s /sbin/nologin haproxy
# mkdir /etc/haproxy

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


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

(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& ~

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

# /usr/local/haproxy/sbin/haproxy -f /etc/haproxy/haproxy.cfg -c

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
[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))

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

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

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