mysql一主多从+mysql-proxy实现读写分离

一.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代表定位

注意File和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链接

你可能感兴趣的:(mysql一主多从+mysql-proxy实现读写分离)