我的编程空间,编程开发者的网络收藏夹
学习永远不晚

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

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

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

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

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

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

前期准备工作:

1.两个数据库,一主一从,主从同步;

  1. master: 172.22.10.237:3306 ;主库负责写入操作;

  2. slave: 10.4.66.58:3306 ; 从库负责读取操作;

  3. 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数据库读写分离的案例”有了一定的了解,如果想了解更多相关知识,欢迎关注亿速云行业资讯频道,感谢各位的阅读!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

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

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

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

前期准备工作: 1.两个数据库,一主一从,主从同步; master: 172.22.10.237:3306 ;主库负责写入操作; slave: 10.4.66.58:3306 ; 从库负责读取操作; amoeba: 172.22.10.237:8066 ; 我
利用amoeba(变形虫)实现mysql数据库读写分离
2015-09-22

Node.js Sequelize如何实现数据库的读写分离

一、前言 在构建高并发的Web应用时,除了应用层要采取负载均衡方案外,数据库也要支持高可用和高并发性。使用较多的数据库优化方案是:通过主从复制(Master-Slave)的方式来同步数据,再通过读写分离(MySQL-Proxy)来提升数据库
2022-06-04

MySQL INSERT锁与数据库读写分离的实时性

MySQL的INSERT锁是指在进行INSERT操作时会对表进行排他锁,防止其他事务对该表进行修改,保证插入操作的原子性和一致性。数据库读写分离是指将数据库的读和写操作分开,通过主从复制等技术将数据库的读操作分配给从服务器处理,从而减轻主
MySQL INSERT锁与数据库读写分离的实时性
2024-08-14

SpringBoot+Mybatis-Plus实现mysql读写分离方案的示例代码

1. 引入mybatis-plus相关包,pom.xml文件2. 配置文件application.property增加多库配置 mysql 数据源配置spring.datasource.primary.jdbc-url=jdbc:mysql
2022-05-24

Mysql数据库的主从复制与读写分离怎么实现

这篇文章主要介绍“Mysql数据库的主从复制与读写分离怎么实现”,在日常操作中,相信很多人在Mysql数据库的主从复制与读写分离怎么实现问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Mysql数据库的主从复制
2023-06-21

利用PHP实现MySQL读写分离的优势与挑战

利用PHP实现MySQL读写分离的优势与挑战随着Web应用程序规模的不断扩大和访问量的增加,数据库读写性能成为了开发者们面临的一个关键挑战。为了解决这一问题,很多开发者开始使用MySQL读写分离技术来提高数据库处理能力。本文将探讨如何利用
利用PHP实现MySQL读写分离的优势与挑战
2024-03-04

编程热搜

目录