mycat做Mysql的讀寫分離

在MySQL中間件出現(xiàn)之前,對(duì)于MySQL主從集群,如果要實(shí)現(xiàn)其讀寫分離,一般是在程序端實(shí)現(xiàn),這樣就帶來一個(gè)問題,即數(shù)據(jù)庫和程序的耦合度太高,如果我數(shù)據(jù)庫的地址發(fā)生改變了,那么我程序端也要進(jìn)行相應(yīng)的修改,如果數(shù)據(jù)庫不小心掛掉了,則同時(shí)也意味著程序的不可用,而這對(duì)很多應(yīng)用來說,并不能接受。

成都創(chuàng)新互聯(lián)公司是專業(yè)的荊州網(wǎng)站建設(shè)公司,荊州接單;提供成都網(wǎng)站建設(shè)、網(wǎng)站制作,網(wǎng)頁設(shè)計(jì),網(wǎng)站設(shè)計(jì),建網(wǎng)站,PHP網(wǎng)站建設(shè)等專業(yè)做網(wǎng)站服務(wù);采用PHP框架,可快速的進(jìn)行荊州網(wǎng)站開發(fā)網(wǎng)頁制作和功能擴(kuò)展;專業(yè)做搜索引擎喜愛的網(wǎng)站,專業(yè)的做網(wǎng)站團(tuán)隊(duì),希望更多企業(yè)前來合作!

引入MySQL中間件能很好的對(duì)程序端和數(shù)據(jù)庫進(jìn)行解耦,這樣,程序端只需關(guān)注數(shù)據(jù)庫中間件的地址,而無需知曉底層數(shù)據(jù)庫是如何提供服務(wù)。

作為當(dāng)前炙手可熱的MySQL中間件,MyCAT實(shí)現(xiàn)MySQL主從集群的讀寫分離自是應(yīng)有之義,其配置也相當(dāng)簡單。

在這里,我用三個(gè)實(shí)例組成MySQL主從集群,來驗(yàn)證MyCAT的讀寫分離功能,其實(shí),一主一從就可以滿足,之所以用三個(gè),是為了驗(yàn)證MyCAT的分片功能。

集群組成如下:

角色 主機(jī)名 主機(jī)IP

master mysql-server1 192.168.1.5

slave mysql-server2 192.168.1.6

slave mysql-server3 192.168.1.4

在這里,還是使用Travelrecord表進(jìn)行測試。

首先編輯MyCAT的配置文件schema.xml,關(guān)于dataHost的配置信息如下:


<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="MYM1" url="192.168.1.5:3307" user="root"
                        password="lichao">
                </writeHost>
                <writeHost host="MYS1" url="192.168.1.6:3307" user="root"
                        password="lichao" />
                <writeHost host="MYS2" url="192.168.1.4:3307" user="root"                      
                        password="123456" />
</dataHost>

這里面,有兩個(gè)參數(shù)需要注意,balance和 switchType。

其中,balance指的負(fù)載均衡類型,目前的取值有4種:

  • 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",所有讀請(qǐng)求隨機(jī)的分發(fā)到wiriterHost對(duì)應(yīng)的readhost執(zhí)行,writerHost不負(fù)擔(dān)讀壓力

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

  • switchType='-1' 表示不自動(dòng)切換
  • switchType='1' 默認(rèn)值,表示自動(dòng)切換
  • switchType='2' 基于MySQL主從同步的狀態(tài)決定是否切換,心跳語句為 show slave status
  • switchType='3'基于MySQL galary cluster的切換機(jī)制(適合集群)(1.4.1),心跳語句為 show status like 'wsrep%'。

因此,該配置文件中的balance="1"意味著作為stand by writeHost的hostS1和hostS2將參與select語句的負(fù)載均衡,這就實(shí)現(xiàn)了主從的讀寫分離,switchType='-1'意味著當(dāng)主掛掉的時(shí)候,不進(jìn)行自動(dòng)切換,即hostS1和hostS2并不會(huì)被提升為主,仍只提供讀的功能。這就避免了將數(shù)據(jù)寫進(jìn)slave的可能性,畢竟,單純的MySQL主從集群并不允許將數(shù)據(jù)讀進(jìn)slave中,除非配置的是雙master

驗(yàn)證讀寫分離

下面來驗(yàn)證一下,

創(chuàng)建Travelrecord表

create table travelrecord (id bigint not null primary key,user_id varchar(100),traveldate DATE, fee decimal,days int);`

插入數(shù)據(jù)

mysql> insert into travelrecord(id,user_id,traveldate,fee,days) values(1,@@hostname,20160101,100,10);
Query OK, 1 row affected, 1 warning (0.02 sec)

mysql> insert into travelrecord(id,user_id,traveldate,fee,days) values(5000001,@@hostname,20160102,100,10);
Query OK, 1 row affected, 1 warning (0.01 sec)

在這里,用了一個(gè)取巧的方法,即對(duì)user_id插入了當(dāng)前實(shí)例的主機(jī)名,這樣可直觀的觀察讀寫是否分離以及MyCAT的分片功能。能這樣做的原因在于我當(dāng)前的MySQL版本-5.6.26默認(rèn)是基于statement的復(fù)制,如果是基于row的復(fù)制,則這個(gè)方法將不可取。

查詢數(shù)據(jù)

mysql> select * from travelrecord;
+---------+---------------+------------+------+------+
| id | user_id | traveldate | fee | days |
+---------+---------------+------------+------+------+
| 1 | mysql-server2 | 2016-01-01 | 100 | 10 |
| 5000001 | mysql-server3 | 2016-01-02 | 100 | 10 |
+---------+---------------+------------+------+------+
rows in set (0.01 sec)

mysql> select * from travelrecord;
+---------+---------------+------------+------+------+
| id | user_id | traveldate | fee | days |
+---------+---------------+------------+------+------+
| 5000001 | mysql-server3 | 2016-01-02 | 100 | 10 |
| 1 | mysql-server2 | 2016-01-01 | 100 | 10 |
+---------+---------------+------------+------+------+
rows in set (0.02 sec)

mysql> select * from travelrecord;
+---------+---------------+------------+------+------+
| id | user_id | traveldate | fee | days |
+---------+---------------+------------+------+------+
| 5000001 | mysql-server3 | 2016-01-02 | 100 | 10 |
| 1 | mysql-server3 | 2016-01-01 | 100 | 10 |
+---------+---------------+------------+------+------+
rows in set (0.01 sec)

mysql> select * from travelrecord;
+---------+---------------+------------+------+------+
| id | user_id | traveldate | fee | days |
+---------+---------------+------------+------+------+
| 5000001 | mysql-server3 | 2016-01-02 | 100 | 10 |
| 1 | mysql-server3 | 2016-01-01 | 100 | 10 |
+---------+---------------+------------+------+------+
rows in set (0.01 sec)

mysql> select * from travelrecord;
+---------+---------------+------------+------+------+
| id | user_id | traveldate | fee | days |
+---------+---------------+------------+------+------+
| 1 | mysql-server2 | 2016-01-01 | 100 | 10 |
| 5000001 | mysql-server2 | 2016-01-02 | 100 | 10 |
+---------+---------------+------------+------+------+

從上面的輸出結(jié)果,可以得出以下兩點(diǎn):

一、該配置已實(shí)現(xiàn)讀寫分離,讀出來的數(shù)據(jù)沒有master節(jié)點(diǎn)的。

二、MyCAT的隨機(jī)分發(fā)不是基于statement的,即一個(gè)select語句查詢其中一個(gè)節(jié)點(diǎn),另外一個(gè)select語句查詢另外一個(gè)節(jié)點(diǎn)。它分發(fā)針對(duì)的是片的,同一個(gè)select語句的結(jié)果是有不同dataNode返回的。

不僅如此,從MyCAT日志中也可以獲取讀寫分離的相關(guān)信息,當(dāng)然,前提是MyCAT的日志級(jí)別是debug。日志相關(guān)信息如下:

mycat做Mysql的讀寫分離

驗(yàn)證mater掛了,slave還能提供讀的功能

對(duì)于MySQL主從集群,我們的需求是master掛了,slave還能提供讀的功能。

下面來測試一下

首先,人為的關(guān)閉主庫

[root@mysql-server1 ~]# /etc/init.d/mysqld stop

登錄MyCAT

[root@mysql-server1 ~]# mysql -utest -ptest -h227.0.0.1 -P8066 -DTESTDB

插入數(shù)據(jù)

mysql> insert into travelrecord(id,user_id,traveldate,fee,days) values(10000001,@@hostname,20160103,100,10);
ERROR 1184 (HY000): Connection refused
mysql> select * from travelrecord;
+---------+---------------+------------+------+------+
| id | user_id | traveldate | fee | days |
+---------+---------------+------------+------+------+
| 1 | mysql-server2 | 2016-01-01 | 100 | 10 |
| 5000001 | mysql-server3 | 2016-01-02 | 100 | 10 |
+---------+---------------+------------+------+------+
rows in set (0.02 sec)

可見無法插入數(shù)據(jù),但不影響讀取數(shù)據(jù)。

至此,MyCAT實(shí)現(xiàn)MySQL的讀寫分離部署測試完畢。

總結(jié):

  1. 其實(shí),剛開始配置的是readHost節(jié)點(diǎn),配置如下:

<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="MYM1" url="192.168.1.5:3307" user="root"
password="lichao">
<!-- can have multi read hosts -->
<readHost host="MYS1" url="192.168.1.6:3307" user="root" password="lichao" />
</writeHost>
</dataHost>

但這種方式有個(gè)問題,即master掛了以后,slave也不能提供服務(wù),而這違反了MySQL主從集群的初衷。

  1. 如果開啟了事務(wù)模式,即set autocommit=0,則事務(wù)內(nèi)的讀走的是master節(jié)點(diǎn),而不是從節(jié)點(diǎn)。

文章名稱:mycat做Mysql的讀寫分離
當(dāng)前URL:http://muchs.cn/article36/gcidsg.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供營銷型網(wǎng)站建設(shè)域名注冊(cè)、響應(yīng)式網(wǎng)站網(wǎng)站營銷、ChatGPT、App開發(fā)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

成都定制網(wǎng)站網(wǎng)頁設(shè)計(jì)