Amoeba是一個類似MySQL Proxy的分散式資料庫中間代理層軟體,是由陳思儒開發的一個開源的java項目

來源:互聯網
上載者:User

標籤:blog   http   io   os   使用   ar   java   for   strong   

Amoeba(變形蟲)項目是一個開源架構,於2008年開始發布一款 Amoeba for Mysql軟體;

這個軟體致力於MySQL的分散式資料庫前端代理層,它主要在應用程式層訪問MySQL的時候充當SQL路由功能,專註於分散式資料庫代理層(Database Proxy)開發;位於 Client、DB Server(s)之間,對用戶端透明;

===================================================================

1 簡介

2 準備

   2.1 時間同步

   2.2 配置MySQL主從複製架構

3 ameoba安裝配置

   3.1 安裝配置JDK

   3.2 安裝ameoba

   3.3 配置ameoba

   3.4 使用驗證

   3.5 後期擴充

4 問題記錄

===================================================================

 

1 簡介

Amoeba(變形蟲)項目是一個開源架構,於2008年開始發布一款 Amoeba for Mysql軟體;

這個軟體致力於MySQL的分散式資料庫前端代理層,它主要在應用程式層訪問MySQL的時候充當SQL路由功能,專註於分散式資料庫代理層(Database Proxy)開發;位於 Client、DB Server(s)之間,對用戶端透明;

具有負載平衡、高可用性、SQL 過濾、讀寫分離、可路由相關的請求到目標資料庫、可並發請求多台資料庫併合並結果;

通過Amoeba你能夠完成多資料來源的高可用、負載平衡、資料切片的功能,目前Amoeba已在很多企業的生產線上面使用;

 

2 準備

2.1 時間同步

# crontab -e# Dscrip: Time Sync# CTime: 2014.03.23*/5 * * * * /usr/sbin/ntpdate 172.16.0.1 &>/dev/null

2.2 配置MySQL主從複製架構

詳見博文"MariaDB 主從複製"

 

3 ameoba安裝配置

3.1 安裝配置JDK

chmod +x jdk-6u31-linux-x64-rpm.binvi /etc/profile.d/java.sh # 採用bin檔案安裝jdk    export JAVA_HOME=/usr/java/latest    export PATH=$JAVA_HOME/bin:$PATH

3.2 安裝ameoba

mkdir /usr/local/amoebatar xf amoeba-mysql-binary-2.2.0.tar.gz -C /usr/local/amoeba # 使用二進位程式檔案安裝amoebacd /usr/local/amoebabin/amoeba start # 前台運行nohup /usr/local/amoeba/bin/amoeba start & # 後台運行mysql -h127.0.0.1 -uroot -p -P8066 # amoeba預設監聽連接埠為8066

3.3 配置ameoba

cd /usr/local/amoeba/confvi ameoba.xml # 前端定義設定檔# 修改ameoba前端監聽連接埠<service name="Amoeba for Mysql" class="com.meidusa.amoeba.net.ServerableConnectionManager">    <property name="port">3306</property> # 預設連接埠是8066,修改為3306,便於實現前端程式串連資料庫的透明性# 修改串連amoeba介面的認證資訊<property name="authenticator">    <bean class="com.meidusa.amoeba.mysql.server.MysqlClientAuthenticator">           <property name="user">root</property>           <property name="password">mypass</property> # 添加登入密碼# 查詢路由設定<queryRouter class="com.meidusa.amoeba.mysql.parser.MysqlQueryRouter">    <property name="ruleLoader">               <bean class="com.meidusa.amoeba.route.TableRuleFileLoader">            <property name="ruleFile">${amoeba.home}/conf/rule.xml</property>            <property name="functionFile">${amoeba.home}/conf/ruleFunctionMap.xml</property>        </bean>    </property>    <property name="sqlFunctionFile">${amoeba.home}/conf/functionMap.xml</property>    <property name="LRUMapSize">1500</property>    <property name="defaultPool">master</property> # 設定預設節點    <property name="writePool">master</property>    # 設定可寫入區段點,節點定義見dbServers.xml檔案    <property name="readPool">readservers</property> # 設定唯讀池,可配置多個slave節點    <property name="needParse">true</property></queryRouter>vi dbServers.xml # 後端節點設定檔# 定義抽象伺服器,為每個後端MySQL伺服器提供預設串連配置<dbServer name="abstractServer" abstractive="true">    <factoryConfig class="com.meidusa.amoeba.mysql.net.MysqlServerConnectionFactory">        <property name="manager">${defaultManager}</property>        <property name="sendBufferSize">64</property>        <property name="receiveBufferSize">128</property>        <property name="port">3406</property>        <property name="schema">test</property>        <property name="user">root</property>        <property name="password">magedu</property>    </factoryConfig># 定義後端MySQL的IP地址,一個master,一個slave<dbServer name="master"  parent="abstractServer">    <factoryConfig>        <property name="ipAddress">192.168.0.45</property>    </factoryConfig></dbServer><dbServer name="slave"  parent="abstractServer">    <factoryConfig>        <property name="ipAddress">192.168.0.46</property>    </factoryConfig></dbServer># 定義虛擬伺服器組,即唯讀池readservers<dbServer name="readservers" virtual="true">    <poolConfig class="com.meidusa.amoeba.server.MultipleServerPool">        <property name="loadbalance">1</property>        <property name="poolNames">master,slave</property>    </poolConfig></dbServer>
 

3.4 使用驗證

在主庫上授權:

MariaDB [(none)]> grant all on *.* to‘root‘@‘172.16.%.%‘ identified by ‘magedu‘;Query OK, 0 rows affected (0.00 sec)MariaDB [(none)]> grant all on *.* to‘root‘@‘%mysql.com‘ identified by ‘magedu‘; # 這裡的密碼應該與dbServer.xml中的資料庫密碼一致Query OK, 0 rows affected (0.00 sec)MariaDB [(none)]> flush privileges;Query OK, 0 rows affected (0.00 sec)
# 登入驗證[[email protected]l conf]# mysql -h127.0.0.1 -uroot -p -P3306Enter password:Welcome to the MariaDB monitor.  Commands end with ; or \g.Your MySQL connection id is 2097086015Server version: 5.1.45-mysql-amoeba-proxy-2.2.0 Source distributionCopyright (c) 2000, 2014, Oracle, SkySQL Ab and others.Type ‘help;‘ or ‘\h‘ for help. Type ‘\c‘ to clear the current input statement.MySQL [(none)]> show master status;+------------------+----------+--------------+------------------+| File             | Position | Binlog_Do_DB | Binlog_Ignore_DB |+------------------+----------+--------------+------------------+| mysql-bin.000030 |      326 |              |                  |+------------------+----------+--------------+------------------+1 row in set (0.00 sec)MySQL [(none)]># 讀寫驗證[[email protected] conf]# mysql -h127.0.0.1 -uroot -p -P3306Enter password:Welcome to the MariaDB monitor.  Commands end with ; or \g.Your MySQL connection id is 2097086015Server version: 5.1.45-mysql-amoeba-proxy-2.2.0 Source distributionCopyright (c) 2000, 2014, Oracle, SkySQL Ab and others.Type ‘help;‘ or ‘\h‘ for help. Type ‘\c‘ to clear the current input statement.MySQL [(none)]> create database amoeba_test;Query OK, 1 row affected (0.04 sec)MySQL [(none)]>[[email protected] bin]# mysql -h127.0.0.1 -uroot -p -P3406Enter password:Welcome to the MariaDB monitor.  Commands end with ; or \g.Your MariaDB connection id is 33Server version: 10.0.10-MariaDB-log Source distributionCopyright (c) 2000, 2014, Oracle, SkySQL Ab and others.Type ‘help;‘ or ‘\h‘ for help. Type ‘\c‘ to clear the current input statement.MariaDB [(none)]> show databases;+--------------------+| Database           |+--------------------+| amoeba_test        || information_schema || mysql              || performance_schema || test               |+--------------------+9 rows in set (0.01 sec)MariaDB [(none)]># 從amoeba介面登入建立資料庫amoeba_test後,再從主庫的介面中去查詢資料庫已建立,說明寫入確實是落在了主庫節點上;# 若要驗證ameoba對於讀操作的調度,則需要暫時停止從庫的複製操作,然後在主庫上更新資料,這樣從ameoba讀取資料將出現不一致的情況;
 

3.5 後期擴充

利用MMM雙主複製架構+Amoeba代理,可以實現對MySQL的高可用性和高效能;

關於MMM的內容參加博文"MySQL Scale Out"

4 問題記錄

現象:使用mysql -uroot -p -P8066命令始終無法串連進入ameoba的配置介面,一直都是進入mysql資料庫的配置介面

原因:在測試環境下,ameoba和mysql的主庫都部署在同一台主機上,當啟動ameoba服務後,即使指定-P8066串連,mysql用戶端還是預設採用可被識別的socket檔案(/tmp/mysql.sock)串連,同樣指定-hlocalhost也是一樣的;

當使用mysql命令串連mysqld時:

  • 串連主機為localhost或不指定時,mysql會採用Unix Socket的串連方式;

  • 串連主機為127.0.0.1時,mysql會採用TCP的方式串連;

解決方案:指定-h127.0.0.1串連即可,即mysql -h127.0.0.1 -uroot -p -P8066

Amoeba是一個類似MySQL Proxy的分散式資料庫中間代理層軟體,是由陳思儒開發的一個開源的java項目

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.