利用amoeba(变形虫)实现mysql数据库读写分离

amoeba是阿里开发的一款数据库读写分离的项目(读写分离只是它的一个小功能),由于是基于java编写的,所以运行环境需要安装jdk;

前期准备工作:
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. < property name= "port"> 3306</ property>  
  2. #设置Amoeba要连接的mysql数据库的端口,默认是3306
  3. < property name= "schema">testdb</ property>  
  4. #设置缺省的数据库,当连接amoeba时,操作表必须显式的指定数据库名,即采用dbname.tablename的方式,不支持 use dbname指定缺省库,因为操作会调度到各个后端dbserver
  5. < property name= "user">test1</ property>  
  6. #设置amoeba连接后端数据库服务器的账号和密码,因此需要在所有后端数据库上创建该用户,并授权amoeba服务器可连接
  7. < property name= "password"> 111111</ property>
  8. < property name= "maxActive"> 500</ property>   #最大连接数,默认500
  9. < property name= "maxIdle"> 500</ property>     #最大空闲连接数
  10. < property name= "minIdle"> 1</ property>     #最新空闲连接数
  11. <dbServer name= "writedb" parent= "abstractServer">   #设置一个后端可写的数据库,这里定义为writedb,这个名字可以任意命名,后面还会用到
  12. < property name= "ipAddress"> 172.22 .10 .237</ property> #设置后端可写dbserver的ip
  13. <dbServer name= "slave01" parent= "abstractServer">   #设置后端可读数据库
  14. < property name= "ipAddress"> 10.4 .66 .58</ property>
  15. <dbServer name= "myslave" virtual= "true">   #设置定义一个虚拟的dbserver,实际上相当于一个dbserver组,这里将可读的数据库ip统一放到一个组中,将这个组的名字命名为myslave
  16. < property name= "loadbalance"> 1</ property>   #选择调度算法,1表示复制均衡,2表示权重,3表示HA, 这里选择1
  17. < property name= "poolNames">slave01</ property>   #myslave组成员

conf/amoeba.xml :


 
 
  1. < property name= "port"> 8066</ property>    
  2. #设置amoeba监听的端口,默认是8066
  3. < property name= "ipAddress"> 127.0 .0 .1</ property>
  4. #配置监听的接口,如果不设置,默认监听所以的IP
  5. # 提供客户端连接amoeba时需要使用这里设定的账号 (这里的账号密码和amoeba连接后端数据库服务器的密码无关)
  6. < property name= "user">root</ property> 
  7. < property name= "password"> 123456</ property>
  8. < property name= "defaultPool">myslave</ property>  
  9. #设置amoeba默认的池,这里设置为writedb
  10. < property name= "writePool">master</ property>  
  11. #这两个选项默认是注销掉的,需要取消注释,这里用来指定前面定义好的俩个读写池
  12. < property name= "readPool">slave01</ property>

bin/launcher :


 
 
  1. #启动脚本,需要配置jdk环境变量;
  2. #在注释后的第一行添加:
  3. JAVA_HOME= /usr/local /java/jdk1. 8.0_131

launcher 是启动脚本,如果不配置JAVA_HOME的话,即便你在/etc/profile中配置了环境变量也可能会报错:没有配置jdk环境变量;
还有一个配置文件: jvm.properties


 
 
  1. #占用内存配置文件
  2. # -Xss参数有最小值要求,必须大于228才能启动JVM
  3. #修改:
  4. JVM_OPTIONS= "-server -Xms1024m -Xmx1024m -Xss256k -XX:PermSize=16m -XX:MaxPermSize=96m"

有经验的运维都知道,凡是和jdk沾上边的,基本都会和内存的调优有关系,amoeba也不例外;

现在可以启动了:

启动后就可以看到本机的8066端口:

这时,你只需要通过本机ip的8066端口和你配置文件中设置的账号密码来连接数据库就行了,写入的数据都会到master里,读取的数据都会从slave中读取;
测试:
关闭master数据库,依然可以读取:执行 select 查看命令;
或者
关闭slave数据库,依然可以写入: 执行 update、inster命令;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值