一、 安裝和執行Amoeba
1. Amoeba for MySQL 架構:
2. 驗證Java的安裝
Amoeba框架是基於Java SE1.5開發的,建議使用Java SE1.5以上的版本。
# java -version
java version "1.6.0_35"
Java(TM) SE Runtime Environment (build 1.6.0_35-b10)
Java HotSpot(TM) 64-Bit Server VM (build 20.10-b01, mixed mode)
注:JDK的安裝方法不再闡述,不會的可以參考:http://www.minunix.com/2013/05/install_tomcat/ 安裝JDK部分。
3. 安裝MySQL資料庫及配置主從複製部分此處不再闡述,不會者可參考:http://www.minunix.com/2013/05/mysql-slave/。
4. 下載Amoeba
本例使用版本:amoeba-mysql-3.0.5-RC-distribution.zip
下載地址:http://pan.baidu.com/s/1fkno
5. 安裝Amoeba
把下載的壓縮包解壓完了之後放到 /usr/local/ 目錄下即可。
# mkdir /usr/local/amoeba
# unzip amoeba-mysql-3.0.5-RC-distribution.zip
# /bin/cp –rf amoeba-mysql-3.0.5-RC/* /usr/local/amoeba
二、 配置Amoeba for MySQL:
Amoeba for MySQL的使用是很簡單的,主要是通過xml檔案來實現的。
1. 配置檔案介紹:
(1.) dbServers.xml 想象Amoeba作為資料庫代理層,它一定會和很多資料庫保持通訊,因此它必須知道由它代理的資料庫如何連線,比如最基礎的:主機IP、埠、Amoeba使用的使用者名稱和密碼等等。這些資訊儲存在$AMOEBA_HOME/conf/dbServers.xml中。
(2.) rule.xml Amoeba為了完成資料切分提供了完善的切分規則配置,為了瞭解如何分片資料、如何將資料庫返回的資料整合,它必須知道切分規則。與切分規則相關的資訊儲存在$AMOEBA_HOME/conf/rule.xml中。
(3.) functionMap.xml 當我們書寫SQL來運算元據庫的時候,常常會用到很多不同的資料庫函式,比如:UNIX_TIMESTAMP()、SYSDATE()等等。這些函式如何被Amoeba解析呢?$AMOEBA_HOME/conf/functionMap.xml描述了函式名和函式處理的關係。
(4.) ruleFunctionMap.xml 對$AMOEBA_HOME/conf/rule.xml進行配置時,會用到一些我們自己定義的函式,比如我們需要對使用者ID求HASH值來切分資料,這些函式在$AMOEBA_HOME/conf/ruleFunctionMap.xml中定義。
(5.) access_list.conf Amoeba可以制定一些可訪問以及拒絕訪問的主機IP地址,這部分配置在$AMOEBA_HOME/conf/access_list.conf中。
(6.) log4j.xml Amoeba允許使用者配置輸出日誌級別以及方式,配置方法使用log4j的檔案格式,檔案是$AMOEBA_HOME/conf/log4j.xml。
其中,我們主要用到dbServer.xml 和 amoeba.xml 。
2. dbServer.xml 的配置:
<dbServer name=”abstractServer” abstractive=”true”>
<factoryConfig class=”com.meidusa.amoeba.mysql.net.MysqlServerConnectionFactory”>
<property name=”connectionManager”>${defaultManager}</property>
<property name=”sendBufferSize”>64</property>
<property name=”receiveBufferSize”>128</property>
<!—mysql port --><!—代理連線資料庫使用的埠號-->
<property name=”port”>3306</property>
<!—mysql schema --><!—代理連線資料庫所使用的資料庫-->
<property name=”schema”>test</property>
<!—mysql user --><!—代理連線資料庫使用的使用者名稱-->
<property name=”user”>minunix</property>
<!—代理連線資料庫使用的密碼-->
<property name=”password”>minunix.com</property>
</factoryConfig>
<poolConfig class=”com.meidusa.toolkit.common.poolable.PoolableObjectPool”>
<property name=”maxActive”>500</property>
<property name=”maxIdle”>500</property>
<property name=”minIdle”>1</property>
<property name=”minEvictableIdleTimeMillis”>600000</property>
<property name=”timeBetweenEvictionRunsMillis”>600000</property>
<property name=”testOnBorrow”>true</property>
<property name=”testOnReturn”>true</property>
<property name=”testWhileIdle”>true</property>
</poolConfig>
</dbServer>
<!--- 配置真實的資料庫的地址-->
<!--- 配置主從伺服器及伺服器連線池-->
<dbServer name="server1" parent="abstractServer">
<factoryConfig>
<!-- mysql ip -->
<property name="ipAddress">192.168.0.162</property>
</factoryConfig>
</dbServer>
<dbServer name=”server2” parent=”abstractServer”>
<factoryConfig>
<!—mysql ip -->
<property name=”ipAddress”>192.168.0.171</property>
</factoryConfig>
</dbServer>
<dbServer name=”multiPool” virtual=”true”>
<poolConfig class=”com.meidusa.amoeba.server.MultipleServerPool”>
<!—Load balancing strategy: 1=ROUNDROBIN , 2=WEIGHTBASED , 3=HA-->
<property name=”loadbalance”>1</property>
<!—Separated by commas,such as: server1,server2,server1 -->
<property name=”poolNames”>server1,server2</property>
</poolConfig>
</dbServer>
3. amoeba.xml 配置:
客戶端連線Amoeba時所繫結的IP地址、埠、使用者名稱和密碼。及IP訪問限制。
<service name="Amoeba for Mysql" >
<!-- port -->
<property name="port">8066</property>
<!-- bind ipAddress -->
<!--
<property name="ipAddress">127.0.0.1</property>
-->
<property name="connectionFactory">
<bean >
<property name="sendBufferSize">128</property>
<property name="receiveBufferSize">64</property>
</bean>
</property>
<property name="authenticateProvider">
<bean >
<property name="user">root</property>
<property name="password">minunix</property>
<property name="filter">
<bean>
<property name="ipFile">${amoeba.home}/conf/access_list.conf</property>
</bean>
</property>
</bean>
</property>
</service>
以下內容是定義讀寫分離:
<queryRouter >
<property name="ruleLoader">
<bean >
<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">multiPool</property>
<property name="writePool">server1</property>
<property name="readPool">server2</property>
<property name="needParse">true</property>
</queryRouter>
通過以上簡單配置,已經可以實現資料庫的讀寫分離了。
三、 測試
# cd /usr/local/bin/
# ./launcher \\ (也可通過nohup後臺啟動,或者自己寫一個指令碼來啟動。 )
啟動的Amoeba預設埠為8066
在客戶端連線Amoeba測試:
# mysql -uroot –pminunix -h192.168.0.161 --port 8066
mysql> show databases;
mysql> CREATE DATABASE minunix; \\ 建立資料庫,之後在主從庫分別檢視
通過Amoeba登入,進行資料的查詢及插入更新等操作,並檢視mysql-log日誌,可發現所執行的INSERT 、UPDATE、DELETE等操作在主庫server1上操作,SELECT查詢語句在從庫server2上執行。
Amoeba for MySQL讀寫分離配置
相關文章
- 配置\清除 MySQL 主從 讀寫分離MySql
- discuz 配置讀寫分離(主寫從讀)
- ShardingSphere(七) 讀寫分離配置,實現分庫讀寫操作
- mysql優化之讀寫分離MySql優化
- 探究MySQL MGR的讀寫分離MySql
- MySQL 讀寫分離的好處MySql
- ProxySQL實現MySQL讀寫分離MySql
- MYSQL 主從 + ATLAS 讀寫分離 搭建MySql
- MySQL cetus 中介軟體 讀寫分離MySql
- MySQL 官宣:支援讀寫分離了!!MySql
- mysql讀寫分離的最佳實踐MySql
- Mysql之讀寫分離架構-AtlasMySql架構
- MySQL主從複製讀寫分離MySql
- Mysql 高可用(MHA)-讀寫分離(Atlas)MySql
- Mycat2+Mysql一主一從實現讀寫分離配置MySql
- DM8配置讀寫分離叢集
- MySQL 中讀寫分離資料延遲MySql
- docker+atlas+mysql實現讀寫分離DockerMySql
- [Mysql]主從複製和讀寫分離MySql
- Kubernetes 中實現 MySQL 的讀寫分離MySql
- 搭建基於springmvc,ibatis的工程實現讀寫分離,配置分離SpringMVCBAT
- ProxySQL實現Mysql讀寫分離 - 部署手冊MySql
- Mysql-主從複製與讀寫分離MySql
- 搭建MySQL主從實現Django讀寫分離MySqlDjango
- ShardingSphere + Mysql,實現分庫分表、讀寫分離,並整合 SpringBootMySqlSpring Boot
- MySQL從庫卡主了--讀寫分離也不能亂讀MySql
- shardingjdbc + jpa 完成讀寫分離配置及資料分片JDBC
- Redis的讀寫分離Redis
- KunlunBase 讀寫分離方案
- Laravel讀寫分離原理Laravel
- 提高效能,MySQL 讀寫分離環境搭建MySql
- Mycat實現mysql的負載均衡讀寫分離MySql負載
- MyCat分庫分表、讀寫分離
- 使用ShardingSphere-JDBC完成Mysql的分庫分表和讀寫分離JDBCMySql
- 線上MySQL讀寫分離,出現寫完讀不到問題如何解決MySql
- 資料讀寫壓力大,讀寫分離
- DM8配置讀寫分離叢集V4.0
- MySQL-SpringBoot整合JPA實現資料讀寫分離MySqlSpring Boot
- MySQL運維15-一主一從讀寫分離MySql運維