Перейти к основному содержимому
Версия: 2.0.x

Балансировка нагрузки

При развёртывании нескольких узлов FE пользователи могут развернуть слой балансировки нагрузки поверх FE для достижения высокой доступности.

Ниже приведены некоторые варианты обеспечения высокой доступности:

Подход на уровне кода

Один из способов — реализовать логику на уровне приложения для выполнения повторных попыток и балансировки нагрузки. Например, если соединение разрывается, оно автоматически повторяется на других соединениях. Этот подход требует, чтобы пользователи настроили несколько адресов узлов FE.

JDBC Connector

JDBC connector поддерживает автоматические повторные попытки:

jdbc:mysql:loadbalance://[host1][:port],[host2][:port][,[host3][:port]]...[/[database]][?propertyName1=propertyValue1[&propertyName2=propertyValue2]...]

ProxySQL

ProxySQL — это прокси-слой MySQL, который поддерживает разделение чтения/записи, маршрутизацию запросов, кэширование SQL, динамическую настройку нагрузки, отказоустойчивость и фильтрацию SQL.

Selena FE отвечает за приём соединений и запросов, и он горизонтально масштабируется и обладает высокой доступностью. Однако FE требует, чтобы пользователи настроили прокси-слой поверх него для достижения автоматической балансировки нагрузки. Ниже приведены шаги настройки:

1. Установка необходимых зависимостей

yum install -y gnutls perl-DBD-MySQL perl-DBI perl-devel

2. Загрузка установочного пакета

wget https://github.com/sysown/proxysql/releases/download/v1.5.2/proxysql-2.0.14-1-centos7.x86_64.rpm

3. Распаковка в текущую директорию

rpm2cpio proxysql-2.0.14-1-centos7.x86_64.rpm | cpio -ivdm

4. Изменение файла конфигурации

vim ./etc/proxysql.cnf

Укажите директорию, к которой у пользователя есть права доступа (абсолютный путь):

datadir="/var/lib/proxysql"
errorlog="/var/lib/proxysql/proxysql.log"

5. Запуск

./usr/bin/proxysql -c ./etc/proxysql.cnf --no-monitor

6. Вход в систему

mysql -u admin -padmin -h 127.0.0.1 -P6032

7. Настройка глобального журнала

SET mysql-eventslog_filename='proxysql_queries.log';
SET mysql-eventslog_default_log=1;
SET mysql-eventslog_format=2;
LOAD MYSQL VARIABLES TO RUNTIME;
SAVE MYSQL VARIABLES TO DISK;

8. Добавление leader-узла

insert into mysql_servers(hostgroup_id, hostname, port) values(1, '172.xx.xx.139', 9030);

9. Добавление observer-узлов

insert into mysql_servers(hostgroup_id, hostname, port) values(2, '172.xx.xx.139', 9030);
insert into mysql_servers(hostgroup_id, hostname, port) values(2, '172.xx.xx.140', 9030);

10. Загрузка конфигурации

load mysql servers to runtime;
save mysql servers to disk;

11. Настройка имени пользователя и пароля

insert into mysql_users(username, password, active, default_hostgroup, backend, frontend) values('root', '*94BDCEBE19083CE2A1F959FD02F964C7AF4CFC29', 1, 1, 1, 1);

12. Загрузка конфигурации

load mysql users to runtime;
save mysql users to disk;

13. Запись в правила прокси

insert into mysql_query_rules(rule_id, active, match_digest, destination_hostgroup, mirror_hostgroup, apply) values(1, 1, '.', 1, 2, 1);

14. Загрузка конфигурации

load mysql query rules to runtime;
save mysql query rules to disk;