Mysql-Proxy: Установка и настройка на CentOS7
Балансировка mysql запросов - важная вещь, если мы используете несколько mysql серверов. Если у Вас настроена master-slave репликация баз даных, то есть смысл распределить нагрузку на несколько серверов. Отправлять update, insert запросы на master сервер, а select запросы распределять между двумя, тремя и более серверами.
Для этого можно воспользоваться утилитой mysql-proxy. К сожалению довольно мало документации на эту тему присутствует на просторах интернета. Нужно устранить эту брешь.
Итак, для начала нам понадобится glib последней версии. Все действия я проводил на CentOS7.
Скачиваем исходник и распаковываем его:
wget http://ftp.gnome.org/pub/gnome/sources/glib/2.42/glib-2.42.0.tar.xz
tar xvf glib-2.42.0.tar.xz
В случае проблем с распаковкой - усановите xz-utils
или просто пакет xz
и посторите операцию.
Следующие пакеты нужны будут для выполнения правильной сборки:
yum install lua lua-devel libevent libevent-devel glib2 glib2-devel pkg-config mysqlclient14-devel libffi mysql libffi-devel zlib zlib-devel gcc gettext-devel glibc glibc-devel
Теперь переходим в папку glib
и устанавливаем его:
cd glib-2.42.0
./configure
make
make install
В ходе выполнения появится вот такое сообщение:
Libraries have been installed in:
/usr/local/lib
If you ever happen to want to link against installed libraries
in a given directory, LIBDIR, you must either use libtool, and
specify the full pathname of the library, or use the `-LLIBDIR'
flag during linking and do at least one of the following:
- add LIBDIR to the `LD_LIBRARY_PATH' environment variable
during execution
- add LIBDIR to the `LD_RUN_PATH' environment variable
during linking
- use the `-Wl,-rpath -Wl,LIBDIR' linker flag
- have your system administrator add LIBDIR to '/etc/ld.so.conf'
Соответсвенно библиотеки оказались в /usr/local/lib/
Для того что бы система их увидела, я сделал симлинки, создав резервные копии оригиальных файлов:
mv /usr/lib64/libglib-2.0.so.0 /usr/lib64/libglib-2.0.so.0.bak
mv /usr/lib64/libglib-2.0.so /usr/lib64/libglib-2.0.so.bak
ln -s /usr/local/lib/libglib-2.0.so.0.4200.0 /usr/lib64/libglib-2.0.so.0
ln -s /usr/local/lib/libglib-2.0.so.0.4200.0 /usr/lib64/libglib-2.0.so
Теперь можно переходить к установке mysql-proxy
. Говорят, что он когда-то был доступен в репозитарии Epel
. К сожалению я его там не нашел. Поэтому скачиваем готовый пакет и устанавливаем его:
wget ftp://195.220.108.108/linux/fedora/linux/releases/22/Everything/x86_64/os/Packages/m/mysql-proxy-0.8.5-1.fc22.x86_64.rpm
rpm -ihv mysql-proxy-0.8.5-1.fc22.x86_64.rpm
Также понадобится оригинальный пакет с исходниками из-за дополнительного скрипта. Скачиваем его и распаковываем:
wget http://dev.mysql.com/get/Downloads/MySQL-Proxy/mysql-proxy-0.8.5-linux-glibc2.3-x86-64bit.tar.gz
tar xf mysql-proxy-0.8.5-linux-glibc2.3-x86-64bit.tar.gz
Чудо скрипт, который будет разделять read
и write
запросы, нужно скопировать в папку к mysql-proxy
:
cp share/doc/mysql-proxy/rw-splitting.lua /usr/lib64/mysql-proxy/lua/proxy/
Узнаем расположение конфиг файла вот ткой командой:
rpm -qc mysql-proxy
В моем случае это /etc/sysconfig/mysql-proxy
. В любимом редакторе открываем этот файл для редактирования и устанавливаем пароль для админа (ADMIN_PASSWORD
) - он не должен быть пустым.
PROXY_OPTIONS
приводим к следующему виду:
PROXY_OPTIONS=`-log-level=info \
-proxy-address=:3306 \
-log-use-syslog \
-plugins=proxy \
-plugins=admin \
-proxy-backend-addresses=192.168.1.143:3306 \
-proxy-read-only-backend-addresses=192.168.1.132 \
-proxy-lua-script=/usr/lib64/mysql-proxy/lua/proxy/rw-splitting.lua`
proxy-backend-addresses
- адресmaster
сервера, на который будут отправлятьсяinsert
иupdate
запросы.proxy-read-only-backend-addresses
- адрес сервера, на который будут уходить толькоselect
запросы.proxy-address
- определяетip
адрес и порт, на котором будут обрабатываться входящие соединения. По умолчанию 4040
Создаем симлинки:
cd /usr/lib64
ln -s /opt/mysql-proxy/lib/libmysql-chassis.so.0.0.0 libmysql-chassis.so.0
ln -s /opt/mysql-proxy/lib/libmysql-proxy.so.0.0.0 libmysql-proxy.so.0
ln -s /opt/mysql-proxy/lib/libmysql-chassis-glibext.so.0.0.0 libmysql-chassis-glibext.so.0
ln -s /opt/mysql-proxy/lib/libevent-2.0.so.5.1.9 libevent-2.0.so.5
ln -s /opt/mysql-proxy/lib/libmysql-chassis-timing.so.0.0.0 libmysql-chassis-timing.so.0
Теперь можно запускать:
/etc/init.d/mysql-proxy start
Для того что бы проверть состояние кластера подключитесь к админке:
mysql -hlocalhost -P4041 -uadmin -ppassword
Для отображения всех бэкэндов выполните следующий запрос:
SELECT * FROM backends;
В результате получаем табличку:
+-------------+--------------------+---------+------+------+-------------------+
| backend_ndx | address | state | type | uuid | connected_clients |
+-------------+--------------------+---------+------+------+-------------------+
| 1 | 192.168.1.143:3306 | unknown | rw | NULL | 0 |
| 2 | 192.168.1.132:3306 | unknown | ro | NULL | 0 |
+-------------+--------------------+---------+------+------+-------------------+
При написании получал вдохновление с этой статей.