MyCat環(huán)境搭建詳細教程
一、準備工作
1、確保jdk已安裝成功,并且jdk版本選用1.7以上版本
2、準備一臺新的主機mysql_mycat放到master的前面做代理
mycat ip 192.168.232.13
3、將三臺機器互做本地解析
192.168.232.11 mysql_master 192.168.232.12 mysql_slave1 192.168.232.13 mysql_slave2 192.168.232.14 mysql_mycat
架構:
二、下載安裝mycat
我們通過本地上傳mycat包來安裝mycat
[root@mysql_mycat ~]# tar xf Mycat-server-1.6.5-release-linux.tar.gz -C /usr/local/
cd 到/usr/local目錄下,多了一個mycat文件夾
三、編輯配置文件
[root@mysql_mycat conf]# cd mycat/conf [root@mysql_mycat conf]# vim server.xml
1.server.xml
<user name="mycat" defaultAccount="true"> <property name="password">Qf@12345!</property> <property name="schemas">testdb</property> <!-- 表級 DML 權限設置 --> <!-- <privileges check="false"> <schema name="TESTDB" dml="0110" > <table name="tb01" dml="0000"></table> <table name="tb02" dml="1111"></table> </schema> </privileges> --> </user> <!--只讀用戶--> <user name="mycat_read"> <property name="password">Qf@12345!</property> <property name="schemas">TESTDB</property> <property name="readOnly">true</property> </user>
2.編輯schema.xml
[root@mysql_mycat conf]# vim schema.xml
<?xml version="1.0"?> <!DOCTYPE mycat:schema SYSTEM "schema.dtd"> <mycat:schema xmlns:mycat="http://io.mycat/"> <schema name="testdb" checkSQLschema="false" sqlMaxLimit="100" dataNode="dn1"></schema> <dataNode name="dn1" dataHost="localhost1" database="testdb"/> <dataHost name="localhost1" maxCon="1000" minCon="10" balance="3" writeType="0" dbType="mysql" dbDriver="native" switchType="1" slaveThreshold="100"> <heartbeat>select user()</heartbeat> <writeHost host="mysql_master" url="192.168.232.11:3306" user="mycat" password="Qf@12345!" > <readHost host="mysql_slave1" url="192.168.232.12:3306" user="mycat" password="Qf@12345!" /> </writeHost> </dataHost> </mycat:schema>
注意:一定要嚴格遵守標簽開始和結尾格式,否則會報錯導致mycat啟動后自動關閉
3.在mysql_mycat上創(chuàng)建庫
? mysql> create database testdb; mysql> use testdb; mysql> create table testdb.t1(id int); mysql> insert into testdb.t1 values(1); ?
4.在master上給用戶授權
[root@mysql_master ~]# mysql -uroot -p mysql> grant all on testdb.* to mycat@'%' identified by 'Qf@12345!'; mysql> flush privileges;
5.在mycat機器上測試mycat用戶登錄master
[root@mysql_mycat ~]# mysql -umycat -p'Qf@12345!' -h mysql_master
登錄上之后不進行任何操作,直接退出
6.在wrapper.conf中添加
[root@mycat mycat]# cd conf/ [root@mysql_mycat conf]# vim wrapper.conf
#在設置JVM哪里添加如下內容
wrapper.startup.timeout=300 //超時時間300秒
啟動:
[root@mysql_mycat mycat]# bin/mycat start Starting Mycat-server... [root@mysql_mycat mycat]# jps 3814 Jps 3801 WrapperSimpleApp
再次啟動jps查看,如果進程丟失一個,則是因為jdk版本問題,更換jdk
四、卸載重新安裝jdk
1.卸載原有jdk版本
[root@mysql_mycat mycat]# java -version
查看jdk所有包
[root@mysql_mycat ~]# rpm -qa | grep openjdk
卸載:[root@mysql_mycat ~]# rpm -qa | grep openjdk |xargs rpm -e --nodeps
再查看:[root@mysql_mycat ~]# rpm -qa | grep openjdk
發(fā)現(xiàn)jdk已全部刪除
2.安裝新jdk1.8
(1)從本地上傳jdk文件壓縮包
(2)解壓縮
[root@mysql_mycat ~]# tar xzf jdk-8u162-linux-x64.tar.gz -C /usr/local/ [root@mysql_mycat ~]# cd /usr/local/ [root@mysql_mycat local]# mv jdk1.8.0_162/ java
(3)設置環(huán)境變量
[root@mysql_mycat ~]# vim /etc/profile export JAVA_HOME=/usr/local/java export JRE_HOME=$JAVA_HOME/jre export CLASSPATH=.:$JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar:$JRE_HOME/lib export PATH=$PATH:$JAVA_HOME/bin:$JRE_HOME/bin
然后使之生效:
[root@mysql_master local]# source /etc/profile
(4)查看java版本
[root@mysql_mycat ~]# java -version java version "1.8.0_162" Java(TM) SE Runtime Environment (build 1.8.0_162-b12) Java HotSpot(TM) 64-Bit Server VM (build 25.162-b12, mixed mode)
五、開啟mycat
[root@mysql_mycat mycat]# bin/mycat start [root@mysql_mycat mycat]# jps 7173 WrapperSimpleApp 7189 Jps 查看8066端口 [root@mysql_mycat ~]# netstat -lntp | grep java
(1)將master當做mycat的客戶端
[root@mysql_master ~]# mysql -umycat -hmysql_mycat -p'Qf@12345!' -P 8066
六、常見問題
1.在master上登錄:mysql -umycat -hmysql_mycat -p'Qf@12345!' -P 8066
2.若出現(xiàn)連接失敗,大概率是mycat未啟動
3.cd到/mycat/bin/mycat目錄,start啟動
4.查看jps,有兩個進程,啟動成功
5.多行注釋: <![CDATA[---內容---]]>
6.mycat配置的密碼是Qf@12345! 7.插入數(shù)據(jù)操作在mycat端
七、show tables報錯
如果在show table報錯:
mysql> show tables;
ERROR 3009 (HY000): java.lang.IllegalArgumentException: Invalid DataSource:0
解決方式:
登錄master服務將mycat的登錄修改為%
mysql> update user set Host = '%' where User = 'mycat' and Host = 'localhost';
Query OK, 1 row affected (0.00 sec)
Rows matched: 1 Changed: 1 Warnings: 0
mysql> flush privileges;
或者在授權用戶mycat權限為*.*
到此這篇關于MyCat環(huán)境搭建詳細教程的文章就介紹到這了,更多相關MyCat環(huán)境搭建內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
mysql添加索引方法詳解(Navicat可視化加索引與sql語句加索引)
索引用來快速地尋找那些具有特定值的記錄,如果沒有索引,執(zhí)行查詢時MySQL必須從第一個記錄開始掃描整個表的所有記錄,直至找到符合要求的記錄,表里面的記錄數(shù)量越多,代價就越高,下面這篇文章主要給大家介紹了關于mysql添加索引的相關資料,需要的朋友可以參考下2022-11-11MySQL數(shù)據(jù)庫優(yōu)化經驗詳談(服務器普通配置)
同時在線訪問量繼續(xù)增大 對于1G內存的服務器明顯感覺到吃力嚴重時甚至每天都會死機 或者時不時的服務器卡一下 這個問題曾經困擾了我半個多月MySQL使用是很具伸縮性的算法,因此你通常能用很少的內存運行或給MySQL更多的被存以得到更好的性能。2011-03-03Mysql Workbench查詢mysql數(shù)據(jù)庫方法
在本篇文章里小編給大家分享了個關于Mysql Workbench查詢mysql數(shù)據(jù)庫方法和步驟,有需要的朋友們學習下。2019-03-03