本篇是以MySql之主从复制为基础作的拓展mysql
在主从复制中,咱们设置了两台数据库服务器(master,slave)linux
接下来咱们须要作到在master进行写操做(insert,update,delete)
在slave上进行读操做(select)sql
通常状况下,会有多台slave,由于数据库的读写操做比基本是4:1
因此咱们使用多台slave服务器来进行负载均衡,分担数据库的压力数据库
要完成读写分离,咱们还要继续准备一台数据库服务器,做为其集群的中间件segmentfault
Mysql-Proxy是基于rw-splitting.lua实现的
首先安装rw-splitting.lua:服务器
wget wget http://www.lua.org/ftp/lua-5.2.4.tar.gz tar zvfx lua-5.2.4.tar.gz cd lua-5.2.4
配置安装文件:负载均衡
vi src/Makefile 找到 CFLAGS= -O2 -Wall (MYCFLAGS) 修改成: CFLAGS=−O2−Wall−fPIC (MYCFLAGS) :wq
安装lua
make make install
配置系统变量:rest
cp etc/lua.pc /usr/lib/pkgconfig/ export PKG_CONFIG_PATH=$PKG_CONFIG_PATH:/usr/lib/pkgconfig
下载地址:code
https://downloads.mysql.com/archives/proxy/
解压安装:
tar zxvf mysql-proxy-0.8.0-linux-rhel5-x86-32bit.tar.gz mv mysql-proxy-0.8.0-linux-rhel5-x86-32bit mysql-proxy
配置mysql-proxy
mkdir /mysql-proxy/init.d
cd /mysql-proxy/init.d
vi mysql-proxy
#!/bin/sh # # mysql-proxy This script starts and stops the mysql-proxy daemon # # chkconfig: - 78 30 # processname: mysql-proxy # description: mysql-proxy is a proxy daemon to mysql # Source function library. . /etc/rc.d/init.d/functions #PROXY_PATH=/usr/local/bin PROXY_PATH=/opt/mysql-proxy/bin prog="mysql-proxy" # Source networking configuration. . /etc/sysconfig/network # Check that networking is up. [ ${NETWORKING} = "no" ] && exit 0 # Set default mysql-proxy configuration. #PROXY_OPTIONS="--daemon" PROXY_OPTIONS="--admin-username=root --admin-password=password --proxy-read-only-backend-addresses=192.168.10.131:3306 --proxy-backend-addresses=192.168.10.130:3306 --admin-lua-script=/opt/mysql-proxy/lib/mysql-proxy/lua/admin.lua --proxy-lua-script=/opt/mysql-proxy/scripts/rw-splitting.lua" PROXY_PID=/opt/mysql-proxy/run/mysql-proxy.pid # Source mysql-proxy configuration. if [ -f /etc/sysconfig/mysql-proxy ]; then . /etc/sysconfig/mysql-proxy fi PATH=$PATH:/usr/bin:/usr/local/bin:$PROXY_PATH # By default it's all good RETVAL=0 # See how we were called. case "$1" in start) # Start daemon. echo -n $"Starting $prog: " NICELEVELNICELEVELPROXY_PATH/mysql-proxy $PROXY_OPTIONS --daemon --pid-file=$PROXY_PID --user=mysql --log-level=warning --log-file=/opt/mysql-proxy/log/mysql-proxy.log RETVAL=$? echo if [ $RETVAL = 0 ]; then touch /var/lock/subsys/mysql-proxy fi ;; stop) # Stop daemons. echo -n $"Stopping $prog: " killproc $prog RETVAL=$? echo if [ $RETVAL = 0 ]; then rm -f /var/lock/subsys/mysql-proxy rm -f $PROXY_PID fi ;; restart) $0 stop sleep 3 $0 start ;; condrestart) [ -e /var/lock/subsys/mysql-proxy ] && $0 restart ;; status) status mysql-proxy RETVAL=$? ;; *) echo "Usage: $0 {start|stop|restart|status|condrestart}" RETVAL=1 ;; esac exit $RETVAL
chmod +x /opt/mysql-proxy/init.d/mysql-proxy
mkdir /opt/mysql-proxy/run
mkdir /opt/mysql-proxy/log
mkdir /opt/mysql-proxy/scripts
拿到最新的rw-splitting.lua读写分离脚本
从https://downloads.mysql.com/archives/proxy/
下载最新的源码包
解压并cd到根目录,把脚本考到咱们本地mysql-proxy的scripts文件夹下
cp lib/rw-splitting.lua /mysql-proxy/scripts
修改rw-splitting.lua:
vi /mysql-proxy/scripts/rw-splitting.lua
min_idle_connections = 1, //默认为4 max_idle_connections = 1, //默认为8
保存后启动
/mysql-proxy/init.d/mysql-proxy start
以上即是MySql之读写分离