准备好三台机器:
192.168.220.129(proxy)
192.168.220.143(master)
192.168.220.144(slave)
确保三台机器上mysql(5.6.29)都已装好
my.cnf配置
master:
[mysqld1]
basedir = /usr/localmysql
datadir = /data/mysql
port = 3306
server_id=1
socket = /tmp/mysql.sock
log-bin=mysql-bin
slave:
[mysqld1]
basedir = /usr/localmysql
datadir = /data/mysql
port = 3306
server_id=2
socket = /tmp/mysql.sock
master上创建复制用户
grant replication slave on *.* to 'server'@'192.168.220.144' identified by '123456';
flush privileges;
show master status;
mysql> show master status;
+------------------+----------+--------------+------------------+-------------------+
| File | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |
+------------------+----------+--------------+------------------+-------------------+
| mysql-bin.000001 | 120 | | | |
+------------------+----------+--------------+------------------+-------------------+
slave上操作
slave stop;
change master to master_host='192.168.220.144',master_user='server',master_password='123456',master_log_file='mysql-bin.000001',master_log_pos=120;
slave start;
show slave status\G;
确保状态:
Slave_IO_Running: Yes
Slave_SQL_Running: Yes
实现读写分离
安装一些依赖包:
yum -y install gcc libevent libevent-devel readline readline-devel ncurses ncurses-devel glib2 glib2-devel
安装Lua:
wget -c http://www.lua.org/ftp/lua-5.1.5.tar.gz
tar zxvf lua-5.1.5.tar.gz
cd lua-5.1.5
vi Makefile #将INSTALL_TOP=/usr/local修改为:INSTALL_TOP=/usr/local/lua
vi ./src/Makefile #将CFLAGS= -O2 -Wall $(MYCFLAGS)修改为:CFLAGS= -O2 -Wall -fPIC $(MYCFLAGS)
make linux
make install
安装MySQL Proxy
wget -c http://dev.mysql.com/get/Downloads/MySQL-Proxy/mysql-proxy-0.8.3.tar.gz/from/http://cdn.mysql.com/ -O /usr/local/src/mysql-proxy-0.8.3.tar.gz
tar zxvf mysql-proxy-0.8.3.tar.gz
cd mysql-proxy-0.8.3
./configure LDFLAGS="-lm -ldl" LUA_CFLAGS="-I/usr/local/lua/include/" LUA_LIBS=/usr/local/lua/lib/liblua.a --prefix=/usr/local/mysql-proxy --with-lua --with-mysql=/usr/local/mysql/bin/mysql_config
make && make install
MySQL Proxy配置与启动
mkdir /usr/local/mysql-proxy/conf
mkdir /var/log/mysql-proxy
cd /usr/local/mysql-proxy/conf
vim mysql-proxy.conf
[mysql-proxy]
daemon=true
pid-file=/usr/local/mysql-proxy/mysql-proxy.pid
log-file=/var/log/mysql-proxy/mysql.log
log-level=debug
LUA_PATH="/usr/local/src//usr/local/src/mysql-proxy-0.8.3/lib/?.lua"
proxy-lua-script=/usr/local/src/mysql-proxy-0.8.3/lib/rw-splitting.lua
proxy-address=192.168.220.129:3306
proxy-read-only-backend-addresses=192.168.220.143:3306
proxy-backend-addresses=192.168.220.144:3306
keepalive=true
proxy-skip-profiling=true
#proxy-connect-timeout=2
#proxy-read-timeout=60
#proxy-write-timeout=30
admin-address=:4041
admin-lua-script=/usr/local/src/mysql-proxy-0.8.3/lib/admin.lua
admin-username=admin
admin-password=admin
plugins=proxy,admin
chmod 660 mysql-proxy.conf
vim /usr/local/src/mysql-proxy-0.8.3/lib/rw-splitting.lua
--- config
---- connection poolif not proxy.global.config.rwsplit then proxy.global.config.rwsplit = { min_idle_connections = 1, max_idle_connections = 3, is_debug = false }end
启动MySQL Proxy
[root@abc conf]# /usr/local/mysql-proxy/bin/mysql-proxy --defaults-file=/usr/local/mysql-proxy/conf/mysql-proxy.conf
查看启动日志:
[root@abc conf]# tail -f /var/log/mysql-proxy/mysql.log
2016-03-04 19:54:03: (message) shutting down normally, exit code is: 0
2016-03-04 19:54:18: (message) chassis-unix-daemon.c:136: [angel] we try to keep PID=10766 alive
2016-03-04 19:54:18: (debug) chassis-unix-daemon.c:157: waiting for 10766
2016-03-04 19:54:18: (debug) chassis-unix-daemon.c:121: we are the child: 10766
2016-03-04 19:54:18: (critical) plugin proxy 0.8.3 started
2016-03-04 19:54:18: (critical) plugin admin 0.8.3 started
2016-03-04 19:54:18: (debug) max open file-descriptors = 1024
2016-03-04 19:54:18: (message) proxy listening on port 192.168.220.129:3306
2016-03-04 19:54:18: (message) added read/write backend: 192.168.220.144:3306
2016-03-04 19:54:18: (message) added read-only backend: 192.168.220.143:3306