HAProxy + Percona XtraDB Cluster

1

Eu estou tentando configurar o HAproxy em conjunto com o Percona XtraDB Cluster em uma série de 3 instâncias do EC2. Eu encontrei alguns tutoriais online lidando com esta questão específica, mas estou um pouco preso.

Os servidores Percona e os servidores HAproxy estão executando o Ubuntu 12.04. A versão do HAProxy é 1.4.18,

Quando inicio o HAProxy, recebo o seguinte erro: O servidor pxc-back / db01 está ABAIXO, motivo: erro de soquete, verificação de duração: 2 ms.

Eu não tenho certeza do que o problema poderia ser. Eu verifiquei o seguinte:

  1. As portas dos grupos de segurança do EC2 estão abertas
  2. despejei meus arquivos de configuração em busca de problemas. Eu atualmente não vejo nenhum.
  3. Assegure-se de que o xinetd foi instalado
  4. Garanto que estou usando o endereço IP correto do servidor mysql.

Qualquer ajuda com isso é muito apreciada.

Aqui está minha configuração atual

Balanceador de carga

/etc/haproxy/haproxy.cfg

global
  log 127.0.0.1 local0
  log 127.0.0.1 local1 notice
  maxconn 4096
  user haproxy
  group haproxy
  debug
  #quiet
  daemon

defaults
  log global
  mode http
  option tcplog
  option dontlognull
  retries 3
  option redispatch
  maxconn 2000
  contimeout 5000
  clitimeout 50000
  srvtimeout 50000

frontend pxc-front
  bind 0.0.0.0:3307
  mode tcp
  default_backend pxc-back

frontend stats-front
  bind 0.0.0.0:22002
  mode http
  default_backend stats-back

backend pxc-back
  mode tcp
  balance leastconn
  option httpchk
  server db01 10.86.154.105:3306 check port 9200 inter 12000 rise 3 fall 3

backend stats-back 
  mode http
  balance roundrobin
  stats uri /haproxy/stats

Servidor MySql

/etc/xinetd.d/mysqlchk

# default: on
# description: mysqlchk
service mysqlchk
{
# this is a config for xinetd, place it in /etc/xinetd.d/
        disable = no
        flags           = REUSE
        socket_type     = stream
        port            = 9200
        wait            = no
        user            = nobody
        server          = /usr/bin/clustercheck
        log_on_failure  += USERID
        #only_from       = 0.0.0.0/0
        # recommended to put the IPs that need
        # to connect exclusively (security purposes)
        per_source      = UNLIMITED
}

Servidor MySql

/ etc / services

Adicionada a linha mysqlchk 9200 / tcp # mysqlchk

Servidor MySql

/ usr / bin / clustercheck

# GNU nano 2.2.6 File: /usr/bin/clustercheck
#!/bin/bash
#
# Script to make a proxy (ie HAProxy) capable of monitoring Percona XtraDB Cluster nodes properly
#
# Author: Olaf van Zandwijk <[email protected]>
# Documentation and download: https://github.com/olafz/percona-clustercheck
#
# Based on the original script from Unai Rodriguez
#

MYSQL_USERNAME="testuser"
MYSQL_PASSWORD=""
ERR_FILE="/dev/null"
AVAILABLE_WHEN_DONOR=0

#
# Perform the query to check the wsrep_local_state
#
WSREP_STATUS='mysql --user=${MYSQL_USERNAME} --password=${MYSQL_PASSWORD} -e "SHOW STATUS LIKE 'wsrep_local_state';" 2>${ERR_FILE} | awk '{if (NR!=1){print $2}}' 2>${ERR_FILE}'

if [[ "${WSREP_STATUS}" == "4" ]] || [[ "${WSREP_STATUS}" == "2" && ${AVAILABLE_WHEN_DONOR} == 1 ]]
then
    # Percona XtraDB Cluster node local state is 'Synced' => return HTTP 200
    /bin/echo -en "HTTP/1.1 200 OK\r\n"
    /bin/echo -en "Content-Type: text/plain\r\n"
    /bin/echo -en "\r\n"
    /bin/echo -en "Percona XtraDB Cluster Node is synced.\r\n"
    /bin/echo -en "\r\n"
else
    # Percona XtraDB Cluster node local state is not 'Synced' => return HTTP 503
    /bin/echo -en "HTTP/1.1 503 Service Unavailable\r\n"
    /bin/echo -en "Content-Type: text/plain\r\n"
    /bin/echo -en "\r\n"
    /bin/echo -en "Percona XtraDB Cluster Node is not synced.\r\n"
    /bin/echo -en "\r\n"
fi
    
por rottmanj 11.01.2013 / 07:57

2 respostas

1

Por favor, certifique-se dos seguintes passos e publique os resultados aqui.

  1. o xinetd está em execução.
  2. Crie o usuário do teste mysql testuser como você mencionou
  3. verifique a escuta da porta tcp (9200) por netstat -nlt
  4. Se você ativou o iptables, permita a porta 9200
  5. se a porta estiver aberta e no estado de escuta, instale o cliente telnet no nó percona e tente telnetar por telnet 127.0.0.1 9200
  6. Se o xinetd estiver funcionando, você deverá ver a resposta http.
  7. se não, execute /usr/bin/clustercheck

Depois de fazer tudo isso, poste os resultados aqui.

    
por 02.09.2013 / 07:22
1

Eu tive problema onde telnet 127.0.0.1 9200 deu 503 Server resposta indisponível, mas quando eu executei /usr/bin/clustercheck como root mostrou que estava tudo bem.

Com este comando, consegui executar o clustercheck como usuário nobody e recebi um erro real do MySQL para /tmp/cluster.log :

sudo -H -u nobody bash -c "/usr/bin/clustercheck clustercheckuser clustercheckpassword! 0 /tmp/cluster.log"

E /tmp/cluster.log contido:

ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/var/run/mysql/mysql.sock' (13)

O problema era que o diretório em que mysql.sock estava localizado não tinha sinalizador de execução (+ x) e, portanto, não era legível pelo usuário nobody e a correção era:

chmod o+x /var/run/mysql

    
por 08.12.2014 / 15:14