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

MySQL讀寫分離的項(xiàng)目時(shí)間實(shí)踐

 更新時(shí)間:2025年03月06日 10:58:24   作者:Bean295  
本文主要介紹了MySQL數(shù)據(jù)庫(kù)的讀寫分離技術(shù),包括一主一從和雙主雙從兩種架構(gòu),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧

讀寫分離,簡(jiǎn)單地說(shuō)是把對(duì)數(shù)據(jù)庫(kù)的讀和寫操作分開(kāi),以對(duì)應(yīng)不同的數(shù)據(jù)庫(kù)服務(wù)器。主數(shù)據(jù)庫(kù)提供寫操作,從數(shù)據(jù)庫(kù)提供讀操作,這樣能有效地減輕單臺(tái)數(shù)據(jù)庫(kù)的壓力。

一、一主一從讀寫分離

1、一主一從原理:

MySQL的主從復(fù)制,是基于二進(jìn)制日志(binlog)實(shí)現(xiàn)的。

10.1.1.10 :master

10.1.1.20 :slave

檢查主從同步是否生效:

2、一主一從讀寫分離

(1) 介紹:

MyCat控制后臺(tái)數(shù)據(jù)庫(kù)的讀寫分離和負(fù)載均衡由schema.xml文件datahost標(biāo)簽的balance屬性控制。

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

(2) 配置:

① 修改 schema.xml:

② 修改 server.xml:

③ 啟動(dòng)mycat:

balance 值設(shè)置為3,所有的讀操作均由從庫(kù)承擔(dān),從庫(kù)的數(shù)據(jù)變更不會(huì)同步到從庫(kù)。如果從庫(kù)與主庫(kù)上的數(shù)據(jù)不一致,mycat查詢數(shù)據(jù)得到的結(jié)果是從庫(kù)中的數(shù)據(jù)。

加入主庫(kù)宕機(jī),查詢操作不受影響,但插入、更新等操作則無(wú)法實(shí)現(xiàn)。

二、雙主雙從讀寫分離

1、雙主雙從搭建:

(1) 介紹:

一個(gè)主機(jī) Master1 用于處理所有寫請(qǐng)求,它的從機(jī) Slave1 和另一臺(tái)主機(jī) Master2 還有它的從機(jī) Slave2 負(fù)責(zé)所有讀請(qǐng)求。當(dāng) Master1 主機(jī)宕機(jī)后,Master2 主機(jī)負(fù)責(zé)寫請(qǐng)求,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) 主庫(kù)配置:

① master1(10.1.1.30)

● 修改配置文件:

vim /etc/my.cnf

#mysql 服務(wù)ID,保證整個(gè)集群環(huán)境中唯一,取值范圍:1 – 2^32-1,默認(rèn)為1
server-id=1
#指定同步的數(shù)據(jù)庫(kù)
binlog-do-db=db01
binlog-do-db=db02
binlog-do-db=db03

# 在作為從數(shù)據(jù)庫(kù)的時(shí)候,有寫入操作也要更新二進(jìn)制日志文件

log-slave-updates

log-slave-updates:雙主雙從結(jié)構(gòu)下,兩個(gè)主庫(kù)不僅互為對(duì)方的從庫(kù),也有自己的從庫(kù),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) 從庫(kù)配置:

① slave1(10.1.1.50)

● 修改配置文件

vim /etc/my.cnf

#mysql 服務(wù)ID,保證整個(gè)集群環(huán)境中唯一,取值范圍:1 – 23^2-1,默認(rèn)為1

server-id=2

systemctl restart mysqld

● 關(guān)聯(lián)對(duì)應(yīng)的主庫(kù):

CHANGE MASTER TO MASTER_HOST='10.1.1.30', MASTER_USER='itcast', MASTER_PASSWORD='6666', MASTER_LOG_FILE='binlog.000010', MASTER_LOG_POS=663;

● 啟動(dòng)主從復(fù)制,查看從庫(kù)狀態(tài):

start slave;

show slave status \G;

② slave2(10.1.1.60)

● 修改配置文件

vim /etc/my.cnf

#mysql 服務(wù)ID,保證整個(gè)集群環(huán)境中唯一,取值范圍:1 – 23^2-1,默認(rèn)為1

server-id=4

systemctl restart mysqld

● 關(guān)聯(lián)對(duì)應(yīng)的主庫(kù):

CHANGE MASTER TO MASTER_HOST='10.1.1.40', MASTER_USER='itcast', MASTER_PASSWORD='6666', MASTER_LOG_FILE='binlog.000009', MASTER_LOG_POS=663;

● 啟動(dòng)主從復(fù)制,查看從庫(kù)狀態(tài):

start slave;

show slave status \G;

(4) 兩臺(tái)主庫(kù)互相復(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) 測(cè)試:

在master1上創(chuàng)庫(kù)創(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控制后臺(tái)數(shù)據(jù)庫(kù)的讀寫分離和負(fù)載均衡由schema.xml文件datahost標(biāo)簽的balance屬性控制,通過(guò)writeType及switchType來(lái)完成失敗自動(dòng)切換的。

(2) 配置:

① 配置 schema.xml:

配置邏輯庫(kù)和數(shù)據(jù)節(jié)點(diǎn):

配置節(jié)點(diǎn)主機(jī):

● balance="1" :代表全部的 readHost 與 stand by writeHost 參與 select 語(yǔ)句的負(fù)載均衡,即 M2,S1,S2 都參與 select 語(yǔ)句的負(fù)載均衡。

● writeType 0:寫操作都轉(zhuǎn)發(fā)到第1臺(tái)writeHost,writeHost1掛了會(huì)切換到writeHost2上;1:所有的寫操作都隨機(jī)地發(fā)送到配置的writeHost上。

● switchType -1 : 不自動(dòng)切換 ;1 : 自動(dòng)切換。

② 修改 server.xml:

③ 重啟啟動(dòng)mycat進(jìn)行測(cè)試:

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

到此這篇關(guān)于MySQL讀寫分離的項(xiàng)目時(shí)間實(shí)踐的文章就介紹到這了,更多相關(guān)MySQL讀寫分離內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • mysql 8.0.25 安裝配置方法圖文教程

    mysql 8.0.25 安裝配置方法圖文教程

    這篇文章主要為大家詳細(xì)介紹了mysql 8.0.25 安裝配置方法圖文教程,文中安裝步驟介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-07-07
  • Mysql聯(lián)合索引的原理與實(shí)現(xiàn)

    Mysql聯(lián)合索引的原理與實(shí)現(xiàn)

    聯(lián)合索引是一種將多個(gè)列組合成一個(gè)索引的技術(shù),以提高基于這些列進(jìn)行查詢的性能,本文主要介紹了Mysql聯(lián)合索引的原理與實(shí)現(xiàn),具有一定的參考價(jià)值,感興趣的可以了解一下
    2024-08-08
  • Mysql配置主從復(fù)制-GTID模式詳解

    Mysql配置主從復(fù)制-GTID模式詳解

    這篇文章主要介紹了Mysql配置主從復(fù)制-GTID模式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-04-04
  • mysql8如何設(shè)置不區(qū)分大小寫ubuntu20

    mysql8如何設(shè)置不區(qū)分大小寫ubuntu20

    這篇文章主要介紹了mysql8如何設(shè)置不區(qū)分大小寫ubuntu20問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-05-05
  • CentOS 7下安裝與配置MySQL 5.7

    CentOS 7下安裝與配置MySQL 5.7

    Mysql5.7和之前版本的MySQL有一些不同,現(xiàn)把CentOS 7下MySQL 5.7安裝、配置完整過(guò)程記下來(lái),或許對(duì)新手來(lái)說(shuō)有用。希望大家能夠喜歡
    2018-01-01
  • 讀取mysql一個(gè)庫(kù)下面的所有的表table

    讀取mysql一個(gè)庫(kù)下面的所有的表table

    本文給大家分享的是如何使用php實(shí)現(xiàn)讀取mysql一個(gè)庫(kù)下面的所有的表table的代碼,有需要的小伙伴可以參考下
    2016-12-12
  • sql跨表查詢的三種方案總結(jié)

    sql跨表查詢的三種方案總結(jié)

    這篇文章主要介紹了sql跨表查詢的三種方案總結(jié),文章圍繞主題展開(kāi)詳細(xì)的內(nèi)容,具有一定的參考價(jià)值,需要的小伙伴可以參考一下,希望對(duì)你的學(xué)習(xí)有所幫助
    2022-08-08
  • SQL中字符串截取函數(shù)圖文教程

    SQL中字符串截取函數(shù)圖文教程

    在SQL的實(shí)際用途中,經(jīng)常會(huì)碰到需要對(duì)查詢結(jié)果值需要做字段的一些截取,下面這篇文章主要給大家介紹了關(guān)于SQL中字符串截取函數(shù)的相關(guān)資料,需要的朋友可以參考下
    2023-01-01
  • MySQL事務(wù)(transaction)看這篇就足夠了

    MySQL事務(wù)(transaction)看這篇就足夠了

    M事務(wù)的實(shí)現(xiàn)是基于數(shù)據(jù)庫(kù)的存儲(chǔ)引擎,不同的存儲(chǔ)引擎對(duì)事務(wù)的支持程度不一樣,下面這篇文章主要給大家介紹了關(guān)于MySQL事務(wù)(transaction)的相關(guān)資料,需要的朋友可以參考下
    2022-11-11
  • Mysql數(shù)據(jù)庫(kù)亂碼問(wèn)題的對(duì)應(yīng)方式

    Mysql數(shù)據(jù)庫(kù)亂碼問(wèn)題的對(duì)應(yīng)方式

    今天小編就為大家分享一篇關(guān)于Mysql數(shù)據(jù)庫(kù)亂碼問(wèn)題的對(duì)應(yīng)方式,小編覺(jué)得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧
    2018-12-12

最新評(píng)論