利用amoeba实现mysql数据库读写分离的案例

51次阅读
没有评论

共计 2811 个字符,预计需要花费 8 分钟才能阅读完成。

自动写代码机器人,免费开通

丸趣 TV 小编给大家分享一下利用 amoeba 实现 mysql 数据库读写分离的案例,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!

关于 mysql 的读写分离架构有很多,百度的话几乎都是用 mysql_proxy 实现的。由于 proxy 是基于 lua 脚本语言实现的,所以网上不少网友表示 proxy 效率不高,也不稳定,不建议在生产环境使用;

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/

利用 amoeba 实现 mysql 数据库读写分离的案例

很明显 conf 里是配置文件,bin 里是启动程序;

刚才说到 amoeba 的功能可不止读写分离,但如果只用读写分离功能的话只需要配置这几个个文件即可:conf/dbServers.xml conf/amoeba.xml 和 bin/launcher;

conf/dbServers.xml:

 ` 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:

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

bin/launcher :

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

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

还有一个配置文件:jvm.properties

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

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

现在可以启动了:

利用 amoeba 实现 mysql 数据库读写分离的案例

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

利用 amoeba 实现 mysql 数据库读写分离的案例

这时,你只需要通过本机 ip 的 8066 端口和你配置文件中设置的账号密码来连接数据库就行了,写入的数据都会到 master 里,读取的数据都会从 slave 中读取;

测试:

关闭 master 数据库,依然可以读取:执行 select 查看命令;

或者

关闭 slave 数据库,依然可以写入:执行 update、inster 命令;

看完了这篇文章,相信你对“利用 amoeba 实现 mysql 数据库读写分离的案例”有了一定的了解,如果想了解更多相关知识,欢迎关注丸趣 TV 行业资讯频道,感谢各位的阅读!

向 AI 问一下细节

正文完
 
丸趣
版权声明:本站原创文章,由 丸趣 2023-12-04发表,共计2811字。
转载说明:除特殊说明外本站除技术相关以外文章皆由网络搜集发布,转载请注明出处。
评论(没有评论)