基于mycat的mysql主從讀寫分離配置詳解與示例-正能量_第1頁(yè)
基于mycat的mysql主從讀寫分離配置詳解與示例-正能量_第2頁(yè)
基于mycat的mysql主從讀寫分離配置詳解與示例-正能量_第3頁(yè)
已閱讀5頁(yè),還剩2頁(yè)未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡(jiǎn)介

1、基于 Mycat 開源數(shù)據(jù)庫(kù)中間件數(shù)據(jù)庫(kù)主從讀寫分離配置詳解與示例參考文檔:Mycat指南本文說明:根據(jù)心跳問題 heartbeat bug #393,做了修正,請(qǐng)使用附件中的 Mycat 安裝包:Mycat-Server-1.4-RC-Linux-RW-20150721.tar.gz或者將附件中的 Mycat-server-1.4-RC.jar 更新到 Mycat 安裝目錄下的 lib 目錄,替換原文件一、主服務(wù)器 Master 配置1、修改主服務(wù)器配置:#vifbinlog-do-db=db1binlog-do-db=db2 binlog-do-db=db3 binlog-ignore-d

2、b =ysql-bin#啟用二進(jìn)制日志log-b#服務(wù)器唯一 ID,一般取 IP 最后一段server-id=1582、重啟/etc/init.d/restart3、建立帳戶并slave:#/usr/local/bysql -uroot -p123456GRANT FILE ON *.* TO backup% IDENTIFIED BY 123456;GRANT REPLICATION SLAVE, REPLICATION CNT ON *.* to backup% identified by123456;#一般不用 root 帳號(hào),“%”表示所有客戶端都可能連,只要帳號(hào),具體客戶端 IP 代

3、替,如 192.168.145.226,加強(qiáng)安全。正確,此處可用刷新權(quán)限 FLUSH PRIVILEGES;查看現(xiàn)在有哪些用戶select user,host from.user;4、登錄主服務(wù)器的,查詢 master 的狀態(tài) show master sus;+|+|+|+|File|itionBinlog_Do_DB|Binlog_Ignore_DB+-bin.000010|106|db1,db2,db3|+|+Master 重啟后會(huì)修改-bin(序號(hào)加 1)二、從服務(wù)器 Slave配置1、修改從服務(wù)器配置:#vifreplicate-do-db=db1replicate-do-db=db2

4、 replicate-do-db=db3 replicate-ignore-db=master-connect-retry=60server-id=78master-host=10.1.176.158 master-user=backupmastmastassword=123456ort=3306master-connect-retry=60#log-slave-updatesskip-slave-start#防止隨著啟動(dòng)而自動(dòng)啟動(dòng)。即 slave 端的服務(wù)重啟后需手動(dòng)來啟動(dòng)主從比較安全(slave start),最好加上,slave 端數(shù)據(jù)庫(kù)服務(wù)重啟后手動(dòng)啟動(dòng) slave2、重啟/etc/i

5、nit.d/restart3、登錄并停止 slave 服務(wù)# cd /usr/local/bin/-uroot p123456 或# ./# /usr/local/bysql -uroot p123456slave stop;設(shè)置與 master 服務(wù)器相關(guān)的配置參數(shù)changemastertomaster_host=10.1.176.158,master_user=backup,master_password=123456,MASTER_LOG_FILE=-bin.000015,MASTER_LOG_=106;注意:Master 重啟后 slave 要修改 MASTER_LOG_FILE,1

6、06 無單引號(hào)。啟動(dòng)從服務(wù)器功能start slave;ERROR 1201 (HY000):Could not initialize master info structure解決方案是:運(yùn)行命令 stop slave;成功執(zhí)行后繼續(xù)運(yùn)行 reset slave;4、檢查從服務(wù)器功能狀態(tài) show slave susG以下兩個(gè)參數(shù)必須為 YES: Slave_IO_Running: YesSlave_SQL_Running: Yes返回如下:* 1. row * Slave_IO_Se: Waiting for master to send eventMaster_Host: 10.1.17

7、6.158 Master_User: backupMaster_Port: 3306Connect_Retry: 60Master_Log_File:Read_Master_Log_-bin.000010: 106Relay_Log_File: bogon-relay-bin.000002Relay_Log_Relay_Master_Log_File: 251-bin.000010Slave_IO_Running: YesSlave_SQL_Running: YesReplicate_Do_DB: db1,db2,db3 Replicate_Ignore_DB:Replicate_Do_Tab

8、le: Replicate_Ignore_Table: Replicate_Wild_Do_Table:Replicate_Wild_Ignore_Table:Last_Errno: 0 Last_Error:Skip_Counter: 0Exec_Master_Log_: 106Relay_Log_Space: 406Until_Condition: None Until_Log_File:Until_Log_: 0Master_SSL_Allowed: NoMaster_SSL_CA_File: Master_SSL_CA_Path:Master_SSL_Cert: Master_SSL_

9、Cipher: Master_SSL_Key:Seconds_Behind_Master: 0 Master_SSL_Verify_Server_Cert: NoLast_IO_Errno: 0 Last_IO_Error: Last_SQL_Errno: 0 Last_SQL_Error:1 row in set (0.00 sec)三、數(shù)據(jù)庫(kù)中間件 Mycat 配置1、不使用 Mycat 托管主從服務(wù)器,簡(jiǎn)單使用如下配置dataNodedataNodedataNode/name=localhost1 maxCon=1000 minCon=10 balance=0writeType=0 db

10、Type=slaveThreshold=100 dbDriver=native switchType=1select user()2、Mycat 1.4 支持主從狀態(tài)綁定的讀寫分離機(jī)制,讓讀更加安全可靠,配置如下:dataNodedataNodedataNode/name=localhost1maxCon=1000 minCon=10 balance=1 dbDriver=native switchType=2writeType=0 dbType=slaveThreshold=100show slave susurl=10.1.176.158:3306 user=root(1) 設(shè)置 bala

11、nce=1與 writeType=0Balance 參數(shù)設(shè)置:1. balance=“0”, 所有讀操作都發(fā)送到當(dāng)前可用的 writeHost 上。2. balance=“1”,所有讀操作都隨機(jī)的發(fā)送到 readHost。3. balance=“2”,所有讀操作都隨機(jī)的在 writeHost、readhost 上分發(fā)WriteType 參數(shù)設(shè)置:1. writeType=“0”, 所有寫操作都發(fā)送到可用的 writeHost 上。2. writeType=“1”,所有寫操作都隨機(jī)的發(fā)送到 readHost。3. writeType=“2”,所有寫操作都隨機(jī)的在 writeHost、readho

12、st 分上發(fā)?!皉eadHost 是從屬于 writeHost 的,即意味著它從那個(gè) writeHost 獲取同步數(shù)據(jù),因此,當(dāng)它所屬的 writeHost 宕機(jī)了,則它也不會(huì)再參與到讀寫分離中來,即“不工作了”,這是因?yàn)榇藭r(shí),它的數(shù)據(jù)已經(jīng)“不可靠”了。基于這個(gè)考慮,目前 mycat 1.3 和1.4 版本中,若想支持一主一從的標(biāo)準(zhǔn)配置,并且在主節(jié)點(diǎn)宕機(jī)的情況下,從節(jié)點(diǎn)還能數(shù)據(jù),則需要在 Mycat 里配置為兩個(gè) writeHost 并設(shè)置 banlance=1?!?2) 設(shè)置 switchType=2 與 slaveThreshold=100“Mycat 心跳檢查語(yǔ)句配置為 show sla

13、ve sus ,dataHost 上定義兩個(gè)新屬性:switchType=2 與 slaveThreshold=100,此時(shí)意味著開啟主從狀態(tài)綁定的讀寫分離與切換機(jī)制。Mycat 心跳機(jī)制通過檢測(cè) show slave sus 中的Seconds_Behind_Master, Slave_IO_Running, Slave_SQL_Running三個(gè)字段來確定當(dāng)前主從同步的狀態(tài)以及 Seconds_Behind_Master 主從時(shí)延?!八摹⒅鲝臏y(cè)試,執(zhí)行以下命令 explain create table company(idnot null primarykey,name varchar(1

14、00);+|+|+ 3+|+|+DATA_NODE |+SQLdn1 dn2dn3|+create createcreatetable tabletablecompany(id company(idcompany(idnot notnotnull nullnullprimary primaryprimarykey,name key,namekey,namevarchar(100) varchar(100)varchar(100)rows inset(0.32 sec) createtable company(idnotnull primary key,name varchar(100);Query

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。

評(píng)論

0/150

提交評(píng)論