本文摘自PHP中文网,作者little bottle,侵删。
关于mysql的读写分离架构有很多,百度的话几乎都是用mysql_proxy实现的。由于proxy是基于lua脚本语言实现的,所以网上不少网友表示proxy效率不高,也不稳定,不建议在生产环境使用;
amoeba是阿里开发的一款数据库读写分离的项目(读写分离只是它的一个小功能),由于是基于java编写的,所以运行环境需要安装jdk;相关教程:mysql视频教程
前期准备工作:
1.两个数据库,一主一从,主从同步;
master: 172.22.10.237:3306 ;主库负责写入操作;
slave: 10.4.66.58:3306 ; 从库负责读取操作;
amoeba: 172.22.10.237:8066 ; 我把amoeba安装到了主库所在的服务器,当然,你也可以安装到第三台服务器上;
所有服务器操作系统均为centos7;
2.在amoeba所在的服务器上配置安装jdk;
我安装的是jdk1.8;
路径是: JAVA_HOME=/usr/local/java/jdk1.8.0_131
以上务必自己点搭建、配置好,主从正常工作,添加jdk环境变量: /etc/profile ;
安装amoeba的方式有很多,这里就不在安装上面费口舌了,我下载了amoeba-mysql-3.0.5-RC-distribution的安装包,直接解压即可使用;
解压目录: /usr/local/amoeba/
很明显 conf里是配置文件,bin里是启动程序;
刚才说到 amoeba的功能可不止读写分离,但如果只用读写分离功能的话只需要配置这几个个文件即可: conf/dbServers.xml conf/amoeba.xml 和 bin/launcher ;
conf/dbServers.xml :
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 | `<property name = "port" >3306</property>
#设置Amoeba要连接的mysql数据库的端口,默认是3306
<property name = "schema" >testdb</property>
#设置缺省的数据库,当连接amoeba时,操作表必须显式的指定数据库名,即采用dbname.tablename的方式,不支持 use dbname指定缺省库,因为操作会调度到各个后端dbserver
<property name = "user" >test1</property>
#设置amoeba连接后端数据库服务器的账号和密码,因此需要在所有后端数据库上创建该用户,并授权amoeba服务器可连接
<property name = "password" >111111</property>
<property name = "maxActive" >500</property> #最大连接数,默认500
<property name = "maxIdle" >500</property> #最大空闲连接数
<property name = "minIdle" >1</property> #最新空闲连接数
<dbServer name = "writedb" parent= "abstractServer" > #设置一个后端可写的数据库,这里定义为writedb,这个名字可以任意命名,后面还会用到
<property name = "ipAddress" >172.22.10.237</property> #设置后端可写dbserver的ip
<dbServer name = "slave01" parent= "abstractServer" > #设置后端可读数据库
<property name = "ipAddress" >10.4.66.58</property>
<dbServer name = "myslave" virtual= "true" > #设置定义一个虚拟的dbserver,实际上相当于一个dbserver组,这里将可读的数据库ip统一放到一个组中,将这个组的名字命名为myslave
<property name = "loadbalance" >1</property> #选择调度算法,1表示复制均衡,2表示权重,3表示HA, 这里选择1
<property name = "poolNames" >slave01</property> #myslave组成员`
|
conf/amoeba.xml :
1 2 3 | #启动脚本,需要配置jdk环境变量;
#在注释后的第一行添加:
JAVA_HOME=/usr/ local /java/jdk1.8.0_131
|
launcher 是启动脚本,如果不配置JAVA_HOME的话,即便你在/etc/profile中配置了环境变量也可能会报错:没有配置jdk环境变量;
还有一个配置文件: jvm.properties
1 2 3 4 | #占用内存配置文件
# -Xss参数有最小值要求,必须大于228才能启动JVM
#修改:
JVM_OPTIONS= "-server -Xms1024m -Xmx1024m -Xss256k -XX:PermSize=16m -XX:MaxPermSize=96m"
|
有经验的运维都知道,凡是和jdk沾上边的,基本都会和内存的调优有关系,amoeba也不例外;
现在可以启动了:
启动后就可以看到本机的8066端口:
这时,你只需要通过本机ip的8066端口和你配置文件中设置的账号密码来连接数据库就行了,写入的数据都会到master里,读取的数据都会从slave中读取;
测试:
关闭master数据库,依然可以读取:执行 select 查看命令;
或者
关闭slave数据库,依然可以写入: 执行 update、inster命令;
以上就是如何利用amoeba实现mysql数据库的读写分离的详细内容,更多文章请关注木庄网络博客!
相关阅读 >>
mysql子查询是什么
总结mysql中float、double、decimal三个浮点类型的区别
wamp中mysql无法启动怎么办
mysql中的中文显示为问号怎么办
怎么检查看到mysql的用户名和密码
mysql主键,外键,非空,唯一,默认约束及创建表的方法
如何在phpmyadmin中修改mysql密码
动力节点mysql基础视频教程的资源分享
mysql查询数据之合并查询结果
mysql主键索引和普通索引之间的区别是什么
更多相关阅读请进入《mysql》频道 >>
机械工业出版社
本书主要讲述了数据模型、基于对象的数据库和XML、数据存储和查询、事务管理、体系结构等方面的内容。
转载请注明出处:木庄网络博客 » 如何利用amoeba实现mysql数据库的读写分离