MySQL讀寫分離的項(xiàng)目時間實(shí)踐
讀寫分離,簡單地說是把對數(shù)據(jù)庫的讀和寫操作分開,以對應(yīng)不同的數(shù)據(jù)庫服務(wù)器。主數(shù)據(jù)庫提供寫操作,從數(shù)據(jù)庫提供讀操作,這樣能有效地減輕單臺數(shù)據(jù)庫的壓力。
一、一主一從讀寫分離
1、一主一從原理:
MySQL的主從復(fù)制,是基于二進(jìn)制日志(binlog)實(shí)現(xiàn)的。
10.1.1.10 :master
10.1.1.20 :slave

檢查主從同步是否生效:

2、一主一從讀寫分離
(1) 介紹:
MyCat控制后臺數(shù)據(jù)庫的讀寫分離和負(fù)載均衡由schema.xml文件datahost標(biāo)簽的balance屬性控制。

負(fù)載均衡策略 balance 配置:

(2) 配置:
① 修改 schema.xml:


② 修改 server.xml:

③ 啟動mycat:
balance 值設(shè)置為3,所有的讀操作均由從庫承擔(dān),從庫的數(shù)據(jù)變更不會同步到從庫。如果從庫與主庫上的數(shù)據(jù)不一致,mycat查詢數(shù)據(jù)得到的結(jié)果是從庫中的數(shù)據(jù)。
加入主庫宕機(jī),查詢操作不受影響,但插入、更新等操作則無法實(shí)現(xiàn)。

二、雙主雙從讀寫分離
1、雙主雙從搭建:
(1) 介紹:
一個主機(jī) Master1 用于處理所有寫請求,它的從機(jī) Slave1 和另一臺主機(jī) Master2 還有它的從機(jī) Slave2 負(fù)責(zé)所有讀請求。當(dāng) Master1 主機(jī)宕機(jī)后,Master2 主機(jī)負(fù)責(zé)寫請求,Master1 、 Master2 互為備機(jī)。
10.1.1.10 :mycat 服務(wù)器
10.1.1.30 :master1
10.1.1.40 :master2
10.1.1.50 :slave1
10.1.1.60 :slave2


(2) 主庫配置:
① master1(10.1.1.30)
● 修改配置文件:
vim /etc/my.cnf
#mysql 服務(wù)ID,保證整個集群環(huán)境中唯一,取值范圍:1 – 2^32-1,默認(rèn)為1 server-id=1 #指定同步的數(shù)據(jù)庫 binlog-do-db=db01 binlog-do-db=db02 binlog-do-db=db03
# 在作為從數(shù)據(jù)庫的時候,有寫入操作也要更新二進(jìn)制日志文件
log-slave-updates
log-slave-updates:雙主雙從結(jié)構(gòu)下,兩個主庫不僅互為對方的從庫,也有自己的從庫,slave1、2需要讀取master1、2的二進(jìn)制日志文件保證數(shù)據(jù)同步。

● 重啟mysql服務(wù)器:systemctl restart mysqld
● 創(chuàng)建賬戶并授權(quán):
CREATE USER 'itcast'@'%' IDENTIFIED WITH mysql_native_password BY'6666' ; GRANT REPLICATION SLAVE ON *.* TO 'itcast'@'%';
查看二進(jìn)制日志坐標(biāo):

② master2(10.1.1.40)
配置步驟與master1類似:
vim /etc/my.cnf
server-id=3 binlog-do-db=db01 binlog-do-db=db02 binlog-do-db=db03 log-slave-updates
systemctl restart mysqld CREATE USER 'itcast'@'%' IDENTIFIED WITH mysql_native_password BY'6666' ; GRANT REPLICATION SLAVE ON *.* TO 'itcast'@'%';

(3) 從庫配置:
① slave1(10.1.1.50)
● 修改配置文件
vim /etc/my.cnf
#mysql 服務(wù)ID,保證整個集群環(huán)境中唯一,取值范圍:1 – 23^2-1,默認(rèn)為1 server-id=2
systemctl restart mysqld
● 關(guān)聯(lián)對應(yīng)的主庫:
CHANGE MASTER TO MASTER_HOST='10.1.1.30', MASTER_USER='itcast', MASTER_PASSWORD='6666', MASTER_LOG_FILE='binlog.000010', MASTER_LOG_POS=663;
● 啟動主從復(fù)制,查看從庫狀態(tài):
start slave; show slave status \G;

② slave2(10.1.1.60)
● 修改配置文件
vim /etc/my.cnf
#mysql 服務(wù)ID,保證整個集群環(huán)境中唯一,取值范圍:1 – 23^2-1,默認(rèn)為1
server-id=4
systemctl restart mysqld
● 關(guān)聯(lián)對應(yīng)的主庫:
CHANGE MASTER TO MASTER_HOST='10.1.1.40', MASTER_USER='itcast', MASTER_PASSWORD='6666', MASTER_LOG_FILE='binlog.000009', MASTER_LOG_POS=663;
● 啟動主從復(fù)制,查看從庫狀態(tài):
start slave; show slave status \G;

(4) 兩臺主庫互相復(fù)制:
① master1:
CHANGE MASTER TO MASTER_HOST='10.1.1.40', MASTER_USER='itcast', MASTER_PASSWORD='6666', MASTER_LOG_FILE='binlog.000009', MASTER_LOG_POS=663;
start slave; show slave status \G;

② master2:
CHANGE MASTER TO MASTER_HOST='10.1.1.30', MASTER_USER='itcast', MASTER_PASSWORD='6666', MASTER_LOG_FILE='binlog.000010', MASTER_LOG_POS=663;
start slave; show slave status \G;

(5) 測試:
在master1上創(chuàng)庫創(chuàng)表,插入數(shù)據(jù):
create database db01; use db01; create table tb_user( id int(11) not null, name varchar(50) not null, sex varchar(1), primary key (id) )engine=innodb default charset=utf8; insert into tb_user(id,name,sex) values(1,'Tom','1'); insert into tb_user(id,name,sex) values(2,'Trigger','0'); insert into tb_user(id,name,sex) values(3,'Dawn','1'); insert into tb_user(id,name,sex) values(4,'Jack Ma','1'); insert into tb_user(id,name,sex) values(5,'Coco','0'); insert into tb_user(id,name,sex) values(6,'Jerry','1');


2、雙主雙從讀寫分離:
(1) 介紹:
MyCat控制后臺數(shù)據(jù)庫的讀寫分離和負(fù)載均衡由schema.xml文件datahost標(biāo)簽的balance屬性控制,通過writeType及switchType來完成失敗自動切換的。

(2) 配置:
① 配置 schema.xml:
配置邏輯庫和數(shù)據(jù)節(jié)點(diǎn):

配置節(jié)點(diǎn)主機(jī):
● balance="1" :代表全部的 readHost 與 stand by writeHost 參與 select 語句的負(fù)載均衡,即 M2,S1,S2 都參與 select 語句的負(fù)載均衡。
● writeType 0:寫操作都轉(zhuǎn)發(fā)到第1臺writeHost,writeHost1掛了會切換到writeHost2上;1:所有的寫操作都隨機(jī)地發(fā)送到配置的writeHost上。
● switchType -1 : 不自動切換 ;1 : 自動切換。

② 修改 server.xml:

③ 重啟啟動mycat進(jìn)行測試:

當(dāng)主節(jié)點(diǎn)master1宕機(jī)后,在mycat上執(zhí)行insert和select操作均不受影響,說明雙主雙從讀寫分離配置成功。

到此這篇關(guān)于MySQL讀寫分離的項(xiàng)目時間實(shí)踐的文章就介紹到這了,更多相關(guān)MySQL讀寫分離內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Mysql聯(lián)合索引的原理與實(shí)現(xiàn)
聯(lián)合索引是一種將多個列組合成一個索引的技術(shù),以提高基于這些列進(jìn)行查詢的性能,本文主要介紹了Mysql聯(lián)合索引的原理與實(shí)現(xiàn),具有一定的參考價值,感興趣的可以了解一下2024-08-08
mysql8如何設(shè)置不區(qū)分大小寫ubuntu20
這篇文章主要介紹了mysql8如何設(shè)置不區(qū)分大小寫ubuntu20問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-05-05
MySQL事務(wù)(transaction)看這篇就足夠了
M事務(wù)的實(shí)現(xiàn)是基于數(shù)據(jù)庫的存儲引擎,不同的存儲引擎對事務(wù)的支持程度不一樣,下面這篇文章主要給大家介紹了關(guān)于MySQL事務(wù)(transaction)的相關(guān)資料,需要的朋友可以參考下2022-11-11
Mysql數(shù)據(jù)庫亂碼問題的對應(yīng)方式
今天小編就為大家分享一篇關(guān)于Mysql數(shù)據(jù)庫亂碼問題的對應(yīng)方式,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧2018-12-12

