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.
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.gzCopier 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/READMECopier 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/haproxyCopier 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/haproxyCopier 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 TRUECopier 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 noticeCopier 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 -cCopier 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.cfgCopier 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.localCopier 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 3306164Copier 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!