首頁  >  文章  >  資料庫  >  如何利用amoeba實現mysql資料庫的讀寫分離

如何利用amoeba實現mysql資料庫的讀寫分離

little bottle
little bottle轉載
2019-05-07 09:08:312086瀏覽

關於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/

如何利用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 :

       #启动脚本,需要配置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資料庫的讀寫分離的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文轉載於:51cto.com。如有侵權,請聯絡admin@php.cn刪除