亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

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

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

schema.xml的配置有哪些

發布時間:2021-10-13 15:41:40 來源:億速云 閱讀:168 作者:iii 欄目:編程語言

這篇文章主要講解了“schema.xml的配置有哪些”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“schema.xml的配置有哪些”吧!

schema.xml 配置介紹

schema 標簽

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

1、name:配置邏輯庫的名字(即mycat展示的數據庫實例名)

2、dataNode:用于配置該邏輯庫默認的分片。沒有通過table標簽配置的表,就會走到默認的分片上。這里注意沒有配置在table標簽的表,用工具查看是無法顯示的,但是可以正常使用。
如果沒有配置dataNode屬性,則沒有配置在table標簽的表,是無法使用的。
通過mycat建表,而該表并沒有提前配置table標簽,則mycat會找到默認的dataNode,并把表建在默認的dataNode上。如果沒有配置默認dataNode,則mycat會報錯。
如果該表有配置table標簽,則表會分別在table標簽指定的dataNode上建表。

3、checkSQLschema:boolean類型
當前端執行【select *from USERDB.tf_user;】時(表名前指定了mycat邏輯庫名)
兩種取值:
true:mycat會把語句轉換為【select * from tf_user;】
false:會報錯

4、sqlMaxLimit:相當于sql的結果集中,加上【limit N】。如果sql本身已經指定limit,則以sql指定的為準。
如果table標簽的表,needAddLimit屬性配置為false,則該表的sql禁止自動加上limit

table 標簽

table標簽為schema標簽的子標簽。
table標簽用于定義Mycat的邏輯表,以及邏輯表的分片規則。
<table name="user" primaryKey="id" autoIncrement="true" dataNode="dn1,dn2" rule="hash-int" />

1、name:邏輯表的表名,同一個schema表名必須唯一

2、dataNode:定義這個邏輯表所屬的 dataNode,用英文逗號間隔,如:dataNode="dn1,dn2"

3、rule:該屬性用于指定邏輯表要使用的規則名字,規則名字在 rule.xml 中定義,必須與 tableRule 標簽中 name 屬性屬性值一一對應。

4、ruleRequired:該屬性用于指定表是否綁定分片規則,如果配置為 true,但沒有配置具體 rule 的話 ,程序會報錯

5、primaryKey:指定該邏輯表對應真實表的主鍵。MyCat會緩存主鍵(通過primaryKey屬性配置)與具體 dataNode的信息。當分片規則使用非主鍵進行分片時,那么在使用主鍵進行查詢時,MyCat就會通過緩存先確定記錄在哪個dataNode上,然后再在該dataNode上執行查詢。
如果緩存并沒有命中的話,還是會發送語句給所有的dataNode。
關于Mycat的主鍵緩存,其機制是:當根據主鍵查詢的SQL語句第一次執行時,Mycat會對其結果進行分析,確定該主鍵在哪個分片上,并進行該主鍵到分片ID的緩存。通過連接MyCAT的9066管理端口,執行show@@cache,可以顯示當前緩存的使用情況。可在sql執行前后的2個時間點執行show @@cache,通過結果信息中的LAST_PUT和LAST_ACCESS列,判斷相應表的緩存是否有被更新過。

6、type:該屬性定義了邏輯表的類型,目前邏輯表只有“全局表”和”普通表”兩種類型。
對應的配置:
全局表:global。
普通表:不指定該值為 global 的所有表。

7、autoIncrement:表示該表使用自增長策略

8、subTables:分表配置,mycat1.6之后開始支持,但dataNode 在分表條件下只能配置一個。

9、needAddLimit:與schema標簽的sqlMaxLimit配合使用,如果needAddLimit值為false,則語句不會加上limit

childTable 標簽

childTable 標簽用于定義 E-R 分片的子表。通過標簽上的屬性與父表進行關聯。

1、name:定義子表的表名

2、joinKey:插入子表的時候會使用這個列的值查找父表存儲的數據節點。

3、parentKey:該屬性指定的值一般為與父表建立關聯關系的列名。Mycat首先獲取 joinkey 的值,再通過 parentKey 屬性指定的列名產生查詢語句,通過執行該語句得到父表存儲在哪個分片上。從而確定子表存儲的位置。

4、primaryKey:同table標簽描述。

5、needAddLimit:同table標簽描述。

dataNode 標簽

<dataNode name="dn1" dataHost="localhost1" database="testdb01" />

1、name:指定分片的名字

2.、dataHost:定義該分片屬于哪個數據庫實例

3、database:定義該分片屬于哪個具體數據庫實例上的具體庫(即對應mysql中實際的DB)

dataHost 標簽

定義后端的數據庫主機
<dataHost name="localhost1" maxCon="1000" minCon="10" balance="0" writeType="0" dbType="mysql" dbDriver="native" switchType="1" slaveThreshold="100">

1、name:指定dataHost的名字

2、maxCon:指定每個讀寫實例連接池的最大連接。也就是說,標簽內嵌套的writeHost、 readHost 標簽都會使用這個屬 性的值來實例化出連接池的最大連接數。

3、minCon:指定每個讀寫實例連接池的最小連接,初始化連接池的大小。

4、balance負載均衡類型:
(1)balance="0", 不開啟讀寫分離機制,所有讀操作都發送到當前可用的writeHost 上。
(2)balance="1",全部的 readHost 與 stand by writeHost 參與 select 語句的負載均衡,簡單的說,當雙主雙從模式(M1->S1,M2->S2,并且 M1 與 M2 互為主備),正常情況下,M2,S1,S2 都參與 select 語句的負載均衡。
(3)balance="2",所有讀操作都隨機的在 writeHost、 readhost 上分發。
(4)balance="3",所有讀請求隨機的分發到 wiriterHost 對應的 readhost 執行,writerHost 不負擔讀壓力,注意 balance=3 只在 1.4 及其以后版本有,1.3 沒有。

5、writeType:負載均衡策略:
(1)writeType="0", 所有寫操作發送到配置的第一個 writeHost,第一個掛了切到還生存的第二個riteHost,重新啟動后已切換后的為準,切換記錄在配置文件中:dnindex.properties.
(2)writeType="1",所有寫操作都隨機的發送到配置的 writeHost,1.5 以后廢棄不推薦。

6、dbType:指定后端連接的數據庫類型,目前支持二進制的 mysql 協議,還有其他使用 JDBC 連接的數據庫。例如:mongodb、 oracle、 spark 等。

7、dbDriver:指定連接后端數據庫使用的 Driver,目前可選的值有 native 和 JDBC。使用native 的話,因為這個值執行的是二進制的 mysql 協議,所以可以使用 mysql 和 maridb。其他類型的數據庫則需要使用 JDBC 驅動來支持。

8、switchType
-1 表示不自動切換
1 默認值,自動切換
2 基于 MySQL 主從同步的狀態決定是否切換 心跳語句為 show slave status
3 基于 MySQL galary cluster 的切換機制(適合集群) 心跳語句為 show status like ‘wsrep%’.

9、tempReadHostAvailable:如果配置了這個屬性 writeHost 下面的 readHost 仍舊可用,默認 0 可配置(0、 1)。

writeHost 標簽 和 readHost 標簽

1、host:用于標識不同實例,一般 writeHost 我們使用M1,readHost 我們用S1。

2、url:后端實例連接地址,如果是使用 native 的 dbDriver,則一般為 address:port 這種形式。用 JDBC 或其他的dbDriver,則需要特殊指定。當使用 JDBC 時則可以這么寫:jdbc:mysql://localhost:3306/。

3、user:實例數據庫用戶名

4、password:實例數據庫用戶密碼

5、weight 屬性:權重 配置在 readhost 中作為讀節點的權重(1.4 以后)

6、usingDecrypt:是否對密碼加密默認 0 否 如需要開啟配置 1,同時使用加密程序對密碼加密

感謝各位的閱讀,以上就是“schema.xml的配置有哪些”的內容了,經過本文的學習后,相信大家對schema.xml的配置有哪些這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

宜良县| 昌黎县| 上杭县| 永丰县| 大名县| 富顺县| 金坛市| 乌苏市| 萍乡市| 隆昌县| 盐山县| 城口县| 特克斯县| 民县| 金沙县| 佛教| 云和县| 北流市| 西畴县| 上虞市| 湘潭市| 赣榆县| 桐城市| 高尔夫| 荆门市| 古田县| 大新县| 曲松县| 西乌| 宁远县| 凤阳县| 玉门市| 屏东县| 渝中区| 巴青县| 慈利县| 五寨县| 和政县| 辽阳市| 荣昌县| 宁夏|