欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時(shí)間:2019年05月08日 09:06:06   作者:星火燎愿  
這篇文章主要介紹了詳解如何利用amoeba(變形蟲(chóng))實(shí)現(xiàn)mysql數(shù)據(jù)庫(kù)讀寫(xiě)分離,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧

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

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

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

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

  1. master: 172.22.10.237:3306 ;主庫(kù)負(fù)責(zé)寫(xiě)入操作;
  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)程序;

剛才說(shuō)到 amoeba的功能可不止讀寫(xiě)分離,但如果只用讀寫(xiě)分離功能的話只需要配置這幾個(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è)后端可寫(xiě)的數(shù)據(jù)庫(kù),這里定義為writedb,這個(gè)名字可以任意命名,后面還會(huì)用到
    <property name="ipAddress">172.22.10.237</property> #設(shè)置后端可寫(xiě)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)聽(tīng)的端口,默認(rèn)是8066
    <property name="ipAddress">127.0.0.1</property> 
        #配置監(jiān)聽(tīng)的接口,如果不設(shè)置,默認(rèn)監(jiān)聽(tīng)所以的IP
        # 提供客戶端連接amoeba時(shí)需要使用這里設(shè)定的賬號(hào) (這里的賬號(hào)密碼和amoeba連接后端數(shù)據(jù)庫(kù)服務(wù)器的密碼無(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)是注銷掉的,需要取消注釋,這里用來(lái)指定前面定義好的倆個(gè)讀寫(xiě)池
    <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ò):沒(méi)有配置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í),你只需要通過(guò)本機(jī)ip的8066端口和你配置文件中設(shè)置的賬號(hào)密碼來(lái)連接數(shù)據(jù)庫(kù)就行了,寫(xiě)入的數(shù)據(jù)都會(huì)到master里,讀取的數(shù)據(jù)都會(huì)從slave中讀??;

測(cè)試:

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

或者

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

相關(guān)文章

  • MySQL中字段類型為longtext的值導(dǎo)出后顯示二進(jìn)制串方式

    MySQL中字段類型為longtext的值導(dǎo)出后顯示二進(jìn)制串方式

    這篇文章主要介紹了MySQL中字段類型為longtext的值導(dǎo)出后顯示二進(jìn)制串方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-07-07
  • mysql批量刪除大量數(shù)據(jù)

    mysql批量刪除大量數(shù)據(jù)

    這篇文章主要介紹了mysql批量刪除大量數(shù)據(jù)的相關(guān)資料,需要的朋友可以參考下
    2017-04-04
  • mysql解壓包的安裝基礎(chǔ)教程

    mysql解壓包的安裝基礎(chǔ)教程

    這篇文章主要為大家詳細(xì)介紹了mysql解壓包的安裝基礎(chǔ)教程,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-08-08
  • MySQL配置sql_mode的參數(shù)屬性作用

    MySQL配置sql_mode的參數(shù)屬性作用

    ,通過(guò)設(shè)置sql_mode,可以完成不同嚴(yán)格程度的數(shù)據(jù)校驗(yàn),本文主要介紹了MySQL配置sql_mode的作用,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2024-07-07
  • mysql命令行下執(zhí)行sql文件的幾種方法

    mysql命令行下執(zhí)行sql文件的幾種方法

    本文主要介紹了mysql命令行下執(zhí)行sql文件的幾種方法,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-12-12
  • mysql 5.7.30安裝配置方法圖文教程

    mysql 5.7.30安裝配置方法圖文教程

    這篇文章主要為大家分享了mysql 5.7.30安裝配置方法圖文教程,感興趣的小伙伴們可以參考一下
    2016-05-05
  • 安裝MySQL時(shí),輸入mysqld --install后,顯式該文件已存在問(wèn)題

    安裝MySQL時(shí),輸入mysqld --install后,顯式該文件已存在問(wèn)題

    這篇文章主要介紹了安裝MySQL時(shí),輸入mysqld --install后,顯式該文件已存在問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-12-12
  • Mysql忘記密碼解決方法

    Mysql忘記密碼解決方法

    這篇文章主要給大家風(fēng)向的是Mysql忘記密碼解決方法,我們忘記mysql密碼時(shí),我們可以通過(guò)mysql的配置文件設(shè)置登錄不需要認(rèn)證就可以不需要密碼進(jìn)行登錄了,下面我們就進(jìn)入文章學(xué)習(xí)具體的解決方法吧
    2022-02-02
  • 全面了解mysql中utf8和utf8mb4的區(qū)別

    全面了解mysql中utf8和utf8mb4的區(qū)別

    下面小編就為大家?guī)?lái)一篇全面了解mysql中utf8和utf8mb4的區(qū)別。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2016-08-08
  • php mysql連接數(shù)據(jù)庫(kù)實(shí)例

    php mysql連接數(shù)據(jù)庫(kù)實(shí)例

    這篇文章主要介紹了php mysql連接數(shù)據(jù)庫(kù)實(shí)例,需要的朋友可以參考下
    2016-09-09

最新評(píng)論