• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            xiaoguozi's Blog
            Pay it forword - 我并不覺的自豪,我所嘗試的事情都失敗了······習慣原本生活的人不容易改變,就算現狀很糟,他們也很難改變,在過程中,他們還是放棄了······他們一放棄,大家就都是輸家······讓愛傳出去,很困難,也無法預料,人們需要更細心的觀察別人,要隨時注意才能保護別人,因為他們未必知道自己要什么·····

            Amoeba for MySQL 位于Client、Database Server(s)之間,具有負載均衡、高可用性、sql過濾、可承受高并發、讀寫分離、Query Route(解析sql query語句,并且根據條件與預先設定的規則,請求到指定的目標數據庫。可并發請求多臺數據庫合并結果)、對客戶端透明,能降低數據切分帶來的復雜多數據庫結構、數據切分規則給應用帶來的影響。適用mysql 4.1或者以上版本(mysql 協議版本:10)暫時不支持事務、DDL語句目前只會分配給默認的數據庫執行,運行環境至少需要運行 mysql 4.1以上服務, Java 1.5或以上版本。
            Amoeba與mysql proxy存在一些區別。在mysql proxy上面如果想要讀寫分離并且讀集群、寫集群機器比較多情況下,用mysql proxy 需要自己寫一個LUA腳本,目前mysql proxy沒有現成的比較好的lua腳本。amoeba只需要進行相關的配置就可以滿足需求。


            一、Mysql Master/Slave 結構之下的讀寫分離:
            Master: serverM (主庫,接收寫操作)
            slaves:serverA、serverB、serverC(3個輔庫,只讀操作)

            amoeba提供讀寫分離pool相關配置,可配置serverA、serverB、serverC形成一個虛擬的virtualSlave,該配置提供LB,failover/failbackup功能.
             
            <dbServer name="virtualSlave" virtual="true"> 
                <poolConfig> 
                    <className>com.meidusa.amoeba.server.MultipleServerPool</className> 
                    <!-- 負載均衡參數 1=ROUNDROBIN , 2=WEIGHTBASED --> 
                    <property name="loadbalance">1</property> 
                              
                    <!-- 參與該pool負載均衡的poolName列表以逗號分割 --> 
                    <property name="poolNames">serverA,serverB,serverC</property> 
                </poolConfig> 
            </dbServer> 


            <dbServer name="virtualSlave" virtual="true">
             <poolConfig>
              <className>com.meidusa.amoeba.server.MultipleServerPool</className>
              <!-- 負載均衡參數 1=ROUNDROBIN , 2=WEIGHTBASED -->
              <property name="loadbalance">1</property>
                
              <!-- 參與該pool負載均衡的poolName列表以逗號分割 -->
              <property name="poolNames">serverA,serverB,serverC</property>
             </poolConfig>
            </dbServer>

             

            如果不啟用數據切分功能,那么只需要配置QueryRouter屬性
            wirtePool=serverM
            readPool=virtualSlave

            <queryRouter> 
                <className>com.meidusa.amoeba.mysql.parser.MysqlQueryRouter</className> 
                <property name="LRUMapSize">1500</property> 
                <property name="defaultPool">serverM</property> 
             
                <property name="writePool">serverM</property> 
                <property name="readPool">virtualSlave</property> 
             
                <property name="needParse">true</property> 
            </queryRouter> 

             <queryRouter>
              <className>com.meidusa.amoeba.mysql.parser.MysqlQueryRouter</className>
              <property name="LRUMapSize">1500</property>
              <property name="defaultPool">serverM</property>

              <property name="writePool">serverM</property>
              <property name="readPool">virtualSlave</property>

              <property name="needParse">true</property>
             </queryRouter>


            client發送過來的update/insert/delete語句被發送到wirtePool,將select語句發送到readPool機器執行。

             

            二、數據切分方面:
            這方面amoeba顯然也很容易,舉個數據切分例子:

            select * from user_event where user_id='test' and  gmt_create between Sysdate() -1 and Sysdate()

            如果根據gmt_create 時間進行數據切分,比如6個月進行切分一次,amoeba提供利用類似sql表達式進行數據切分:

            規則1:GMT_CREATE > to_date('2008-01-01','yyyy-mm-dd') and GMT_CREATE < to_date('2008-05-31','yyyy-mm-dd')

            規則1對應服務器1

            規則2:GMT_CREATE > to_date('2008-06-01','yyyy-mm-dd') and GMT_CREATE < to_date('2008-12-31','yyyy-mm-dd')

            規則2對應服務器2
            上面的sql的條件 gmt_create 與規則里面的的gmt_create 進行交集判斷,如果存在交集則表示符合規則,則會將sql轉移到 規則1 的相應的服務器上面執行。

            利用amoeba寫出這種類似規則很容易,但是要想做到數據切分以后可線性擴容,那么這樣的規則需要自己根據業務實際情況進行設置。amoeba可同時將 sql并發分發到多臺服務器、然后將結果合并再反饋給客戶端,而且amoeba內部采用無阻塞模式,工作線程是不會等待的,并發請求多臺 database server情況下,客戶端等待的時間基本上面是性能最差的那臺database server+amoeba內部解析協議時間。


            中文文檔地址: http://amoeba.sourceforge.net/amoeba.pdf
            amoeba 未來發展方向: http://amoeba.sourceforge.net/amoeba-big-picture.pdf

            文件下載: http://www.sourceforge.net/projects/amoeba
            amoeba 開發者博客: http://amoeba.meidusa.com

            轉自:
            http://blog.sina.com.cn/s/blog_499740cb0100g45w.html
            posted on 2012-12-13 17:14 小果子 閱讀(507) 評論(0)  編輯 收藏 引用 所屬分類: SQL
            久久精品国产免费观看| 久久伊人精品一区二区三区| 成人国内精品久久久久一区| 久久99精品国产麻豆宅宅| 国产激情久久久久影院小草| 久久久久亚洲精品天堂久久久久久| 久久亚洲精品国产亚洲老地址| 国产一久久香蕉国产线看观看| 伊人久久大香线蕉精品不卡| 国产成人精品综合久久久| 久久久久久久人妻无码中文字幕爆 | 久久国产三级无码一区二区| 久久强奷乱码老熟女网站| 久久九九兔免费精品6| 99久久精品免费看国产一区二区三区| 国产精品伊人久久伊人电影 | 欧美亚洲国产精品久久久久| 日日躁夜夜躁狠狠久久AV| 久久久精品视频免费观看| AV无码久久久久不卡蜜桃| 亚洲国产成人精品久久久国产成人一区二区三区综 | 精品久久久久久国产91| 理论片午午伦夜理片久久 | 精品一区二区久久| 亚洲欧美伊人久久综合一区二区| 66精品综合久久久久久久| 久久精品国产清自在天天线| 亚洲精品97久久中文字幕无码| 精品亚洲综合久久中文字幕| 成人午夜精品无码区久久| 久久精品一区二区国产| 久久精品国产亚洲AV麻豆网站| 久久久久av无码免费网| 午夜精品久久久久成人| 亚洲国产综合久久天堂| 久久久久久久久久久免费精品| 久久综合亚洲色HEZYO国产| 婷婷久久香蕉五月综合加勒比| 久久亚洲精品无码观看不卡| 996久久国产精品线观看| 7777久久亚洲中文字幕|