本篇內(nèi)容主要講解“MySQL讀寫分離基本原理是什么”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“MySQL讀寫分離基本原理是什么”吧!
站在用戶的角度思考問題,與客戶深入溝通,找到東明網(wǎng)站設計與東明網(wǎng)站推廣的解決方案,憑借多年的經(jīng)驗,讓設計與互聯(lián)網(wǎng)技術結合,創(chuàng)造個性化、用戶體驗好的作品,建站類型包括:成都網(wǎng)站建設、做網(wǎng)站、企業(yè)官網(wǎng)、英文網(wǎng)站、手機端網(wǎng)站、網(wǎng)站推廣、國際域名空間、網(wǎng)絡空間、企業(yè)郵箱。業(yè)務覆蓋東明地區(qū)。
在一些大型網(wǎng)站業(yè)務場景中,單臺數(shù)據(jù)庫服務器所能提供的并發(fā)量已經(jīng)無法滿足業(yè)務需求,為了滿足這種情況,一般而言是通過主從同步的方式來同步數(shù)據(jù),在此基礎上,通過讀寫分離來提升數(shù)據(jù)庫的并發(fā)和負載能力。
一般而言,業(yè)務場景下對數(shù)據(jù)庫的查詢操作要遠遠高于增、刪和改,并且讀操作對數(shù)據(jù)庫的影響要更小。因此,我們一般會設置一臺數(shù)據(jù)庫服務器作為主服務器,主要承擔數(shù)據(jù)的增、刪和改的任務,配置3-4臺數(shù)據(jù)庫服務器為從服務器,主要承擔數(shù)據(jù)的查詢?nèi)蝿?。?shù)據(jù)庫從服務器從數(shù)據(jù)庫主服務器中同步數(shù)據(jù),以此實現(xiàn)數(shù)據(jù)的一致性。
根據(jù)讀寫分離實現(xiàn)的層級,讀寫分離一般有兩種方式實現(xiàn),通過應用程序?qū)訉崿F(xiàn)和通過中間件層實現(xiàn)。
通過應用程序?qū)訉崿F(xiàn)是指在網(wǎng)頁內(nèi)部實現(xiàn)數(shù)據(jù)查詢語言和數(shù)據(jù)操作語言分別指向不同的MySQL主庫和從庫。通過應用程序?qū)訉崿F(xiàn)的MySQL讀寫分離圖解如下:
這樣做的優(yōu)點是減少了部署的難度,部署安裝即用,且性能較好,缺點是當架構拓展時也要修改代碼,難以實現(xiàn)自動分庫、分表等高級操作,在一些大型應用場景中不是很適用。
通過中間件層實現(xiàn)是指在應用程序?qū)咏y(tǒng)一將所有的SQL語句指向一個中間件設備,由該中間件設備將不同的SQL語句指向不同的數(shù)據(jù)庫服務器進行操作。通過中間件層實現(xiàn)讀寫分離圖解如下:
這樣做的優(yōu)點是架構設計更加靈活,對業(yè)務代碼影響較小,可移植性好,并且可以實現(xiàn)高級控制,但是這種架構需要專業(yè)的運維人員對架構進行維護。
常用的讀寫分離中間件程序有以下種:
1、cobar
阿里B2B開發(fā)的關系型分布式系統(tǒng),是一款早期的中間件,后來因開發(fā)者離職而無人維護。
2、MyCAT
技術愛好者在cobar的基礎上進行了二次開發(fā),解決了cobar的一些問題,并加入了一些新功能,目前MyCAT社區(qū)活躍度較高,也有很多公司在使用MyCAT。
3、OneProxy
Oneproxy是一款商業(yè)收費的中間件,由支付寶團隊開發(fā),在高并發(fā)場景下十分穩(wěn)定。
4、Vitess
該中間件架構復雜,且使用Vitess需要使用其所提供的API接口。
5、Kingshard
由360團隊開發(fā),支持分庫分表,但是在高并發(fā)情況下穩(wěn)定性一般。
6、MaxScale和MySQL Route
這兩者均為MySQL官方中間件。Maxscale是Mariadb研發(fā)的,MySQL Route是現(xiàn)在Oracle公司為MySQL數(shù)據(jù)庫發(fā)布的中間件。
到此,相信大家對“MySQL讀寫分離基本原理是什么”有了更深的了解,不妨來實際操作一番吧!這里是創(chuàng)新互聯(lián)網(wǎng)站,更多相關內(nèi)容可以進入相關頻道進行查詢,關注我們,繼續(xù)學習!