Amoeba for mysql讀寫分離
Amoeba for mysql讀寫分離
8066 192.168.1.110 20 30 30 128 true root password 60 com.meidusa.amoeba.net.AuthingableConnectionManager 5 defaultManager 3306 192.168.1.121 test zhang zhang123 200 200 10 600000 600000 true true
defaultManager 3306 192.168.1.108 test zhang zhang123 200 200 10 600000 600000 true true
1 server1
1 server1,server2 ${amoeba.home}/conf/rule.xml ${amoeba.home}/conf/functionMap.xml ${amoeba.home}/conf/ruleFunctionMap.xml 1500 master master slave true
server1,server2,server2,server2
安裝JDK環境
下載jdk1.5或者更新版本,地址
我用的是:jdk-6u20-linux-i586-rpm.bin
在Amoeba server上執行
chmod +x jdk-6u20-linux-i586-rpm.bin
./ jdk-6u20-linux-i586-rpm.bin
##然後按n次空格鍵,然後輸入yes就可以了!
ln -s /usr/java/jdk1.6.0_20/ /usr/java/jdk1.6
vi /etc/profile
#新增如下兩行內容
export JAVA_HOME=/usr/java/jdk1.6
export PATH=$JAVA_HOME/bin:$JAVA_HOME/jre/bin:$PATH
#執行下面的命令使更改的內容生效
source /etc/profile
安裝amoeba-mysql
下載amoeba-mysql,目前最新版本為amoeba-mysql-1.3.1-BETA.zip
mkdir /usr/local/amoeba/
wget http://blogimg.chinaunix.net/blog/upfile2/101027160252.zip
unzip 101027160252.zip
配置檔案位於conf目錄下,執行檔案位於bin目錄下,解壓後發現bin目錄下的啟動檔案沒有可執行許可權,請執行:chmod -R +x /usr/local/amoeba/bin/
Amoeba For MySQL 的使用非常簡單,所有的配置檔案都是標準的XML 檔案,總共有四個配置檔案。分別為:
◆ amoeba.xml:主配置檔案,配置所有資料來源以及Amoeba 自身的引數設定;實現主從的話配置這個檔案就可以了;
◆ rule.xml:配置所有Query 路由規則的資訊;
◆ functionMap.xml:配置用於解析Query 中的函式所對應的Java 實現類;
◆ rullFunctionMap.xml:配置路由規則中需要使用到的特定函式的實現類;
下面我們就來透過更改amoeba.xml配置檔案實現mysql主從讀寫分離,我的配置如下:
<!-- proxy server繫結的埠 -->
<!-- proxy server繫結的IP -->
<!-- proxy server net IO Read thread size -->
<!-- proxy server client process thread size -->
<!-- mysql server data packet process thread size -->
<!-- socket Send and receive BufferSize(unit:K) -->
<!-- Enable/disable TCP_NODELAY (disable/enable Nagle's algorithm). -->
<!-- 對外驗證的使用者名稱 -->
<!-- 對外驗證的密碼 -->
<!-- query timeout( default: 60 second , TimeUnit:second) -->
<!--
每個ConnectionManager都將作為一個執行緒啟動。
manager負責Connection IO讀寫/死亡檢測
-->
<!--
default value is avaliable Processors
-->
<!--
一臺mysqlServer 需要配置一個pool,
如果多臺 平等的mysql需要進行loadBalance,
平臺已經提供一個具有負載均衡能力的objectPool:com.meidusa.amoeba.mysql.server.MultipleServerPool
簡單的配置是屬性加上 virtual="true",該Pool 不允許配置factoryConfig
或者自己寫一個ObjectPool。
-->
<!-- PoolableObjectFactory實現類 -->
<!-- 真實mysql資料庫埠 -->
<!-- 真實mysql資料庫IP -->
<!-- 用於登陸mysql的使用者名稱 -->
<!-- 用於登陸mysql的密碼 -->
<!-- ObjectPool實現類 -->
<!-- PoolableObjectFactory實現類 -->
<!-- 真實mysql資料庫埠 -->
<!-- 真實mysql資料庫IP -->
<!-- 用於登陸mysql的使用者名稱 -->
<!-- 用於登陸mysql的密碼 -->
<!-- ObjectPool實現類 -->
<!-- 負載均衡引數 1=ROUNDROBIN , 2=WEIGHTBASED , 3=HA-->
<!-- 參與該pool負載均衡的poolName列表以逗號分割 -->
<!-- 負載均衡引數 1=ROUNDROBIN , 2=WEIGHTBASED , 3=HA-->
<!-- 參與該pool負載均衡的poolName列表以逗號分割 -->
啟動amoeba
/usr/local/amoeba/bin/amoeba &
檢驗啟動是否成功(使用的是預設的8066埠):
[root@Centos2 amoeba]# ps aux | grep amoeba
root 24580 0.2 19.2 408912 49264 pts/1 Sl 12:52 0:11 /usr/java/jdk1.6/bin/java -server -Xms256m -Xmx256m -Xss128k -Damoeba.home=/usr/local/amoeba -Dclassworlds.conf=/usr/local/amoeba/bin/amoeba.classworlds -classpath /usr/local/amoeba/lib/classworlds-1.0.jar org.codehaus.classworlds.Launcher
[root@Centos2 amoeba]# netstat -lnp | grep java
tcp 0 0 ::ffff:192.168.1.159:8066 :::* LISTEN 24580/java
5、 測試
測試之前先要保證amoeba-server有訪問兩個主從伺服器test庫的許可權,在主從mysql上都執行:
grant all on test.* to zhang@'192.168.1.%' identified by 'zhang123';
#使用者名稱密碼要和前面配置的意志
flush privileges;
測試的時候和我們平時使用一樣,amoeba-mysql對我們應用透明,就是個mysql的代理了!
登入mysql使用如下命令(使用者名稱密碼和上面配置的要一致):
mysql -uroot -ppassword -h192.168.1.159 -P8066
登入上去後,為了測試讀和寫必須,先把mysql的主從複製停掉,才能更清楚地看出讀寫的伺服器是哪臺,在從上使用stop slave;登入到amoeba-mysql上,使用命令mysql -uroot -ppassword -h192.168.1.159 -P8066,然後執行寫和讀操作,檢視寫的是哪臺伺服器,讀的是哪臺伺服器,實驗結果顯示:寫只在主上進行,讀在主和從都進行,比率是1:1
測試步驟:
還沒有停掉從同步之前,建立一個表:
create table zhang (id int(10) ,name varchar(10),address varchar(20));
在從上執行stop slave;
然後在主從上各插入一條不同資料(供測試讀的時候用),
在主上插入:insert into zhang values('1','zhang','this_is_master');
在從上插入:insert into zhang values('2','zhang','this_is_slave');
接下來透過登入amoeba-mysql上來測試讀寫:
[root@Centos2 ~]# mysql -uroot -ppassword -h192.168.1.159 -P8066
Welcome to the MySQL monitor. Commands end with ; or \g.
Your MySQL connection id is 14556042
Server version: 5.1.45-mysql-amoeba-proxy-1.3.1-BETA Source distribution
Type 'help;' or '\h' for help. Type '\c' to clear the buffer.
mysql> use test;
Database changed
mysql> select * from zhang; ###第一次執行顯示在主上讀取的資料!
+------+-------+----------------+
| id | name | address |
+------+-------+----------------+
| 1 | zhang | this_is_master |
+------+-------+----------------+
1 row in set (0.02 sec)
mysql> select * from zhang; ####第二次執行select語句顯示是在從上讀取的資料
+------+-------+---------------+
| id | name | address |
+------+-------+---------------+
| 2 | zhang | this_is_slave |
+------+-------+---------------+
1 row in set (0.02 sec)
mysql> insert into zhang values('3','hhh','test_write'); ###插入一條資料,然後查詢
Query OK, 1 row affected (0.01 sec)
mysql> select * from zhang; ###我們可以看到插入的資料被新增到了主上!
+------+-------+----------------+ ####可以多插入幾次資料看看是否會出現錯誤!
| id | name | address |
+------+-------+----------------+
| 1 | zhang | this_is_master |
| 3 | hhh | test_write |
+------+-------+----------------+
mysql> select * from zhang; ###從上還是沒有插入,因為執行了stop slave;
+------+-------+---------------+
| id | name | address |
+------+-------+---------------+
| 2 | zhang | this_is_slave |
+------+-------+---------------+
6、 簡單主從權重配置
大家可能會想到,我們加入只有兩臺資料庫伺服器,一臺主,一臺從,按照上面的配置只能是主和從的讀取比率是1:1,而寫又全部在主上進行,這樣主的壓力就很大了,所以如果能讓主和從的讀設定權重,比如設定成1:3,這樣就可以很好的解決主從不壓力均衡的問題!透過研究確實可以!
配置就是將上面的讀的池的配置更改一下:
將server1,server2 更改成
我測試的結果剛好為1:3,如下:
mysql> select * from zhang;
+------+-------+----------------+
| id | name | address |
+------+-------+----------------+
| 1 | zhang | this_is_master |
| 3 | hhh | test_write |
+------+-------+----------------+
2 rows in set (0.01 sec)
mysql> select * from zhang;
+------+-------+---------------+
| id | name | address |
+------+-------+---------------+
| 2 | zhang | this_is_slave |
+------+-------+---------------+
1 row in set (0.04 sec)
mysql> select * from zhang;
+------+-------+---------------+
| id | name | address |
+------+-------+---------------+
| 2 | zhang | this_is_slave |
+------+-------+---------------+
1 row in set (0.01 sec)
mysql> select * from zhang;
+------+-------+---------------+
| id | name | address |
+------+-------+---------------+
| 2 | zhang | this_is_slave |
+------+-------+---------------+
學習連結:
開發者部落格連結:
amoeba 中文文件下載地址:amoeba.pdf
amoeba 未來發展方向:amoeba-big-picture.pdf
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/90618/viewspace-774222/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- mysql優化之讀寫分離MySql優化
- 探究MySQL MGR的讀寫分離MySql
- MySQL 讀寫分離的好處MySql
- ProxySQL實現MySQL讀寫分離MySql
- MYSQL 主從 + ATLAS 讀寫分離 搭建MySql
- MySQL cetus 中介軟體 讀寫分離MySql
- 配置\清除 MySQL 主從 讀寫分離MySql
- MySQL 官宣:支援讀寫分離了!!MySql
- mysql讀寫分離的最佳實踐MySql
- Mysql之讀寫分離架構-AtlasMySql架構
- MySQL主從複製讀寫分離MySql
- Mysql 高可用(MHA)-讀寫分離(Atlas)MySql
- MySQL 中讀寫分離資料延遲MySql
- docker+atlas+mysql實現讀寫分離DockerMySql
- [Mysql]主從複製和讀寫分離MySql
- Kubernetes 中實現 MySQL 的讀寫分離MySql
- ProxySQL實現Mysql讀寫分離 - 部署手冊MySql
- Mysql-主從複製與讀寫分離MySql
- 搭建MySQL主從實現Django讀寫分離MySqlDjango
- ShardingSphere + Mysql,實現分庫分表、讀寫分離,並整合 SpringBootMySqlSpring Boot
- MySQL從庫卡主了--讀寫分離也不能亂讀MySql
- Redis的讀寫分離Redis
- KunlunBase 讀寫分離方案
- Laravel讀寫分離原理Laravel
- discuz 配置讀寫分離(主寫從讀)
- 提高效能,MySQL 讀寫分離環境搭建MySql
- Mycat實現mysql的負載均衡讀寫分離MySql負載
- MyCat分庫分表、讀寫分離
- 使用ShardingSphere-JDBC完成Mysql的分庫分表和讀寫分離JDBCMySql
- 線上MySQL讀寫分離,出現寫完讀不到問題如何解決MySql
- 資料讀寫壓力大,讀寫分離
- ShardingSphere(七) 讀寫分離配置,實現分庫讀寫操作
- MySQL-SpringBoot整合JPA實現資料讀寫分離MySqlSpring Boot
- MySQL運維15-一主一從讀寫分離MySql運維
- MySQL運維16-雙主雙從讀寫分離MySql運維
- Mycat中介軟體實現Mysql主從讀寫分離MySql
- MySQL中介軟體之ProxySQL(3):初試讀寫分離MySql
- 提高效能,MySQL 讀寫分離環境搭建(二)MySql
- 資料庫讀寫分離資料庫