Amoeba(變形蟲)項目是一個開源框架,於2008年開始發佈一款 Amoeba for Mysql軟件;html
這個軟件致力於MySQL的分佈式數據庫前端代理層,它主要在應用層訪問MySQL的時候充當SQL路由功能,專一於分佈式數據庫代理層(Database Proxy)開發;位於 Client、DB Server(s)之間,對客戶端透明;前端
===================================================================java
1 簡介mysql
2 準備linux
2.1 時間同步sql
2.2 配置MySQL主從複製架構數據庫
3 ameoba安裝配置後端
3.1 安裝配置JDKbash
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.bin vi /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/amoeba tar xf amoeba-mysql-binary-2.2.0.tar.gz -C /usr/local/amoeba # 使用二進制程序文件安裝amoeba cd /usr/local/amoeba bin/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/conf vi 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)
# 登陸驗證 [root@mysql conf]# mysql -h127.0.0.1 -uroot -p -P3306 Enter password: Welcome to the MariaDB monitor. Commands end with ; or \g. Your MySQL connection id is 2097086015 Server version: 5.1.45-mysql-amoeba-proxy-2.2.0 Source distribution Copyright (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)]> # 讀寫驗證 [root@mysql conf]# mysql -h127.0.0.1 -uroot -p -P3306 Enter password: Welcome to the MariaDB monitor. Commands end with ; or \g. Your MySQL connection id is 2097086015 Server version: 5.1.45-mysql-amoeba-proxy-2.2.0 Source distribution Copyright (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)]> [root@mysql bin]# mysql -h127.0.0.1 -uroot -p -P3406 Enter password: Welcome to the MariaDB monitor. Commands end with ; or \g. Your MariaDB connection id is 33 Server version: 10.0.10-MariaDB-log Source distribution Copyright (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