centos7 AMOEBA读写分离配置
生活随笔
收集整理的這篇文章主要介紹了
centos7 AMOEBA读写分离配置
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
Amoeba框架是居于JDK1.5開發的,采用了JDK1.5的特性,所以還需要安裝java環境,建議使用javaSE1.5以上的JDK版本
1、安裝java環境
先去官網下載:http://www.oracle.com/technetwork/java/javase/downloads/jdk8-downloads-2133151.html安裝:
命令: [root@bogon src]# rpm -ivh jdk-8u111-linux-x64.rpm設置java環境變量
命令: [root@bogon src]# vim /etc/profile在最后添加: JAVA_HOME=/usr/java/jdk1.8.0_111 JRE_HOME=/usr/java/jdk1.8.0_111/jre CLASS_PATH=.:$JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar:$JRE_HOME/lib PATH=$PATH:$JAVA_HOME/bin:$JRE_HOME/bin export JAVA_HOME JRE_HOME CLASS_PATH PATH環境變量生效: [root@bogon amoeba]# source /etc/profile環境是否成功: [root@bogon src]# java -version java version "1.8.0_111" Java(TM) SE Runtime Environment (build 1.8.0_111-b14) Java HotSpot(TM) 64-Bit Server VM (build 25.111-b14, mixed mode)2、安裝Amoeba
可以從https://sourceforge.net/projects/amoeba/下載最新版本的Amoeba,我這里下載的是amoeba-mysql-3.0.5-RC-distribution.zip。Amoeba安裝非常簡單,直接解壓即可使用,這里將Amoeba解壓到/usr/local/amoeba目錄下,這樣就安裝完成了
執行命令:[root@bogon amoeba]# pwd /usr/local/amoeba查看目錄:[root@bogon amoeba]# ll總用量 20drwxrwxrwx. 2 root root 4096 7月 5 2013 benchmarkdrwxrwxrwx. 2 root root 4096 7月 5 2013 bindrwxrwxrwx. 2 root root 4096 7月 5 2013 conf-rwxrwxrwx. 1 root root 728 7月 5 2013 jvm.propertiesdrwxrwxrwx. 2 root root 4096 7月 5 2013 lib3、配置Amoeba
Amoeba的配置文件在本環境下位于/usr/local/amoeba/conf目錄下。配置文件比較多,但是僅僅使用讀寫分離功能,只需配置兩個文件即可,分別是dbServers.xml和amoeba.xml,如果需要配置ip訪問控制,還需要修改access_list.conf文件,下面首先介紹dbServers.xml
執行命令: [root@bogon amoeba]# cat conf/dbServers.xml 復制進去: <?xml version="1.0" encoding="utf-8"?><!DOCTYPE amoeba:dbServers SYSTEM "dbserver.dtd"> <amoeba:dbServers xmlns:amoeba="http://amoeba.meidusa.com/"><!-- Each dbServer needs to be configured into a Pool,If you need to configure multiple dbServer with load balancing that can be simplified by the following configuration:add attribute with name virtual = "true" in dbServer, but the configuration does not allow the element with name factoryConfigsuch as 'multiPool' dbServer --><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> #設置Amoeba要連接的mysql數據庫的端口,默認是3306<!-- mysql schema --><property name="schema">testdb</property> #設置缺省的數據庫,當連接amoeba時,操作表必須顯式的指定數據庫名,即采用dbname.tablename的方式,不支持 use dbname指定缺省庫,因為操作會調度到各個后端dbserver<!-- mysql user --><property name="user">test1</property> #設置amoeba連接后端數據庫服務器的賬號和密碼,因此需要在所有后端數據庫上創建該用戶,并授權amoeba服務器可連接<property name="password">111111</property></factoryConfig><poolConfig class="com.meidusa.toolkit.common.poolable.PoolableObjectPool"><property name="maxActive">500</property> #最大連接數,默認500<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="writedb" parent="abstractServer"> #設置一個后端可寫的dbServer,這里定義為writedb,這個名字可以任意命名,后面還會用到<factoryConfig><!-- mysql ip --><property name="ipAddress">192.168.2.204</property> #設置后端可寫dbserver</factoryConfig></dbServer><dbServer name="slave" parent="abstractServer"> #設置后端可讀dbserver<factoryConfig><!-- mysql ip --><property name="ipAddress">192.168.2.205</property></factoryConfig></dbServer><dbServer name="myslave" virtual="true"> #設置定義一個虛擬的dbserver,實際上相當于一個dbserver組,這里將可讀的數據庫ip統一放到一個組中,將這個組的名字命名為myslave<poolConfig class="com.meidusa.amoeba.server.MultipleServerPool"><!-- Load balancing strategy: 1=ROUNDROBIN , 2=WEIGHTBASED , 3=HA--><property name="loadbalance">1</property> #選擇調度算法,1表示復制均衡,2表示權重,3表示HA, 這里選擇1<!-- Separated by commas,such as: server1,server2,server1 --><property name="poolNames">slave</property> #myslave組成員</poolConfig></dbServer></amoeba:dbServers>另一個配置文件amoeba.xml
執行命令: [root@bogon amoeba]# cat conf/amoeba.xml 復制配置: <?xml version="1.0" encoding="utf8"?><!DOCTYPE amoeba:configuration SYSTEM "amoeba.dtd"> <amoeba:configuration xmlns:amoeba="http://amoeba.meidusa.com/"><proxy><!-- service class must implements com.meidusa.amoeba.service.Service --><service name="Amoeba for Mysql" class="com.meidusa.amoeba.mysql.server.MySQLService"><!-- port --><property name="port">8066</property> #設置amoeba監聽的端口,默認是8066<!-- bind ipAddress --> #下面配置監聽的接口,如果不設置,默認監聽所以的IP<!-- <property name="ipAddress">127.0.0.1</property>--><property name="connectionFactory"><bean class="com.meidusa.amoeba.mysql.net.MysqlClientConnectionFactory"><property name="sendBufferSize">128</property><property name="receiveBufferSize">64</property></bean></property><property name="authenticateProvider"><bean class="com.meidusa.amoeba.mysql.server.MysqlClientAuthenticator">#提供客戶端連接amoeba時需要使用這里設定的賬號 (這里的賬號密碼和amoeba連接后端數據庫服務器的密碼無關)<property name="user">root</property> <property name="password">123456</property><property name="filter"><bean class="com.meidusa.toolkit.net.authenticate.server.IPAccessController"><property name="ipFile">${amoeba.home}/conf/access_list.conf</property></bean></property></bean></property></service><runtime class="com.meidusa.amoeba.mysql.context.MysqlRuntimeContext"><!-- proxy server client process thread size --><property name="executeThreadSize">128</property><!-- per connection cache prepared statement size --><property name="statementCacheSize">500</property><!-- default charset --><property name="serverCharset">utf8</property><!-- query timeout( default: 60 second , TimeUnit:second) --><property name="queryTimeout">60</property></runtime></proxy><!-- Each ConnectionManager will start as threadmanager responsible for the Connection IO read , Death Detection--><connectionManagerList><connectionManager name="defaultManager" class="com.meidusa.toolkit.net.MultiConnectionManagerWrapper"><property name="subManagerClassName">com.meidusa.toolkit.net.AuthingableConnectionManager</property></connectionManager></connectionManagerList><!-- default using file loader --><dbServerLoader class="com.meidusa.amoeba.context.DBServerConfigFileLoader"><property name="configFile">${amoeba.home}/conf/dbServers.xml</property></dbServerLoader><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">writedb</property> #設置amoeba默認的池,這里設置為writedb<property name="writePool">writedb</property> #這兩個選項默認是注銷掉的,需要取消注釋,這里用來指定前面定義好的倆個讀寫池<property name="readPool">myslave</property> #<property name="needParse">true</property></queryRouter> </amoeba:configuration>4、在masterdb上創建數據庫testdb
在主庫創建表:testdb mysql> create database testdb;分別在masterdb和slavedb上為amoedb授權: mysql> GRANT ALL ON testdb.* TO 'test1'@'192.168.2.203' IDENTIFIED BY '111111'; Query OK, 0 rows affected (0.05 sec) mysql> privileges;啟動amoeba
命令: [root@bogon amoeba]# /usr/local/amoeba/bin/launcher異常: Error: JAVA_HOME environment variable is not set. [root@bogon amoeba]# vim /etc/profile^C [root@bogon amoeba]# source /etc/profile [root@bogon amoeba]# /usr/local/amoeba/bin/launcher Java HotSpot(TM) 64-Bit Server VM warning: ignoring option PermSize=16m; support was removed in 8.0 Java HotSpot(TM) 64-Bit Server VM warning: ignoring option MaxPermSize=96m; support was removed in 8.0The stack size specified is too small, Specify at least 228k Error: Could not create the Java Virtual Machine. Error: A fatal exception has occurred. Program will exit.#從錯誤文字上看,應該是由于stack size太小,導致JVM啟動失敗,要如何修改呢? #其實Amoeba已經考慮到這個問題,并將JVM參數配置寫在屬性文件里。現在,讓我們通過該屬性文件修改JVM參數。 #修改jvm.properties文件JVM_OPTIONS參數。命令: [root@bogon amoeba]# vim /usr/local/amoeba/jvm.properties 改成:JVM_OPTIONS="-server -Xms1024m -Xmx1024m -Xss256k -XX:PermSize=16m -XX:MaxPermSize=96m" 原為:JVM_OPTIONS="-server -Xms256m -Xmx1024m -Xss196k -XX:PermSize=16m -XX:MaxPermSize=96m"再次啟動: [root@bogon ~]# /usr/local/amoeba/bin/launcherat org.codehaus.plexus.classworlds.launcher.Launcher.launchStandard(Launcher.java:329)at org.codehaus.plexus.classworlds.launcher.Launcher.launch(Launcher.java:239)at org.codehaus.plexus.classworlds.launcher.Launcher.mainWithExitCode(Launcher.java:409)at org.codehaus.classworlds.Launcher.mainWithExitCode(Launcher.java:127)at org.codehaus.classworlds.Launcher.main(Launcher.java:110) Caused by: com.meidusa.toolkit.common.bean.util.InitialisationException: default pool required!,defaultPool=writedb invalidat com.meidusa.amoeba.route.AbstractQueryRouter.init(AbstractQueryRouter.java:469)at com.meidusa.amoeba.context.ProxyRuntimeContext.initAllInitialisableBeans(ProxyRuntimeContext.java:337)... 11 more2016-10-24 18:46:37 [INFO] Project Name=Amoeba-MySQL, PID=1577 , System shutdown .... Java HotSpot(TM) 64-Bit Server VM warning: ignoring option PermSize=16m; support was removed in 8.0 Java HotSpot(TM) 64-Bit Server VM warning: ignoring option MaxPermSize=96m; support was removed in 8.02016-10-24 18:50:19 [INFO] Project Name=Amoeba-MySQL, PID=1602 , starting... log4j:WARN log4j config load completed from file:/usr/local/amoeba/conf/log4j.xml 2016-10-24 18:50:21,668 INFO context.MysqlRuntimeContext - Amoeba for Mysql current versoin=5.1.45-mysql-amoeba-proxy-3.0.4-BETA log4j:WARN ip access config load completed from file:/usr/local/amoeba/conf/access_list.conf 2016-10-24 18:50:22,852 INFO net.ServerableConnectionManager - Server listening on 0.0.0.0/0.0.0.0:8066.查看端口: [root@bogon ~]# netstat -unlpt | grep java tcp 0 0 :::8066 :::* LISTEN 1602/java 由此可知Amoeba啟動正常5、測試
遠程登陸mysql客戶端通過指定amoeba配置文件中指定的用戶名、密碼、和端口以及amoeba服務器ip地址鏈接mysql數據庫
在testdb中創建表test并插入數據分別登陸masterdb和slavedb查看數據停掉masterdb,然后在客戶端分別執行插入和查詢功能可以看到,關掉masterdb和寫入報錯,讀正常開啟masterdb上的msyql 關閉slave上的mysql可以看到插入成功,讀取失敗開啟slavedb上的mysql,查看數據是否自動同步OK 一切正常,到此全部結束備注:
Amoeba主配置文件($AMOEBA_HOME/conf/amoeba.xml),用來配置Amoeba服務的基本參數,如Amoeba主機地址、端口、認證方式、用于連接的用戶名、密碼、線程數、超時時間、其他配置文件的位置等。數據庫服務器配置文件($AMOEBA_HOME/conf/dbServers.xml),用來存儲和配置Amoeba所代理的數據庫服務器的信息,如:主機IP、端口、用戶名、密碼等。切分規則配置文件($AMOEBA_HOME/conf/rule.xml),用來配置切分規則。數據庫函數配置文件($AMOEBA_HOME/conf/functionMap.xml),用來配置數據庫函數的處理方法,Amoeba將使用該配置文件中的方法解析數據庫函數。切分規則函數配置文件($AMOEBA_HOME/conf/ruleFunctionMap.xml),用來配置切分規則中使用的用戶自定義函數的處理方法。訪問規則配置文件($AMOEBA_HOME/conf/access_list.conf),用來授權或禁止某些服務器IP訪問Amoeba。日志規格配置文件($AMOEBA_HOME/conf/log4j.xml),用來配置Amoeba輸出日志的級別和方式。總結
以上是生活随笔為你收集整理的centos7 AMOEBA读写分离配置的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: maya中英文对比_maya2017中英
- 下一篇: 洛谷:P5520 [yLOI2019]