濮阳杆衣贸易有限公司

主頁 > 知識(shí)庫(kù) > 詳解如何利用amoeba(變形蟲)實(shí)現(xiàn)mysql數(shù)據(jù)庫(kù)讀寫分離

詳解如何利用amoeba(變形蟲)實(shí)現(xiàn)mysql數(shù)據(jù)庫(kù)讀寫分離

熱門標(biāo)簽:福建外呼電銷機(jī)器人加盟 昌德訊外呼系統(tǒng) 自己做地圖標(biāo)注需要些什么 百度地圖標(biāo)注要什么軟件 中國(guó)地圖標(biāo)注公司 徐涇鎮(zhèn)騰訊地圖標(biāo)注 天津公司外呼系統(tǒng)軟件 電話機(jī)器人的價(jià)格多少錢一個(gè)月 400電話申請(qǐng)廠家現(xiàn)貨

關(guān)于mysql的讀寫分離架構(gòu)有很多,百度的話幾乎都是用mysql_proxy實(shí)現(xiàn)的。由于proxy是基于lua腳本語言實(shí)現(xiàn)的,所以網(wǎng)上不少網(wǎng)友表示proxy效率不高,也不穩(wěn)定,不建議在生產(chǎn)環(huán)境使用;

amoeba是阿里開發(fā)的一款數(shù)據(jù)庫(kù)讀寫分離的項(xiàng)目(讀寫分離只是它的一個(gè)小功能),由于是基于java編寫的,所以運(yùn)行環(huán)境需要安裝jdk;

前期準(zhǔn)備工作:

1.兩個(gè)數(shù)據(jù)庫(kù),一主一從,主從同步;

  1. master: 172.22.10.237:3306 ;主庫(kù)負(fù)責(zé)寫入操作;
  2. slave: 10.4.66.58:3306 ; 從庫(kù)負(fù)責(zé)讀取操作;
  3. amoeba: 172.22.10.237:8066 ; 我把a(bǔ)moeba安裝到了主庫(kù)所在的服務(wù)器,當(dāng)然,你也可以安裝到第三臺(tái)服務(wù)器上;

所有服務(wù)器操作系統(tǒng)均為centos7;

2.在amoeba所在的服務(wù)器上配置安裝jdk;

我安裝的是jdk1.8;

路徑是: JAVA_HOME=/usr/local/java/jdk1.8.0_131

以上務(wù)必自己點(diǎn)搭建、配置好,主從正常工作,添加jdk環(huán)境變量: /etc/profile ;

安裝amoeba的方式有很多,這里就不在安裝上面費(fèi)口舌了,我下載了amoeba-mysql-3.0.5-RC-distribution的安裝包,直接解壓即可使用;

解壓目錄: /usr/local/amoeba/

很明顯 conf里是配置文件,bin里是啟動(dòng)程序;

剛才說到 amoeba的功能可不止讀寫分離,但如果只用讀寫分離功能的話只需要配置這幾個(gè)個(gè)文件即可: conf/dbServers.xml conf/amoeba.xml 和 bin/launcher ;

conf/dbServers.xml :

 `property name="port">3306/property>  
      #設(shè)置Amoeba要連接的mysql數(shù)據(jù)庫(kù)的端口,默認(rèn)是3306
  property name="schema">testdb/property>  
     #設(shè)置缺省的數(shù)據(jù)庫(kù),當(dāng)連接amoeba時(shí),操作表必須顯式的指定數(shù)據(jù)庫(kù)名,即采用dbname.tablename的方式,不支持 use dbname指定缺省庫(kù),因?yàn)椴僮鲿?huì)調(diào)度到各個(gè)后端dbserver
  property name="user">test1/property>  
       #設(shè)置amoeba連接后端數(shù)據(jù)庫(kù)服務(wù)器的賬號(hào)和密碼,因此需要在所有后端數(shù)據(jù)庫(kù)上創(chuàng)建該用戶,并授權(quán)amoeba服務(wù)器可連接
  property name="password">111111/property>

  property name="maxActive">500/property>  #最大連接數(shù),默認(rèn)500
  property name="maxIdle">500/property>    #最大空閑連接數(shù)
  property name="minIdle">1/property>    #最新空閑連接數(shù)

  dbServer name="writedb" parent="abstractServer">  #設(shè)置一個(gè)后端可寫的數(shù)據(jù)庫(kù),這里定義為writedb,這個(gè)名字可以任意命名,后面還會(huì)用到
    property name="ipAddress">172.22.10.237/property> #設(shè)置后端可寫dbserver的ip

  dbServer name="slave01" parent="abstractServer">  #設(shè)置后端可讀數(shù)據(jù)庫(kù)
    property name="ipAddress">10.4.66.58/property>

   dbServer name="myslave" virtual="true">  #設(shè)置定義一個(gè)虛擬的dbserver,實(shí)際上相當(dāng)于一個(gè)dbserver組,這里將可讀的數(shù)據(jù)庫(kù)ip統(tǒng)一放到一個(gè)組中,將這個(gè)組的名字命名為myslave
      property name="loadbalance">1/property>  #選擇調(diào)度算法,1表示復(fù)制均衡,2表示權(quán)重,3表示HA, 這里選擇1
      property name="poolNames">slave01/property>  #myslave組成員`

conf/amoeba.xml :

property name="port">8066/property>    
    #設(shè)置amoeba監(jiān)聽的端口,默認(rèn)是8066
    property name="ipAddress">127.0.0.1/property> 
        #配置監(jiān)聽的接口,如果不設(shè)置,默認(rèn)監(jiān)聽所以的IP
        # 提供客戶端連接amoeba時(shí)需要使用這里設(shè)定的賬號(hào) (這里的賬號(hào)密碼和amoeba連接后端數(shù)據(jù)庫(kù)服務(wù)器的密碼無關(guān))
      property name="user">root/property> 
      property name="password">123456/property>

    property name="defaultPool">myslave/property>  
        #設(shè)置amoeba默認(rèn)的池,這里設(shè)置為writedb
    property name="writePool">master/property>  
        #這兩個(gè)選項(xiàng)默認(rèn)是注銷掉的,需要取消注釋,這里用來指定前面定義好的倆個(gè)讀寫池
    property name="readPool">slave01/property>

bin/launcher :

 #啟動(dòng)腳本,需要配置jdk環(huán)境變量;
    #在注釋后的第一行添加:
    JAVA_HOME=/usr/local/java/jdk1.8.0_131

launcher 是啟動(dòng)腳本,如果不配置JAVA_HOME的話,即便你在/etc/profile中配置了環(huán)境變量也可能會(huì)報(bào)錯(cuò):沒有配置jdk環(huán)境變量;

還有一個(gè)配置文件: jvm.properties

  #占用內(nèi)存配置文件
    # -Xss參數(shù)有最小值要求,必須大于228才能啟動(dòng)JVM
    #修改:
      JVM_OPTIONS="-server -Xms1024m -Xmx1024m -Xss256k -XX:PermSize=16m -XX:MaxPermSize=96m"

有經(jīng)驗(yàn)的運(yùn)維都知道,凡是和jdk沾上邊的,基本都會(huì)和內(nèi)存的調(diào)優(yōu)有關(guān)系,amoeba也不例外;

現(xiàn)在可以啟動(dòng)了:

啟動(dòng)后就可以看到本機(jī)的8066端口:


這時(shí),你只需要通過本機(jī)ip的8066端口和你配置文件中設(shè)置的賬號(hào)密碼來連接數(shù)據(jù)庫(kù)就行了,寫入的數(shù)據(jù)都會(huì)到master里,讀取的數(shù)據(jù)都會(huì)從slave中讀??;

測(cè)試:

關(guān)閉master數(shù)據(jù)庫(kù),依然可以讀?。簣?zhí)行 select 查看命令;

或者

關(guān)閉slave數(shù)據(jù)庫(kù),依然可以寫入: 執(zhí)行 update、inster命令;

您可能感興趣的文章:
  • MySQL主從同步、讀寫分離配置步驟
  • mysql 讀寫分離(基礎(chǔ)篇)
  • MySQL的使用中實(shí)現(xiàn)讀寫分離的教程
  • mysql 讀寫分離(實(shí)戰(zhàn)篇)
  • 詳解MySQL的主從復(fù)制、讀寫分離、備份恢復(fù)
  • mysql主從復(fù)制讀寫分離的配置方法詳解
  • 詳解MySQL主從復(fù)制讀寫分離搭建

標(biāo)簽:陜西 駐馬店 鄂爾多斯 荊門 北京 昌都 黔西 梅河口

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《詳解如何利用amoeba(變形蟲)實(shí)現(xiàn)mysql數(shù)據(jù)庫(kù)讀寫分離》,本文關(guān)鍵詞  詳解,如何,利用,amoeba,變形蟲,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《詳解如何利用amoeba(變形蟲)實(shí)現(xiàn)mysql數(shù)據(jù)庫(kù)讀寫分離》相關(guān)的同類信息!
  • 本頁收集關(guān)于詳解如何利用amoeba(變形蟲)實(shí)現(xiàn)mysql數(shù)據(jù)庫(kù)讀寫分離的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    南通市| 博罗县| 罗田县| 沐川县| 罗定市| 鄱阳县| 漠河县| 霍林郭勒市| 华容县| 宜丰县| 屏边| 威远县| 绩溪县| 都匀市| 苏尼特左旗| 平塘县| 阜城县| 信阳市| 商水县| 吐鲁番市| 阿拉尔市| 乌海市| 正阳县| 太康县| 博兴县| 松江区| 南宫市| 探索| 屏山县| 新密市| 大洼县| 绍兴市| 大同县| 甘德县| 额尔古纳市| 营口市| 平舆县| 南澳县| 阳东县| 大新县| 泾川县|