一、MySQL的主從切換在什么情況下使用
主從切換一般在如下情況下才進(jìn)行:
1、例行的主庫(kù)重啟,主庫(kù)運(yùn)行一段時(shí)間后需要將主庫(kù)進(jìn)行重啟掃盤(pán),降低主庫(kù)死機(jī)的風(fēng)險(xiǎn);
2、主庫(kù)異常情況下切到從庫(kù)。
3、分機(jī)房網(wǎng)絡(luò)調(diào)整涉及到主庫(kù)的情況。
你的情況要看宕掉后的情況。如果有期間同步延遲,需要另外進(jìn)行處理。
在開(kāi)始切換之前先對(duì)主庫(kù)進(jìn)行鎖表:
flush tables with read lock
(在執(zhí)行完成后生產(chǎn)環(huán)境必須等待所有語(yǔ)句執(zhí)行完成)
在flush tables with read lock成功獲得鎖之前,必須等待所有語(yǔ)句執(zhí)行完成(包括SELECT)。所以如果有個(gè)慢查詢(xún)?cè)趫?zhí)行,或者一個(gè)打開(kāi)的事務(wù),或者其他進(jìn)程拿著表鎖,flush tables with read lock就會(huì)被阻塞,直到所有的鎖被釋放。
延伸閱讀:
二、什么是數(shù)據(jù)庫(kù)和數(shù)據(jù)庫(kù)管理系統(tǒng)
數(shù)據(jù)庫(kù)的應(yīng)用非常廣泛,舉個(gè)例子,我們平時(shí)在瀏覽器上搜索內(nèi)容,就要用到數(shù)據(jù)庫(kù)去檢索我們的關(guān)鍵字。以前我們可能會(huì)用數(shù)組、集合、文件等來(lái)存儲(chǔ)數(shù)據(jù),但是接下來(lái)我們就會(huì)面臨一個(gè)問(wèn)題,當(dāng)存儲(chǔ)的數(shù)據(jù)或內(nèi)容過(guò)多的時(shí)候,我們?nèi)绾稳ゾ珳?zhǔn)的找到我們需要的東西,這時(shí)候數(shù)據(jù)庫(kù)管理系統(tǒng)就派上了用場(chǎng)。除此之外,數(shù)據(jù)庫(kù)管理系統(tǒng)還能永久的儲(chǔ)存我們的數(shù)據(jù)。
為了便于大家理解,這里先給大家講解幾個(gè)概念
DB數(shù)據(jù)庫(kù)(database):存儲(chǔ)數(shù)據(jù)的“倉(cāng)庫(kù)”。它保存了一系列有組織的數(shù)據(jù)。
DBMS數(shù)據(jù)庫(kù)管理系統(tǒng)(Database Management System):數(shù)據(jù)庫(kù)是通過(guò)DBMS創(chuàng)建和操作的容器。
SQL,結(jié)構(gòu)化查詢(xún)語(yǔ)言(Structured Query Language)用一句話(huà)概括,SQL是一種特殊目的的編程語(yǔ)言,一種專(zhuān)門(mén)用來(lái)與數(shù)據(jù)庫(kù)通信的語(yǔ)言。在數(shù)據(jù)庫(kù)中,數(shù)據(jù)被結(jié)構(gòu)化并存儲(chǔ)在不同的表中,從而簡(jiǎn)化了訪問(wèn),更新和操作數(shù)據(jù)的過(guò)程。該表由列和行組成。數(shù)據(jù)庫(kù)中的表可以在關(guān)系的幫助下進(jìn)行連接。要在數(shù)據(jù)庫(kù)中執(zhí)行與數(shù)據(jù)相關(guān)的任務(wù),可以使用SQL。SQL代表結(jié)構(gòu)化查詢(xún)語(yǔ)言,旨在在特定RDBMS內(nèi)創(chuàng)建,修改和管理數(shù)據(jù)庫(kù)中的數(shù)據(jù)。
SQL優(yōu)點(diǎn):
1、不是某個(gè)特定數(shù)據(jù)庫(kù)供應(yīng)商專(zhuān)有的語(yǔ)言,幾乎所有DBMS(數(shù)據(jù)庫(kù)管理系統(tǒng))都支持SQL
2、簡(jiǎn)單易學(xué)
3、雖然簡(jiǎn)單,但實(shí)際上是一種強(qiáng)有力的語(yǔ)言,靈活使用其語(yǔ)言元素,可以進(jìn)行非常復(fù)雜和高級(jí)的數(shù)據(jù)庫(kù)操作。