使用Amoeba 實現MySQL DB 讀寫分離


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.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


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM