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链接

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 206,311评论 6 481
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 88,339评论 2 382
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 152,671评论 0 342
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 55,252评论 1 279
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 64,253评论 5 371
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,031评论 1 285
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,340评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,973评论 0 259
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 43,466评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,937评论 2 323
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,039评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,701评论 4 323
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,254评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,259评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,485评论 1 262
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,497评论 2 354
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,786评论 2 345