使用mysqlproxy实现mysql读写分离
先说一下什么是读写分离吧。
以三台虚拟机为例,搭建一主一从一代理,全部配置好之后,当从proxy插入数据时,该数据会同时插入主数据库,因为主从关系,从数据库也会有数据。当把从数据库执行slave stop后,再次从proxy插入数据,数据只会插入主数据库,从数据库不会增加新数据。当在slave上插入数据时,主数据库不会增加新数据,但是proxy会读取到slave上新插入的数据。
简单来说就是,proxy将数据插入主数据库,读取数据时却是从从数据库读取。
下面开始说一下部署步骤:
主数据库:172.16.1.111
从数据库:172.16.1.112
MySQLProxy:172.16.1.110
主从配置,请参阅以下文章,我使用的用于同步的用户名为repl,密码为repl
http://www.cnblogs.com/biaopei/p/7730567.html
MySQLProxy下载地址https://downloads.mysql.com/archives/proxy/
做好安装MySQLProxy准备
解压文件
groupadd mysql
useradd -g mysql mysql
min_idle_connections = 1,
max_idle_connections = 2,
,以下命令需要根据自己的实际情况修改,例如ip地址还有文件的路径,其它就没什么了
./mysql-proxy --daemon --log-level=debug --user=mysql --keepalive --log-file=/var/log/mysql
-proxy.log --plugins="proxy" --proxy-backend-addresses="172.16.1.111:3306" --proxy-read-only-backend-addresses="172.16.1.112:3306" --proxy-lua-script="/root/mysqlproxy/share/doc/mysql-proxy/rw-splitting.lua" --plugins=admin --admin-username="admin" --admin-password="admin" --admin-lua-script="/root/mysqlproxy/lib/mysql-proxy/lua/admin.lua"
mysql -urepl -p -h 172.16.1.110 --port=4040 #密码是repl,如果你没改的话,bp库是我在master上创建的
现在我们再看一下状态是否正确
mysql -uadmin -p -h 172.16.1.110 --port=4041 #默认密码是admin,如图,我们在这里还会遇到一个问题
解决方法是,新开一个终端登录proxy,执行
mysql -urepl -p -h 172.16.1.110 --port=4040
再次查看,两个都为up说明,配置正确
现在我们就完成配置了,接下来开始测试读写分离功能
很简单,就是从proxy上登录
mysql -urepl -p -h 172.16.1.110 --port=4040
然后创建一个数据库,查看主从数据库,都会看到在proxy增加的新数据库
接着,我们从数据库执行slave stop后,再在proxy上新建一个数据库,发现只有master上能看到,slave上看不到,这不是重点,重点是在slave上新建一个数据库,在master上看不到,但proxy能读取到新增的数据库。
至此读写分离就完成了。
注意这里也必须重新开一终端连接proxy才会实现读写分离,如果使用同一个终端,会导致slave stop后,proxy的读写全部都是在master上,没有读写分离。还有就是,登录的时候直接回车即可,无需再输入密码,不知道是什么原因
(我个人觉得,slave 没有stop前,proxy读取的数据应该也是直接从slave上读取的)
如果看不懂的,可以参考一下https://www.2cto.com/database/201607/531145.html
使用mysqlproxy实现mysql读写分离的更多相关文章
- Mysql-Proxy实现mysql读写分离、负载均衡 (转)
在mysql中实现读写分离.负载均衡,用Mysql-Proxy是很容易的事,不过大型处理对于性能方面还有待提高,主要配置步骤如下: 1.1. mysql-proxy安装 MySQL Proxy就是这么 ...
- Windows中使用Mysql-Proxy实现Mysql读写分离
1.简介 读写分离:当业务量上来时,往往一台单机的mysql数据库不能满足性能需求,这时候就需要配置主从库读写分离来解决性能瓶颈.简单的来说,就是原先一台数据库既读又写,现在改成一台写和1台以上读. ...
- [记录]MySQL读写分离(Atlas和MySQL-proxy)
MySQL读写分离(Atlas和MySQL-proxy) 一.阿里云使用Atlas从外网访问MySQL(RDS) (同样的方式修改配置文件可以实现代理也可以实现读写分离,具体看使用场景) 1.在跳板机 ...
- Mysql读写分离(mysql-proxy)
MySQL-Proxy是一个处于你的client端和MySQL server端之间的简单程序,它可以监测.分析或改变它们的通信.它使用灵活,没有限制,常见的用途包括:负载平衡,故障.查询分析,查询过滤 ...
- 转:Mysql读写分离实现的三种方式
1 程序修改mysql操作类可以参考PHP实现的Mysql读写分离,阿权开始的本项目,以php程序解决此需求.优点:直接和数据库通信,简单快捷的读写分离和随机的方式实现的负载均衡,权限独立分配缺点:自 ...
- 使用Atlas实现MySQL读写分离+MySQL-(Master-Slave)配置
参考博文: MySQL-(Master-Slave)配置 本人按照博友北在北方的配置已成功 我使用的是 mysql5.6.27版本. 使用Atlas实现MySQL读写分离 数据切分——Atlas读 ...
- MySQL读写分离技术
1.简介 当今MySQL使用相当广泛,随着用户的增多以及数据量的增大,高并发随之而来.然而我们有很多办法可以缓解数据库的压力.分布式数据库.负载均衡.读写分离.增加缓存服务器等等.这里我们将采用读写分 ...
- mysql读写分离总结
随着一个网站的业务不断扩展,数据不断增加,数据库的压力也会越来越大,对数据库或者SQL的基本优化可能达不到最终的效果,我们可以采用读写分离的策略来改变现状.读写分离现在被大量应用于很多大型网站,这个技 ...
- Mysql读写分离方案-Amoeba环境部署记录
Mysql的读写分离可以使用MySQL Proxy,也可以使用Amoeba.Amoeba(变形虫)项目是一个类似MySQL Proxy的分布式数据库中间代理层软件,是由陈思儒开发的一个开源的java项 ...
随机推荐
- LINQ之路12:LINQ Operators之数据转换(Projecting)
本篇继续LINQ Operators的学习,这里我们讨论的是数据转换的两种方式:Select和SelectMany,看似简单常用的两种运算符,却也大有讲究.我们会在本篇详细介绍他们的使用方式和适用的场 ...
- Mac redis安装
Download, extract and compile Redis with: #进入下载目录 $ cd ... $ wget http://download.redis.io/releases/ ...
- 激活Pychram
最近更新了Intellij IDEA到2018.1.5之后,使用之前的授权服务器(http://idea.imsxm.com)会提示Outdated License Server Detected,大 ...
- jmeter+influxdb+grafana性能测试监控
背景: 话说Jmeter原生的监控确实太丑了,听大佬们在讨论Jmeter+InfluxDb+Grafana的监控,于是,为了有一个漂亮的测试报告,就手动开始进行部署. 安装步骤: 1.influxdb ...
- mapping values are not allowed in this context at line 115 column 10
/opt/vagrant/embedded/lib/ruby//psych.rb::in `parse': (<unknown>): mapping values are not allo ...
- 关于var time = +new Date;
文章地址:https://www.cnblogs.com/Raoh/p/4212075.html
- localStorage、sessionStorage用法以及区别
设置: sessionStorage.setItem("key", "value");localStorage.setItem("site" ...
- Linux进程间通信机制
Linux支持管道.信号.unix system V三种IPC(Inter-Process-Communication)机制.以下分别对三种机制加以简单介绍. 一.信号机制: 信号又称作软中断,用来通 ...
- wonder vscode plugins
├─ .obsolete├─ .wlck├─ .wtid├─ 1194979849.code-snippets-0.1.18├─ abeyuhang.vscode-lesslint-0.0.1├─ a ...
- 最全的测试用例(UI)
一.文本框为字符型 必填项非空校验: 1.必填项未输入--程序应提示错误: 2.必填项只输入若干个空格,未输入其它字符--程序应提示错误: 字段唯一性校验:(不是所有字段都作此项校 ...