Mysql的主从复制的读写分离之Amoeba实现
Mysql的主从复制的读写分离之Amoeba实现以前写过了一篇Mysql的主从复制,但没有实现Mysql的主从复制的读写分离。关于读写分离:读写分离(Read/WriteSplitting),
Mysql的主从复制的读写分离之Amoeba实现以前写过了一篇Mysql的主从复制,但没有实现Mysql的主从复制的读写分离。
关于读写分离:
读写分离(Read/Write Splitting),基本的原理是让主数据库处理事务性增、改、删、操作(INSERT、UPDATE、DELETE),而从数据库处理SELECT查询操作。数据库复制被用来把事务性操作导致的变更同步到集群中的从数据库。
关于Mysql的读写分离实现大致有三种:
1、 程序修改Mysql操作类
就以程序来完成Mysql的读写操作,如以PHP程序、java程序等解决此需求。
优点:直接和数据库通信,简单快捷的读写分离和随机的方式实现的负载均衡,权限独立分配
缺点:自己维护更新,增减服务器上的代码处理。
2、 mysql-proxy
MySQL-Proxy是处在你的MySQL数据库客户和服务端之间的程序,它还支持嵌入性脚本语言Lua。这个代理可以用来分析、监控和变换(transform)通信数据,它支持非常广泛的使用场景:
优点:直接实现读写分离和负载均衡,不用修改代码,master和slave用同一个账号
缺点:字符集问题,lua语言编程,还只是alpha版本,时间消耗有点高
3、 Amoeba
参考官网:,meidusa.com/
优点:直接实现读写分离和负载均衡,不用修改代码,有很灵活的数据解决方案
以上是三种常见的Mysql的读写分离方法。在这建议用第三种也就是amoeba来实现
关于Amoeba
Amoeba(变形虫)项目,该开源框架于2008年开始发布一款Amoeba for Mysql软件。这个软件致力于Mysql的分布式数据库前端代理层,它主要在应用层访问Mysql的时候充当SQL路由功能,专注于分布式数据库代理层(Database Proxy)开发。位于Client、DB Server(s)之间,虚拟主机,对客户透明。具有负载均衡、高可用性、SQL过滤、读写分离、可路由相关的到目标数据库、可并发请求多台数据库合并结果。通过Amoeba你能够完成多数据源的高可用、负载均衡、数据切片的功能,目前Amoeba已在很多企业的生产线上使用。
下面就来把 Mysql的主从复制和读写分离完整的实现一下。
先来做Mysql的主从复制。
我实现的环境如下:
System:Centos 5.4 32bit
主:192.168.1.107
从:192.168.1.139
读写分离:192.168.1.183
拓扑图如下:
MySql的主从复制:
对主MysqL服务器,主要是开启二进制日志,这个默认是开启的,在配置文件中:
# vim /etc/my.cnf
server-id = 1 (默认为1)
log-bin = mysql-bin (这个也是默认开启的)
下面连接到mysql数据库中创建一个用户并赋予复制权限。
mysql> GRANT REPLICATION CLIENT,REPLICATION SLAVE ON *.* TO 'repl'@'192.168.1.139' IDENTIFIED BY "123456";
这样在主服务器上操作暂时完成了。
下面来在从服务器上操作:
修改主配置文件:my.cnf
因为在主mysql中已经有数据了,所以要把主服务器的数据导入到从服务器中,所以在主服务器上的操作:
以上操作完成后就可以做把主从连接在一起了。
在从服务器上进入数据库中
上一篇: PHP的bool值_PHP教程
下一篇: 有何位用过百度云推送,指点下迷津吧
推荐阅读
-
Mysql的主从复制的读写分离之Amoeba实现
-
MySQL主从同步读写分离的集群配置_MySQL
-
keepalived+amoeba+mysql-mmm+mysql实现mysql读写分离及高可用
-
服务器-mysql5.6读写分离中遇到的问题
-
MySQL之—如何添加新数据库到MySQL主从复制列表的具体介绍
-
keepalived+amoeba+mysql-mmm+mysql实现mysql读写分离及高可用
-
RHEL6.5下MySQL读写分离的实现
-
php实现带读写分离功能的MySQL类完整实例
-
Java多线程之readwritelock读写分离的实现代码
-
php实现的mysqldb读写分离操作类示例