MyCat+MySQL實現(xiàn)高可用讀寫分離(實測記錄)

一.測試環(huán)境

創(chuàng)建兩臺CentOS7虛機,部署兩套MySQL數(shù)據(jù)庫配置主從同步育苟,直接在主庫服務(wù)器安裝mycat進行測試。

主庫:192.168.216.128 port:3306
從庫:192.168.216.129 port:3306

1.下載MyCat安裝文件上傳至主庫服務(wù)器M

Mycat-server-1.6-RELEASE-20161028204710-linux.tar.gz
百度網(wǎng)盤:https://pan.baidu.com/s/1Xeyno8pRomT__AvmzcvKnQ
提取碼:hmhc

  • 上傳成功后解壓至/home目錄下
    tar -zxvf Mycat-server-1.6-RELEASE-20161028204710-linux.tar.gz

2.配置環(huán)境變量

  • vim /etc/profile
export PATH=/home/mycat/bin:$PATH
  • source /etc/profile

3.修改MyCat配置文件

  • vim /home/mycat/conf/server.xml
      <!--讀寫權(quán)限管理員賬戶-->
        <user name="root">
                <property name="password">123456</property>
                <property name="schemas">test</property>
        </user>
     <!--只讀權(quán)限普通賬戶-->
        <user name="user">
                <property name="password">user123</property>
                <property name="schemas">test</property>
                <property name="readOnly">true</property>
        </user>
  • vim /home/mycat/conf/schems.xml
<mycat:schema xmlns:mycat="http://io.mycat/">
        <!-- 定義一個MyCat的模式椎木,邏輯數(shù)據(jù)庫名稱TestDB -->
        <!-- “checkSQLschema”:描述的是當前的連接是否需要檢測數(shù)據(jù)庫的模式 -->
        <!-- “sqlMaxLimit”:表示返回的最大的數(shù)據(jù)量的行數(shù) -->
        <!-- “dataNode="dn1"”:該操作使用的數(shù)據(jù)節(jié)點是dn1的邏輯名稱 -->
        <schema name="test" checkSQLschema="false" sqlMaxLimit="100" dataNode="dn1"/>
        <!-- 定義個數(shù)據(jù)的操作節(jié)點违柏,以后這個節(jié)點會進行一些庫表分離使用 -->
        <!-- “dataHost="localhost1"”:定義數(shù)據(jù)節(jié)點的邏輯名稱 -->
        <!-- “database="test"”:定義數(shù)據(jù)節(jié)點要使用的數(shù)據(jù)庫名稱 -->
        <dataNode name="dn1" dataHost="localhost1" database="test" />
        <!-- 定義數(shù)據(jù)節(jié)點,包括了各種邏輯項的配置 -->
        <dataHost name="test" maxCon="1000" minCon="10" balance="1" writeType="0" dbType="mysql" dbDriver="native" switchType="1"  slaveThreshold="100">
            <!-- 配置真實MySQL與MyCat的心跳 -->
            <heartbeat>select user()</heartbeat>
            <!-- 配置真實的MySQL的連接路徑 -->
            <writeHost host="hostM1" url="192.168.216.128:3306" user="root" password="123456">
                <readHost host="hostS1" url="192.168.216.129:3306" user="root" password="123456"/>
            </writeHost>
            <writeHost host="hostM2" url="192.168.216.129:3306" user="root" password="123456">
            </writeHost>
        </dataHost>
</mycat:schema>

4.啟動MyCat : mycat start

二.關(guān)鍵配置項

mycat/conf目錄下 MyCat的核心配置文件schems.xml

屬性 狀態(tài) 說明
balance 表示負載模式
balance 0 不開啟讀寫分離機制香椎,所有讀操作都發(fā)送到當前可用的writeHost上漱竖。
balance 1 全部的readHost與stand by writeHost參與select語句的負載均衡。簡單的說當雙主雙從模式(M1->S1,M2->S2,并且M1與M2互為主備),正常情況下,M2,S1,S2都參與select語句的負載均衡畜伐。
balance 2 所有讀操作都隨機的在writeHost馍惹、readhost上分發(fā)。
balance 3 所有讀請求隨機的分發(fā)到wiriterHost對應(yīng)的readhost執(zhí)行,writerHost不負擔讀壓力
writeType 表示寫模式
writeType 0 所有的操作發(fā)送到配置的第一個writehost
writeType 1 隨機發(fā)送到配置的所有writehost
writeType 2 不執(zhí)行寫操作
switchType 指的是切換模式玛界,目前的取值也有4種万矾。
switchType -1 表示不自動切換
switchType 1 默認值,表示自動切換
switchType 2 基于MySQL主從同步的狀態(tài)決定是否切換,心跳語句為show slave status
switchType 3 基于MySQL galary cluster的切換機制(適合集群)(1.4.1)慎框,心跳語句為show status like ‘wsrep%‘良狈。

三.測試記錄

采用 banlance =1,writeType = 0 ,switchType = 1的配置模式

1.使主庫宕機 service mysql stop;
結(jié)果:讀寫轉(zhuǎn)移至從庫笨枯,mycat正常連接薪丁。
2.恢復主庫運行service mysql start
結(jié)果:mycat依舊采用從庫進行讀寫未重新接入主庫

四.參考

配置屬性詳解-https://www.cnblogs.com/alan319/p/10556995.html

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市猎醇,隨后出現(xiàn)的幾起案子窥突,更是在濱河造成了極大的恐慌,老刑警劉巖硫嘶,帶你破解...
    沈念sama閱讀 219,490評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件阻问,死亡現(xiàn)場離奇詭異,居然都是意外死亡沦疾,警方通過查閱死者的電腦和手機称近,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,581評論 3 395
  • 文/潘曉璐 我一進店門第队,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人刨秆,你說我怎么就攤上這事凳谦。” “怎么了衡未?”我有些...
    開封第一講書人閱讀 165,830評論 0 356
  • 文/不壞的土叔 我叫張陵尸执,是天一觀的道長。 經(jīng)常有香客問我缓醋,道長如失,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,957評論 1 295
  • 正文 為了忘掉前任送粱,我火速辦了婚禮褪贵,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘抗俄。我一直安慰自己脆丁,他們只是感情好,可當我...
    茶點故事閱讀 67,974評論 6 393
  • 文/花漫 我一把揭開白布动雹。 她就那樣靜靜地躺著槽卫,像睡著了一般。 火紅的嫁衣襯著肌膚如雪洽胶。 梳的紋絲不亂的頭發(fā)上晒夹,一...
    開封第一講書人閱讀 51,754評論 1 307
  • 那天,我揣著相機與錄音姊氓,去河邊找鬼。 笑死喷好,一個胖子當著我的面吹牛翔横,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播梗搅,決...
    沈念sama閱讀 40,464評論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼禾唁,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了无切?” 一聲冷哼從身側(cè)響起荡短,我...
    開封第一講書人閱讀 39,357評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎哆键,沒想到半個月后掘托,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,847評論 1 317
  • 正文 獨居荒郊野嶺守林人離奇死亡籍嘹,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,995評論 3 338
  • 正文 我和宋清朗相戀三年闪盔,在試婚紗的時候發(fā)現(xiàn)自己被綠了弯院。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 40,137評論 1 351
  • 序言:一個原本活蹦亂跳的男人離奇死亡泪掀,死狀恐怖听绳,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情异赫,我是刑警寧澤椅挣,帶...
    沈念sama閱讀 35,819評論 5 346
  • 正文 年R本政府宣布,位于F島的核電站塔拳,受9級特大地震影響贴妻,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜蝙斜,卻給世界環(huán)境...
    茶點故事閱讀 41,482評論 3 331
  • 文/蒙蒙 一名惩、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧孕荠,春花似錦娩鹉、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,023評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至个曙,卻和暖如春锈嫩,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背垦搬。 一陣腳步聲響...
    開封第一講書人閱讀 33,149評論 1 272
  • 我被黑心中介騙來泰國打工呼寸, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人猴贰。 一個月前我還...
    沈念sama閱讀 48,409評論 3 373
  • 正文 我出身青樓对雪,卻偏偏與公主長得像,于是被迫代替她去往敵國和親米绕。 傳聞我的和親對象是個殘疾皇子瑟捣,可洞房花燭夜當晚...
    茶點故事閱讀 45,086評論 2 355

推薦閱讀更多精彩內(nèi)容