溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

Linux-Mycat-安裝配置

發(fā)布時(shí)間:2020-05-28 09:41:49 來源:網(wǎng)絡(luò) 閱讀:3794 作者:李佳良 欄目:MySQL數(shù)據(jù)庫

MyCat介紹

面向企業(yè)應(yīng)用開發(fā)的“大數(shù)據(jù)庫集群”支持事務(wù)、ACID、可以替代Mysql的加強(qiáng)版數(shù)據(jù)庫
可以視為“Mysql”集群的企業(yè)級(jí)數(shù)據(jù)庫,用來替代昂貴的Oracle集群
融合內(nèi)存緩存技術(shù)、Nosql技術(shù)、HDFS大數(shù)據(jù)的新型SQL Server
結(jié)合傳統(tǒng)數(shù)據(jù)庫和新型分布式數(shù)據(jù)倉庫的新一代企業(yè)級(jí)數(shù)據(jù)庫產(chǎn)品
MyCat的目標(biāo)是:
低成本的將現(xiàn)有的單機(jī)數(shù)據(jù)庫和應(yīng)用平滑遷移到“云”端,解決數(shù)據(jù)存儲(chǔ)和業(yè)務(wù)規(guī)模迅速增長情況下的數(shù)據(jù)瓶頸問題。


MyCat的關(guān)鍵特性

支持 SQL 92標(biāo)準(zhǔn)
支持Mysql集群,可以作為Proxy使用
支持JDBC連接ORACLE、DB2、SQL Server,將其模擬為MySQL ?Server使用
支持galera for mysql集群,percona-cluster或者mariadb cluster,提供高可用性數(shù)據(jù)分片集群
自動(dòng)故障切換,高可用性
支持讀寫分離,支持Mysql雙主多從,以及一主多從的模式
支持全局表,數(shù)據(jù)自動(dòng)分片到多個(gè)節(jié)點(diǎn),用于高效表關(guān)聯(lián)查詢
支持獨(dú)有的基于E-R 關(guān)系的分片策略,實(shí)現(xiàn)了高效的表關(guān)聯(lián)查詢
多平臺(tái)支持,部署和實(shí)施簡(jiǎn)單


MyCat架構(gòu)

Linux-Mycat-安裝配置

Mycat高可用參數(shù)

有關(guān)Mycat高可用的schema.xml配置參數(shù)相關(guān)說明:
balance屬性?
負(fù)載均衡類型,目前的取值有如下4種。?

*?balance="0"?: 不開啟讀寫分離機(jī)制,所有讀操作都發(fā)送到當(dāng)前可用的writeHost上。?

*?balance="1"?: 全部的readHost與stand by writeHost都參與select語句的負(fù)載均衡,簡(jiǎn)而言之,當(dāng)為雙主雙從模式(M1->S1,M2->S2,并且M1與M2互為主備)時(shí),在正常情況下,M2、S1和S2都參與select語句的負(fù)載均衡。?

*?balance="2"?: 所有的讀操作都隨機(jī)地在writeHost、readHost上分發(fā)。?

*?balance="3"?: 所有的讀請(qǐng)求都隨機(jī)分發(fā)到writeHost對(duì)應(yīng)的readHost上執(zhí)行,writeHost不負(fù)擔(dān)讀壓力。
writeType屬性?
負(fù)載均衡類型目前的取值有兩種。?

*?writeType="0"?: 所有的寫操作都發(fā)送到配置的第1個(gè)writeHost上,writeHost掛了則切到writeHost2上,重新恢復(fù)writeHost1節(jié)點(diǎn)后,不會(huì)再切回來,還是以writeHost2為準(zhǔn),切換記錄在配置文件dnindex.properties中。?

*?writeType="0"?: 所有的寫操作都隨機(jī)地發(fā)送到配置的writeHost上,Mycat1.5版本以后不再推薦使用該值。
switchType屬性?

*?switchType="-1"?: 表示不自動(dòng)切換。?

*?switchType="1"?: 為默認(rèn)值(或?yàn)?),表示自動(dòng)切換。?

*?switchType="2"?: 表示基于MySQL主從同步的狀態(tài)決定是否切換,心跳語句如下:
show slave status

?switchType="3"?: 表示基于 MySQL Galary Cluster的切換機(jī)制,心跳語句如下:
show status like 'wsrep%'


MySQL主從讀寫分離環(huán)境
項(xiàng)目 Mycat MySQL-master MySQL-slaveA MySQL-slaveB
IP 192.168.32.149 192.168.32.146 192.168.32.129 192.168.32.130
Port 8066/9066 3306 3306 3306


Java安裝包:
http://www.oracle.com/technetwork/java/javase/downloads/jdk10-downloads-4416644.html
Mycat安裝包:
http://www.mycat.io/

解壓縮至目錄/usr/local/

#cd /usr/local/

#tar zxf jdk-10.0.1_linux-x64_bin.tar.gz
#tar zxf Mycat-server-1.6-RELEASE-20161028204710-linux.tar.gz

#/usr/local/mycat/bin/mycat start
#ss -lnt | grep mycat

#cd mycat/conf/

先配置server.xml

×××為邏輯庫

#vim server.xml

<user name="root">
<property name="password">123456</property>
<property name="schemas">TESTDB,aaa,bbb</property>

配置schema

#vim schema.xml

<?xml version="1.0"?>
<!DOCTYPE mycat:schema SYSTEM "schema.dtd">
<mycat:schema xmlns:mycat="http://io.mycat/">

    &lt;!-- 邏輯庫配置 DB1,DB2是邏輯庫并不是真的數(shù)據(jù)庫--&gt; 
     &lt;schema name="TESTDB" checkSQLschema="false" sqlMaxLimit="100" dataNode="dn1"/&gt;
     &lt;schema name="aaa" checkSQLschema="false" sqlMaxLimit="100" dataNode="dn2"/&gt;
     &lt;schema name="bbb" checkSQLschema="false" sqlMaxLimit="100" dataNode="dn3"/&gt;

     &lt;!-- &lt;dataNode name="dn1$0-743" dataHost="localhost1" database="db$0-743"
             /&gt; --&gt;

<!-- 節(jié)點(diǎn)配置 db1,db2,db3才是真正的數(shù)據(jù)庫(需要在mysql主上創(chuàng)建) -->
<dataNode name="dn1" dataHost="localhost1" database="db1" />
<dataNode name="dn2" dataHost="localhost1" database="db2" />
<dataNode name="dn3" dataHost="localhost1" database="db3" />
<!--<dataNode name="dn4" dataHost="sequoiadb1" database="SAMPLE" />

<dataNode name="jdbc_dn1" dataHost="jdbchost" database="db1" />
<dataNode name="jdbc_dn2" dataHost="jdbchost" database="db2" />
<dataNode name="jdbc_dn3" dataHost="jdbchost" database="db3" /> -->

  &lt;!-- 讀寫分離的配置(blance="1") --&gt; 

<dataHost name="localhost1" maxCon="1000" minCon="10" balance="1"
writeType="0" dbType="mysql" dbDriver="native" switchType="1" slaveThreshold="100">
<heartbeat>select user()</heartbeat>
<!-- can have multi write hosts -->
<!--注意:writeHost host=是主mysql readHost host=從mysql -->
<writeHost host="hostM1" url="192.168.32.146:3306" user="root"password="123456">
<!-- can have multi read hosts -->
<!-- 可以在這配置它對(duì)應(yīng)的多個(gè)讀庫 -->
<readHost host="hostS2" url="192.168.32.129:3306" user="root" password="123456" />
</writeHost>
<!--主故障,頂替寫節(jié)點(diǎn),主正常是分擔(dān)讀壓力-->
<writeHost host="hostS1" url="localhost:3316" user="root"
password="123456" />


#/usr/local/mycat/bin/mycat restart
#mysql -u root -p123456 -P 8066 -h 127.0.0.1


mysql> show databases;
+----------+
| DATABASE |
+----------+
| TESTDB |
| aaa |
| bbb |
+----------+
3 rows in set (0.00 sec)


mysql> use aaa;
Reading table information for completion of table and column names
You can turn off this feature to get a quicker startup with -A

Database changed


mysql> show tables;
+---------------+
| Tables_in_db2 |
+---------------+
| bbb |
+---------------+
1 row in set (0.00 sec)


mysql> insert into bbb values(1,'lijialiang');
Query OK, 1 row affected (0.04 sec)

MySQL-slaveB:


mysql> show databases;
+--------------------+
| Database |
+--------------------+
| information_schema |
| db1 |
| db2 |
| db3 |
| mysql |
| performance_schema |
| sys |
+--------------------+
7 rows in set (0.10 sec)


mysql> use db2;
Reading table information for completion of table and column names
You can turn off this feature to get a quicker startup with -A

Database changed


mysql> show tables;
+---------------+
| Tables_in_db2 |
+---------------+
| bbb |
+---------------+
1 row in set (0.01 sec)


mysql> select * from bbb;
+------+------------+
| id | name |
+------+------------+
| 1 | lijialiang |
+------+------------+
1 rows in set (0.00 sec)

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI