溫馨提示×

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

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

mycat的schema.xml

發(fā)布時(shí)間:2020-08-23 15:15:02 來源:網(wǎng)絡(luò) 閱讀:1283 作者:lzf05303774 欄目:MySQL數(shù)據(jù)庫

一、一個(gè)簡(jiǎn)單的schema.xml文件:

1、文件內(nèi)容:

<?xml version="1.0"?>  

<!DOCTYPE mycat:schema SYSTEM "schema.dtd">  

<mycat:schema xmlns:mycat="http://io.mycat/">


    <!-- 設(shè)置表的存儲(chǔ)方式.schema name="TESTDB" 與 server.xml中的 TESTDB 設(shè)置一致  -->  

    <schema name="TESTDB" checkSQLschema="false" sqlMaxLimit="100">  

        <table name="company" primaryKey="id" type="global" dataNode="node_db01" />  


        <table name="t_user" primaryKey="id" dataNode="node_db01,node_db02,node_db03" rule="mod-long"/>  

   

    </schema>  


    <!-- 設(shè)置dataNode 對(duì)應(yīng)的數(shù)據(jù)庫,及 mycat 連接的地址dataHost -->  

    <dataNode name="node_db01" dataHost="dataHost01" database="db1" />  

    <dataNode name="node_db02" dataHost="dataHost01" database="db2" />  

    <dataNode name="node_db03" dataHost="dataHost01" database="db3" />  


    <!-- mycat 邏輯主機(jī)dataHost對(duì)應(yīng)的物理主機(jī).其中也設(shè)置對(duì)應(yīng)的mysql登陸信息 -->  

    <dataHost name="dataHost01" maxCon="1000" minCon="10" balance="0" writeType="0" dbType="mysql" dbDriver="native">  

            <heartbeat>select user()</heartbeat>  

            <writeHost host="hostM1" url="192.168.56.101:3306" user="root" password="123456"/>  

    </dataHost>  

</mycat:schema> 


2、說明:

(2.1)、<schema name="mycat" checkSQLschema="false" sqlMaxLimit="100">

在這一行參數(shù)里面,schema name定義了可以在MyCAT前端顯示的邏輯數(shù)據(jù)庫的名字,

checkSQLschema這個(gè)參數(shù)為False的時(shí)候,表明MyCAT會(huì)自動(dòng)忽略掉表名前的數(shù)據(jù)庫名,比如說mydatabase1.test1,會(huì)被當(dāng)做test1;

sqlMaxLimit指定了SQL語句返回的行數(shù)限制;如果sql語句中出現(xiàn)limit會(huì)覆蓋此處的sqlMaxLimit。

(2.2)、<table name="company" primaryKey="id" type="global" dataNode="node_db01" />

global表示 compay表是全局表 在節(jié)點(diǎn)node_db01對(duì)應(yīng)的數(shù)據(jù)庫中

(2.3)、<table name="t_user" primaryKey="id" dataNode="node_db01,node_db02,node_db03" rule="mod-long">  

(2.4)、mod-long 在rule.xml中:

<tableRule name="mod-long">

    <rule>

        <columns>id</columns>

        <algorithm>mod-long</algorithm>

    </rule>

</tableRule>

<function name="mod-long" class="io.mycat.route.function.PartitionByMod">

    <!-- how many data nodes -->

    <property name="count">3</property>

</function>

count值為數(shù)據(jù)庫的節(jié)點(diǎn)數(shù)

如有三個(gè)數(shù)據(jù)庫db1,db2,db3

dataHost 只寫了一個(gè)表明 物理數(shù)據(jù)庫只有一個(gè),有三個(gè)不同邏輯庫

(2.5)、balance 是否啟用讀寫分離

   balance=0時(shí),讀操作都在localhost上(localhost失敗時(shí),后端直接失敗)。

  balance=1時(shí),讀操作會(huì)隨機(jī)分散在localhost1和兩個(gè)readhost上面(localhost失敗時(shí),寫操作會(huì)在localhost1,如果localhost1再失敗,則無法進(jìn)行寫操作)。

  balance=2時(shí),寫操作會(huì)在localhost上,讀操作會(huì)隨機(jī)分散在localhost1,localhost1和兩個(gè)readhost上面(同上)

  我們這里只有個(gè)數(shù)據(jù)庫服務(wù)器hostM1,故balance=0。

(2.6)、writeType 寫操作只寫入幾個(gè)節(jié)點(diǎn)

writeType=0時(shí),寫操作只會(huì)在localhost上,如果localhost失敗,會(huì)自動(dòng)切換到localhost1,localhost恢復(fù)以后并不會(huì)切換回localhost進(jìn)行寫操作。

writeType=1時(shí),寫操作會(huì)隨機(jī)分布在localhost和localhost1上,單點(diǎn)失敗并不會(huì)影響集群的寫操作,但是后端的從庫會(huì)無法從掛掉的主庫獲取更新,會(huì)在讀數(shù)據(jù)的時(shí)候出現(xiàn)數(shù)據(jù)不一致

我們這里只有個(gè)數(shù)據(jù)庫服務(wù)器hostM1,故balance=0。

(2.7)、switchType="-1,1,2,3"  是否啟用主從切換:

-1:表示不啟用主從切換;

1:為默認(rèn)值,自動(dòng)切換;

2:基于主從同步的狀態(tài),決定是否切換,與show slave status心跳對(duì)應(yīng);

3:基于多主galary集群切換,與show status like 'wsrep%'心跳對(duì)應(yīng);

備注:switchType=1、2、3時(shí),需要配置多個(gè)writeHost節(jié)點(diǎn)。

(2.8)、heartbeat 心跳檢測(cè):switchType和heartbeat配合使用

<heartbeat>show slave status</heartbeat>  --心跳檢測(cè)語句,一般為select user();

如果是switchType=2,基于主從同步狀態(tài)決定是否切換,則心跳設(shè)為show slave status;

如果是switchType=3,則心跳設(shè)為show status like 'wsrep%';


二、一個(gè)稍微復(fù)雜的schema.xml文件:

1、文件內(nèi)容:

<?xml version=\"1.0\"?>

<!DOCTYPE mycat:schema SYSTEM \"schema.dtd\">

<mycat:schema xmlns:mycat=\"http://org.opencloudb/\">


    <schema name="mycat" checkSQLschema="false" sqlMaxLimit="100">

        <!-- auto sharding by id (long) -->

        <table name="students" dataNode="dn1,dn2,dn3,dn4" rule="rule1" />

        <table name="log_test" dataNode="dn1,dn2,dn3,dn4" rule="rule2" />

        <!-- global table is auto cloned to all defined data nodes ,so can join 

            with any table whose sharding node is in the same data node -->

        <table name="item_test" primaryKey="ID" type="global" dataNode="dn1,dn2,dn3,dn4" />

     

     <table name="customer" primaryKey="ID" dataNode="dn1,dn2" rule="sharding-by-intfile">

        <childTable name="orders" primaryKey="ID" joinKey="customer_id" parentKey="id">

             <childTable name="order_items" joinKey="order_id" parentKey="id" />

        </childTable>

        <childTable name="customer_addr" primaryKey="ID" joinKey="customer_id" parentKey="id" />

      </table>

    </schema>



    <dataNode name=\"dn1\" dataHost=\"localhost\" database=\"test1\" />

    <dataNode name=\"dn2\" dataHost=\"localhost\" database=\"test2\" />

    <dataNode name=\"dn3\" dataHost=\"localhost\" database=\"test3\" />

    <dataNode name=\"dn4\" dataHost=\"localhost\" database=\"test4\" />


    <dataHost name="localhost" maxCon="100" minCon="10" balance="1"

        writeType="1" dbType="mysql" dbDriver="native">

        <heartbeat>select user()<beat>

        <!-- can have multi write hosts -->

        <writeHost host="localhost" url="localhost:3306" user="root" password="wangwenan">

            <!-- can have multi read hosts -->

            <readHost host=\"hostS1\" url="localhost:3307" user="root" password="wangwenan"/>

        </writeHost>

        <writeHost host="localhost1" url="localhost:3308" user="root" password="wangwenan">

            <!-- can have multi read hosts -->

            <readHost host="hostS11" url="localhost:3309" user="root" password="wangwenan"/>

        </writeHost>

    </dataHost>

  

</mycat:schema>

2、說明:

(2.1)、<table name="item_test" primaryKey="ID" type="global" dataNode="dn1,dn2,dn3,dn4" />

 這一行代表的是全局表,這意味著,item_test這張表會(huì)在四個(gè)dataNode里面都保存有完整的數(shù)據(jù)副本,那么查詢的時(shí)候只會(huì)分發(fā)到某一個(gè)節(jié)點(diǎn)上

配置的primaryKey沒發(fā)現(xiàn)作用在哪里,姑且忽略吧,以后發(fā)現(xiàn)了再補(bǔ)上.

(2.2)、childtable是一種依賴于父表的結(jié)構(gòu),這意味著,childtable的joinkey會(huì)按照父表的parentKey的策略一起切分,

當(dāng)父表與子表進(jìn)行連接,且連接條件是childtable.joinKey=parenttable.parentKey時(shí),不會(huì)進(jìn)行跨庫的連接.

(2.3)、writeType和balance是用來控制后端集群的讀寫分離的關(guān)鍵參數(shù),這里用了雙主雙從的集群配置。

      故writeType="1",balance="1"


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

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

AI