旗下导航:搜·么
当前位置:网站首页 > MySQL教程 > 正文

怎样应用amoeba完成mysql数据库的读写星散【MySQL教程】,mysql,amoeba,读写分离

作者:搜教程发布时间:2019-12-01分类:MySQL教程浏览:55评论:0


导读:关于mysql的读写星散架构有许多,百度的话险些都是用mysql_proxy完成的。由于proxy是基于lua剧本语言完成的,所以网上不少网友示意proxy效力不高,也不稳定,不发...
关于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 :

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

       #启动剧本,须要设置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也不破例;

如今能够启动了:

启动后就能够看到本机的8066端口:

这时候,你只须要经由过程本机ip的8066端口和你设置文件中设置的账号暗码来衔接数据库就好了,写入的数据都邑到master里,读取的数据都邑从slave中读取;
测试:
封闭master数据库,依旧能够读取:实行 select 检察敕令;
或许
封闭slave数据库,依旧能够写入: 实行 update、inster敕令;

以上就是怎样应用amoeba完成mysql数据库的读写星散的细致内容,更多请关注ki4网别的相干文章!

标签:mysqlamoeba读写分离


欢迎 发表评论: