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

MySQL如何實(shí)現(xiàn)負(fù)載均衡功能

 更新時(shí)間:2019年06月26日 14:13:01   作者:課課家教育  
這篇文章主要介紹了MySQL如何實(shí)現(xiàn)負(fù)載均衡功能,學(xué)習(xí)過數(shù)據(jù)庫(kù)的朋友們都會(huì)知道MySQL,那么如何在MySQL下實(shí)現(xiàn)負(fù)載均衡功能呢?本文就將為大家細(xì)致地介紹一下

前言

MySQL是一個(gè)高速度、高性能、多線程、開放源代碼,建立在客戶/服務(wù)器(Client/Server)結(jié)構(gòu)上的關(guān)系型數(shù)據(jù)庫(kù)管理系(RDBMS)。它始于1979年,最初是MichaelWidenius為瑞典TcX公司創(chuàng)建的UNIREG數(shù)據(jù)庫(kù)系統(tǒng),當(dāng)時(shí)的UNIREG沒有SQL(StructuredQueryLanguage結(jié)構(gòu)化查詢語(yǔ)言)接口,限制了它的應(yīng)用。

1996年5月,Widenius開發(fā)出了MySQL的最初版本,開始在Internet上公開發(fā)行。MySQL的開發(fā)人員從一開始就一直關(guān)注它的性能,為此不惜特性集,直到今天,MySQL依然保持本色,以高速度高性能為首要原則。隨著時(shí)間的推移,MySQL也加入了大型數(shù)據(jù)庫(kù)產(chǎn)品的高級(jí)特性,如存儲(chǔ)過程、視圖、觸發(fā)器等,使其在企業(yè)級(jí)數(shù)據(jù)庫(kù)系統(tǒng)中開始被部署應(yīng)用[1]。

2008年10月,SUN公司收購(gòu)了MySQLAB公司,開始進(jìn)入開源領(lǐng)域。隨著重量級(jí)操作系統(tǒng)Solaris的開源,SUNMySQL在數(shù)據(jù)庫(kù)市場(chǎng)占有的份額將會(huì)進(jìn)一步提高。因此,在生產(chǎn)環(huán)境中部署具有負(fù)載均衡功能的MySQL服務(wù)器集群,對(duì)于提高企業(yè)數(shù)據(jù)庫(kù)應(yīng)用系統(tǒng)的速度、穩(wěn)定性及可伸縮性具有很大的現(xiàn)實(shí)意義,也可以有效降低應(yīng)用系統(tǒng)的投資成本。

一、負(fù)載均衡基本思路

在一個(gè)服務(wù)器集群中,盡可能的平均負(fù)載量。通常做法是在服務(wù)器前端設(shè)置一個(gè)負(fù)載均衡器(專門的硬件設(shè)備),MySQL的負(fù)載均衡,通常都離不開數(shù)據(jù)分片(把數(shù)據(jù)分割成小塊,存儲(chǔ)到不同的db節(jié)點(diǎn)中)、復(fù)制等操作。

在一個(gè)服務(wù)器集群中,盡可能的平均負(fù)載量。通常做法是在服務(wù)器前端設(shè)置一個(gè)負(fù)載均衡器(專門的硬件設(shè)備),MySQL的負(fù)載均衡,通常都離不開數(shù)據(jù)分片(把數(shù)據(jù)分割成小塊,存儲(chǔ)到不同的db節(jié)點(diǎn)中)、復(fù)制等操作。

負(fù)載均衡的主要貢獻(xiàn),除了均發(fā)數(shù)據(jù)庫(kù)請(qǐng)求,還可提供管理讀/寫策略。在分發(fā)請(qǐng)求時(shí)則確定那些節(jié)點(diǎn)可寫,可讀,隨即將請(qǐng)求發(fā)送到指定節(jié)點(diǎn)上執(zhí)行操作。

二、實(shí)現(xiàn)負(fù)載均衡的方式

1、mysql讀寫分離

mysql復(fù)制時(shí),產(chǎn)生了多個(gè)數(shù)據(jù)副本(備庫(kù)),為減少服務(wù)器壓力,備庫(kù)用于處理讀操作,主庫(kù)可同時(shí)處理讀寫是mysql集群實(shí)現(xiàn)讀寫分離的常用策略。

由于備庫(kù)的復(fù)制是異步的,無(wú)法實(shí)時(shí)同步,讀寫分離的主要難點(diǎn)也在于備庫(kù)上的臟數(shù)據(jù)。通常如果使用備庫(kù)進(jìn)行讀,一般對(duì)數(shù)據(jù)的實(shí)時(shí)性要求不能太高。對(duì)此,mysql提供了幾種常見的讀寫分離方式,例如基于查詢的讀寫分離、基于臟數(shù)據(jù)、基于會(huì)話等,有興趣可繼續(xù)研究。

mysql設(shè)置的讀寫分離,減少了主庫(kù)的請(qǐng)求量,將大量讀的操作發(fā)送給備庫(kù),實(shí)現(xiàn)負(fù)載均衡。

2、修改DNS

在高并發(fā)負(fù)載均衡(一)——企業(yè)架構(gòu)分析和DNS中詳細(xì)介紹了DNS以及DNS如何實(shí)現(xiàn)負(fù)載,簡(jiǎn)言之,通過n個(gè)服務(wù)器IP指定到一個(gè)域名,根據(jù)請(qǐng)求的不同標(biāo)識(shí)特征,將請(qǐng)求發(fā)送給不同的IP服務(wù)器進(jìn)行處理。

3、引入中間件

mysql官方提供了一個(gè)mysql負(fù)載的中間件,mysql_proxy,也需要在服務(wù)器上進(jìn)行安裝,修改配置文件(mysql的服務(wù)器IP),實(shí)質(zhì)與nginx類似,也是一個(gè)代理服務(wù)器。

4、利用mysql復(fù)制分流查詢操作

利用mysql的主從復(fù)制可以有效的分流更新操作和查詢操作,具體的實(shí)現(xiàn)是一個(gè)主服務(wù)器,承擔(dān)更新操作,多臺(tái)從服務(wù)器,承擔(dān)查詢操作,主從之間通過復(fù)制實(shí)現(xiàn)數(shù)據(jù)的同步。多臺(tái)從服務(wù)器一方面用來(lái)確??捎眯?,一方面可以創(chuàng)建不同的索引滿足不同查詢的需要。

對(duì)于主從之間不需要復(fù)制全部表的情況,可以通過在主的服務(wù)器上搭建一個(gè)虛擬的從服務(wù)器,將需要復(fù)制到從服務(wù)器的表設(shè)置成blackhole引擎,然后定義replicate-do-table參數(shù)只復(fù)制這些表,這樣就過濾出需要復(fù)制的binlog,減少了傳輸binlog的帶寬。因?yàn)榇罱ǖ奶摂M的從服務(wù)器只起到過濾binlog的作用,并沒有實(shí)際紀(jì)錄任何數(shù)據(jù),所以對(duì)主數(shù)據(jù)庫(kù)服務(wù)器的性能影響也非常的有限。

通過復(fù)制分流查詢的存在的問題是主數(shù)據(jù)庫(kù)上更新頻繁或者網(wǎng)絡(luò)出現(xiàn)問題的時(shí)候,主從之間的數(shù)據(jù)可能存在差異,造成查詢結(jié)果的異議,應(yīng)用在設(shè)計(jì)的時(shí)候需要有所考慮。

5、采用分布式數(shù)據(jù)庫(kù)架構(gòu)

mysql從5.0.3開始支持分布式事務(wù),當(dāng)前分布式事務(wù)只對(duì)Innodb存儲(chǔ)引擎支持。分布式的數(shù)據(jù)庫(kù)架構(gòu)適合大數(shù)據(jù)量,負(fù)載高的情況,有良好的擴(kuò)展性和高可用性。通過在多臺(tái)服務(wù)器之間分布數(shù)據(jù)實(shí)現(xiàn)在多臺(tái)服務(wù)器之間的負(fù)載平均,提高了訪問的執(zhí)行效率。具體實(shí)現(xiàn)的時(shí)候,可以使用mysql的Cluster功能(NDB引擎)或者自己編寫程序來(lái)實(shí)現(xiàn)全局事務(wù)。

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • MySQL日期及時(shí)間字段的查詢

    MySQL日期及時(shí)間字段的查詢

    這篇文章主要介紹了MySQL日期及時(shí)間字段的查詢,一分享日期及時(shí)間字段的規(guī)范化查詢方法為主展開詳細(xì)內(nèi)容,需要的小伙伴可以參考一下
    2022-05-05
  • mysql:ERROR?2003?(HY000)故障錯(cuò)誤解決方法與思路

    mysql:ERROR?2003?(HY000)故障錯(cuò)誤解決方法與思路

    這篇文章主要給大家介紹了關(guān)于mysql:ERROR?2003?(HY000)故障錯(cuò)誤解決方法與思路的相關(guān)資料,error 2003 hy000是MySQL數(shù)據(jù)庫(kù)中一個(gè)常見的錯(cuò)誤代碼,它通常意味著MySQL無(wú)法建立到數(shù)據(jù)庫(kù)的連接,需要的朋友可以參考下
    2024-02-02
  • MySQL Json類型字段IN查詢分組優(yōu)化

    MySQL Json類型字段IN查詢分組優(yōu)化

    這篇文章主要為大家介紹了MySQL Json類型字段IN查詢分組優(yōu)化,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-08-08
  • MySQL借助DB實(shí)現(xiàn)分布式鎖思路詳解

    MySQL借助DB實(shí)現(xiàn)分布式鎖思路詳解

    這篇文章主要給大家介紹了關(guān)于MySQL借助DB實(shí)現(xiàn)分布式鎖思路的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用MySQL具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-10-10
  • 在centOS 7安裝mysql 5.7的詳細(xì)教程

    在centOS 7安裝mysql 5.7的詳細(xì)教程

    這篇文章主要介紹了在centOS 7安裝mysql 5.7的詳細(xì)教程,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友參考下吧
    2016-12-12
  • MySQL的日志基礎(chǔ)知識(shí)及基本操作學(xué)習(xí)教程

    MySQL的日志基礎(chǔ)知識(shí)及基本操作學(xué)習(xí)教程

    這篇文章主要介紹了MySQL的日志基礎(chǔ)知識(shí)學(xué)習(xí)教程,包括MySQL中日志相關(guān)常用的服務(wù)器變量說(shuō)明,極力推薦!需要的朋友可以參考下
    2015-11-11
  • MySQL會(huì)發(fā)生死鎖的幾種情況及處理方法

    MySQL會(huì)發(fā)生死鎖的幾種情況及處理方法

    數(shù)據(jù)庫(kù)的死鎖是指不同的事務(wù)在獲取資源時(shí)相互等待,導(dǎo)致無(wú)法繼續(xù)執(zhí)行的一種情況,當(dāng)發(fā)生死鎖時(shí),數(shù)據(jù)庫(kù)系統(tǒng)會(huì)自動(dòng)中斷其中一個(gè)事務(wù),以解除死鎖,本文給大家介紹了MySQL什么情況下會(huì)死鎖,發(fā)生了死鎖怎么處理呢,需要的朋友可以參考下
    2023-09-09
  • MySQL中的臨時(shí)表與內(nèi)存表

    MySQL中的臨時(shí)表與內(nèi)存表

    這篇文章主要介紹了MySQL中的臨時(shí)表與內(nèi)存表,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-01-01
  • mysql獲取指定時(shí)間段中所有日期或月份的語(yǔ)句(不設(shè)存儲(chǔ)過程,不加表)

    mysql獲取指定時(shí)間段中所有日期或月份的語(yǔ)句(不設(shè)存儲(chǔ)過程,不加表)

    最近需要用mysql獲取一個(gè)時(shí)間段中的所有月份,網(wǎng)上查都是要設(shè)置存儲(chǔ)過程或者加一個(gè)日期表的,不滿足我的需求,翻墻找資料加上自己試驗(yàn),如下代碼分享給大家
    2021-06-06
  • MySQL對(duì)數(shù)據(jù)表已有表進(jìn)行分區(qū)表的實(shí)現(xiàn)

    MySQL對(duì)數(shù)據(jù)表已有表進(jìn)行分區(qū)表的實(shí)現(xiàn)

    本文主要介紹對(duì)現(xiàn)有的一個(gè)表進(jìn)行創(chuàng)建分區(qū)表,并把數(shù)據(jù)遷移到新表,可以按時(shí)間來(lái)分區(qū),具有一定的參考價(jià)值,感興趣的可以了解一下
    2021-10-10

最新評(píng)論