一.mysql配置,所有节点都要加上,每个节点的server-id要不同
replicate-do-db=demo #用于读写分离的具体数据库,这里我创建了demo作测试
log-bin=mysql-bin #从库会基于此log-bin来做复制
relay-log = relay-log #开启中继日志
log-bin = mysql-bin #开启二进制日志
read_only = ON #启用只读属性
relay_log_purge = 0 #是否自动清空不再需要中继日志
skip_name_resolve #关闭名称解析(非必须)
log_slave_updates = 1 #使得更新的数据写进二进制日志中
#选择row模式
binlog-format=ROW
enforce_gtid_consistency=on
gtid_mode=on
server-id=2
二.开启集群模式
查看主节点的状态,得到bin-log的信息
file代表当前的bin-log日志文件,position代表定位
从节点配置命令,登陆从节点mysql客户端,步骤关闭从节点服务-重置从节点服务-配置主节点命令-开启从节点服务
开启从节点服务 start slave;
关闭从节点服务 stop slave;
重置从节点服务 reset slave;
配置主节点命令:
change master to
master_host='主节点ip',
master_port=主节点端口,
master_user='主节点mysql用户',
master_password='密码',
master_log_file='mysql-bin.000006',//主节点的file
master_log_pos=196;//主节点的position
以上完成了主从复制的配置
三.读写分离配置-mysql-proxy
1.配置lua
(1)安装依赖
yum install cpp binutils glibc glibc-kernheaders glibc-common glibc-devel gcc make readline-devel -y
(2)下载包
wget http://www.lua.org/ftp/lua-5.3.5.tar.gz -P /opt/
(3)解压包
cd /opt/
tar xf lua-5.3.5.tar.gz
(4)修改Makefile文件
cd /opt/lua-5.3.5/
vi Makefile
# 设置 INSTALL_TOP= /usr/local/lua
(5)编译
make linux && make install
(6)添加环境变量
vim /etc/profile
添加:
export LUA_HOME=/usr/local/lua
export PATH=$PATH:$LUA_HOME/bin
环境变量生效:
source /etc/profile
2.安装mysql-proxy:
(1) 下载mysql-proxy包
wget https://cdn.mysql.com/archives/mysql-proxy/mysql-proxy-0.8.5-linux-el6-x86-64bit.tar.gz -P /opt/
(2) 解压包和创建软连接
tar xf mysql-proxy-0.8.5-linux-el6-x86-64bit.tar.gz
ln -s mysql-proxy-0.8.5-linux-el6-x86-64bit mysql-proxy085
(3) 创建logs目录
mkdir /opt/mysql-proxy085/logs
(4) 添加环境变量
echo "PATH=/opt/mysql-proxy085/bin/:$PATH" >> /etc/profile
source /etc/profile
(5) 配置代理文件
vim /etc/mysql-proxy.cnf
[mysql-proxy]
# 运行mysql-proxy用户
user=root
# mysql-proxy连接后端mysql服务器的用户
admin-username=mysql_proxy_user
# mysql-proxy连接后端mysql服务器的密码
admin-password=123456
# 代理的监听地址端口,默认端口4040
proxy-address=0.0.0.0:3307
#指定后端主master写入数据
proxy-backend-addresses=192.168.1.101:3306
#指定后端从slave读取数据
proxy-read-only-backend-addresses=192.168.1.102:3306
#指定读写分离配置文件位置
proxy-lua-script=/opt/mysql-proxy085/share/doc/mysql-proxy/rw-splitting.lua
#日志位置
log-file=/opt/mysql-proxy085/logs/mysql-proxy.log
#定义log日志级别,由高到低分别有(error|warning|info|message|debug)
log-level=debug
#以守护进程方式运行
daemon=true
#mysql-proxy崩溃时,尝试重启
keepalive=true
(6) 修改配置文件权限
chmod 660 /etc/mysql-proxy.cnf
(7) 主库添加授权用户
grant all privileges on *.* to 'mysql_proxy_user'@'192.168.1.%' identified by '123456';
flush privileges;
(8) 启动代理
mysql-proxy --defaults-file=/etc/mysql-proxy.cnf
(9) 连接通过代理账户连接代理开启的ip及端口
注:前提你连接的这台机器得弄个mysql客户端
# 测试的话:mysql包解压了,添加环境变量即可
# 后端的话:直接通过模块就连接1.100机器3307端口即可
mysql -umysql_proxy_user -p123456 -h192.168.1.100 --port=3307
五.总结
主从复制是基于mysql的bin-log功能,可以实现一主多从配置,因为使用的是bin-log同步,会出现同步有时延问题,此处没有实现高可用,高可用可配置mha,实现一个高可用和管理。而mysql-proxy原理是一个代理,通过lua进行一个读写分离的转发,亦可以当成是一个mysql链接