欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

利用mycat實(shí)現(xiàn)mysql數(shù)據(jù)庫讀寫分離的示例

 更新時間:2018年03月23日 10:36:52   作者:壞~牧羊人  
本篇文章主要介紹了利用mycat實(shí)現(xiàn)mysql數(shù)據(jù)庫讀寫分離的示例,mycat是最近很火的一款國人發(fā)明的分布式數(shù)據(jù)庫中間件,它是基于阿里的cobar的基礎(chǔ)上進(jìn)行開發(fā)的,有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

什么是MyCAT

  1. 一個徹底開源的,面向企業(yè)應(yīng)用開發(fā)的大數(shù)據(jù)庫集群
  2. 支持事務(wù)、ACID、可以替代MySQL的加強(qiáng)版數(shù)據(jù)庫
  3. 一個可以視為MySQL集群的企業(yè)級數(shù)據(jù)庫,用來替代昂貴的Oracle集群
  4. 一個融合內(nèi)存緩存技術(shù)、NoSQL技術(shù)、HDFS大數(shù)據(jù)的新型SQL Server
  5. 結(jié)合傳統(tǒng)數(shù)據(jù)庫和新型分布式數(shù)據(jù)倉庫的新一代企業(yè)級數(shù)據(jù)庫產(chǎn)品
  6. 一個新穎的數(shù)據(jù)庫中間件產(chǎn)品

MyCAT關(guān)鍵特性

  1. 支持SQL92標(biāo)準(zhǔn)
  2. 支持MySQL、Oracle、DB2、SQL Server、PostgreSQL等DB的常見SQL語法
  3. 遵守MySQL原生協(xié)議,跨語言,跨平臺,跨數(shù)據(jù)庫的通用中間件代理。
  4. 基于心跳的自動故障切換,支持讀寫分離,支持MySQL主從,以及galera cluster集群。
  5. 支持Galera for MySQL集群,Percona Cluster或者M(jìn)ariaDB cluster
  6. 基于Nio實(shí)現(xiàn),有效管理線程,解決高并發(fā)問題。
  7. 支持?jǐn)?shù)據(jù)的多片自動路由與聚合,支持sum,count,max等常用的聚合函數(shù),支持跨庫分頁。
  8. 支持單庫內(nèi)部任意join,支持跨庫2表join,甚至基于caltlet的多表join。
  9. 支持通過全局表,ER關(guān)系的分片策略,實(shí)現(xiàn)了高效的多表join查詢。
  10. 支持多租戶方案。
  11. 支持分布式事務(wù)(弱xa)。
  12. 支持XA分布式事務(wù)(1.6.5)。
  13. 支持全局序列號,解決分布式下的主鍵生成問題。
  14. 分片規(guī)則豐富,插件化開發(fā),易于擴(kuò)展。
  15. 強(qiáng)大的web,命令行監(jiān)控。
  16. 支持前端作為MySQL通用代理,后端JDBC方式支持Oracle、DB2、SQL Server 、 mongodb 、巨杉。
  17. 支持密碼加密
  18. 支持服務(wù)降級
  19. 支持IP白名單
  20. 支持SQL黑名單、SQL注入攻擊攔截
  21. 支持prepare預(yù)編譯指令
  22. 支持非堆內(nèi)存(Direct Memory)聚合計(jì)算
  23. 支持PostgreSQL的native協(xié)議
  24. 支持MySQL和oracle存儲過程,out參數(shù)、多結(jié)果集返回
  25. 支持zookeeper協(xié)調(diào)主從切換、zk序列、配置zk化
  26. 支持庫內(nèi)分表
  27. 集群基于ZooKeeper管理,在線升級,擴(kuò)容,智能優(yōu)化,大數(shù)據(jù)處理(2.0開發(fā)版)。

1、這里是在mysql主從復(fù)制實(shí)現(xiàn)的基礎(chǔ)上,利用mycat做讀寫分離,架構(gòu)圖如下:

2、Demo

2.1 在mysql master上創(chuàng)建數(shù)據(jù)庫創(chuàng)建db1

2.2 在數(shù)據(jù)庫db1創(chuàng)建表student

同時,因?yàn)榕渲煤昧薽ysql主從復(fù)制,在mysql slave上也有一樣數(shù)據(jù)庫和表

2.3 編輯 mycat的配置文件server.xml

   <!--表示mycat的登錄用戶名-->
  <user name="test">
        <!--表示mycat的登錄密碼-->
        <property name="password">test</property>
         <!--表示mycat的邏輯數(shù)據(jù)庫名稱,可以自定義-->
        <property name="schemas">TESTDB</property>
    </user>

    <user name="user">
        <property name="password">user</property>
        <property name="schemas">TESTDB</property>
        <property name="readOnly">true</property>
    </user>

2.4編輯mycat的配置文件schema.xml

<!--TESTDB表示mycat的邏輯數(shù)據(jù)庫名稱
 當(dāng)schema節(jié)點(diǎn)沒有子節(jié)點(diǎn)table的時候,一定要有dataNode屬性存在(指向mysql真實(shí)數(shù)據(jù)庫),
-->
<schema name="TESTDB" checkSQLschema="false" sqlMaxLimit="100" dataNode="dn1">
    </schema>
    <!--指定master的數(shù)據(jù)庫db1-->
    <dataNode name="dn1" dataHost="192.168.0.4" database="db1" />
    <!--指定mastet的ip -->
    <dataHost name="192.168.0.4" maxCon="1000" minCon="10" balance="3"
        writeType="0" dbType="mysql" dbDriver="native" switchType="1" slaveThreshold="100">
        <!--表示mysql的心跳狀態(tài)-->
        <heartbeat>select user()</heartbeat>
        <!-- master負(fù)責(zé)寫 -->
        <writeHost host="hostM1" url="192.168.0.4:3306" user="root"
            password="admin">
        <!--slave負(fù)責(zé)讀-->
        <readHost host="hostS2" url="192.168.0.5:3306" user="root" password="admin" />
        </writeHost>
</dataHost>

到這里,利用mycat做讀寫分離就已經(jīng)配置完了

注意 dataHost節(jié)點(diǎn)的下面三個屬性

balance, switchType, writeType

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

balance="1",全部的readHost與stand by writeHost參與select語句的負(fù)載均衡,簡單的說,當(dāng)雙主雙從模式(M1->S1,M2->S2,并且M1與M2互為主備),正常情況下,M2,S1,S2都參與select語句的負(fù)載均衡。

balance="2",所有讀操作都隨機(jī)的在writeHost、readhost上分發(fā)。

balance="3",所有讀請求隨機(jī)的分發(fā)到writeHost下的readhost執(zhí)行,writeHost不負(fù)擔(dān)讀壓力

writeType表示寫模式

writeType="0",所有的操作發(fā)送到配置的第一個writehost

writeType="1",隨機(jī)發(fā)送到配置的所有writehost

writeType="2",不執(zhí)行寫操作

switchType指的是切換的模式,目前的取值也有4種:

switchType=‘-1‘ 表示不自動切換

switchType=‘1‘ 默認(rèn)值,表示自動切換

switchType=‘2‘ 基于MySQL主從同步的狀態(tài)決定是否切換,心跳語句為show slave status

switchType=‘3‘基于MySQL galary cluster的切換機(jī)制(適合集群)(1.4.1),心跳語句為show status like ‘wsrep%‘。

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • MySQL修改root密碼的3種實(shí)用方法

    MySQL修改root密碼的3種實(shí)用方法

    最近在看項(xiàng)目,搭建本地環(huán)境時候,忘記mysql的密碼,怎么修改密碼,網(wǎng)上找了半天,終于配合著幾個帖子搞定了,下面這篇文章主要給大家介紹了關(guān)于MySQL修改root密碼的3種實(shí)用方法,需要的朋友可以參考下
    2023-11-11
  • 淺談MySQL user權(quán)限表

    淺談MySQL user權(quán)限表

    MySQL 在安裝時會自動創(chuàng)建一個名為 mysql 的數(shù)據(jù)庫,mysql 數(shù)據(jù)庫中存儲的都是用戶權(quán)限表。本文就詳細(xì)的介紹一下MySQL user權(quán)限表 ,感興趣的可以了解一下
    2021-06-06
  • MySQL查詢優(yōu)化--調(diào)整內(nèi)部變量的詳解

    MySQL查詢優(yōu)化--調(diào)整內(nèi)部變量的詳解

    本篇文章是對MySQL查詢優(yōu)化中的調(diào)整內(nèi)部變量進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下
    2013-06-06
  • MySQL 主從復(fù)制數(shù)據(jù)不一致的解決方法

    MySQL 主從復(fù)制數(shù)據(jù)不一致的解決方法

    本文主要介紹了MySQL 主從復(fù)制數(shù)據(jù)不一致的解決方法,文中根據(jù)實(shí)例編碼詳細(xì)介紹的十分詳盡,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • mysql int(3)與int(11)的區(qū)別詳解

    mysql int(3)與int(11)的區(qū)別詳解

    這篇文章主要介紹了mysql int(3)與int(11)的區(qū)別詳解的相關(guān)資料,需要的朋友可以參考下
    2016-09-09
  • MySQL參數(shù)lower_case_table_name的實(shí)現(xiàn)

    MySQL參數(shù)lower_case_table_name的實(shí)現(xiàn)

    lower_case_table_names是一個重要的系統(tǒng)變量,它影響著MySQL如何處理表名的大小寫,本文主要介紹了MySQL參數(shù)lower_case_table_name的實(shí)現(xiàn),感興趣的可以了解一下
    2024-08-08
  • MySQL 8中新增的這三大索引 隱藏、降序、函數(shù)

    MySQL 8中新增的這三大索引 隱藏、降序、函數(shù)

    這篇文章主要介紹了MySQL 8.x版本中新增的三大索引 隱藏索引、降索引序、函數(shù)索引,如果文章對你有點(diǎn)幫助,小伙伴們點(diǎn)贊、收藏、評論、分享走起呀
    2021-09-09
  • MySQL 實(shí)例無法啟動的問題分析及解決

    MySQL 實(shí)例無法啟動的問題分析及解決

    這篇文章主要介紹了MySQL 實(shí)例無法啟動的問題分析及解決方法,幫助大家更好的理解和學(xué)習(xí)使用MySQL數(shù)據(jù)庫,感興趣的朋友可以了解下
    2021-03-03
  • 一文掌握MySQL唯一索引是如何加鎖的

    一文掌握MySQL唯一索引是如何加鎖的

    這篇文章主要介紹了一文掌握MySQL唯一索引是如何加鎖的,本案例其實(shí)就是在主鍵索引上進(jìn)行等值查詢,取決于查詢記錄是否存在,存在退化成記錄鎖,否則就是在索引樹中找到第一個大于該查詢記錄的記錄后,將改記錄的索引中的next-key lock退換成間隙鎖,需要的朋友可以參考下
    2024-06-06
  • mysql 5.7.17 安裝圖文教程(windows)

    mysql 5.7.17 安裝圖文教程(windows)

    這篇文章主要介紹了windows下mysql 5.7.17 安裝圖文教程,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-03-03

最新評論