0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

正常情況下的服務(wù)演化之路

電子工程師 ? 來源:lq ? 2019-02-11 15:13 ? 次閱讀

前言

像我這樣的菜鳥,總會(huì)有各種疑問,剛開始是對(duì) JDK API 的疑問,對(duì) NIO 的疑問,對(duì) JVM 的疑問,當(dāng)工作幾年后,對(duì)服務(wù)的可用性,可擴(kuò)展性也有了新的疑問,什么疑問呢?其實(shí)是老生常談的話題:服務(wù)的擴(kuò)容問題。

正常情況下的服務(wù)演化之路

讓我們從最初開始。

1、單體應(yīng)用 每個(gè)創(chuàng)業(yè)公司基本都是從類似 SSM 和 SSH 這種架構(gòu)起來的,沒什么好講的,基本每個(gè)程序員都經(jīng)歷過。

2、RPC 應(yīng)用 當(dāng)業(yè)務(wù)越來越大,我們需要對(duì)服務(wù)進(jìn)行水平擴(kuò)容,擴(kuò)容很簡(jiǎn)單,只要保證服務(wù)是無狀態(tài)的就可以了,如下圖:

當(dāng)業(yè)務(wù)又越來越大,我們的服務(wù)關(guān)系錯(cuò)綜復(fù)雜,同時(shí),有很多服務(wù)訪問都是不需要連接 DB 的,只需要連接緩存即可,那么就可以做成分離的,減少 DB 寶貴的連接。如下圖:

我相信大部分公司都是在這個(gè)階段。Dubbo 就是為了解決這個(gè)問題而生的。

分庫分表

如果你的公司產(chǎn)品很受歡迎,業(yè)務(wù)繼續(xù)高速發(fā)展,數(shù)據(jù)越來越多,SQL 操作越來越慢,那么數(shù)據(jù)庫就會(huì)成為瓶頸,那么你肯定會(huì)想到分庫分表,不論通過 ID hash 或者 range 的方式都可以。如下圖:

這下應(yīng)該沒問題了吧。任憑你用戶再多,并發(fā)再高,我只要無限擴(kuò)容數(shù)據(jù)庫,無限擴(kuò)容應(yīng)用,就可以了。

這也是本文的標(biāo)題,分庫分表就能解決無限擴(kuò)容嗎?

實(shí)際上,像上面的架構(gòu),并不能解決。

其實(shí),這個(gè)問題和 RPC 的問題有點(diǎn)類似:數(shù)據(jù)庫連接過多?。?!

通常,我們的 RPC 應(yīng)用由于是使用中間件進(jìn)行訪問數(shù)據(jù)庫,應(yīng)用實(shí)際上是不知道到底要訪問哪個(gè)數(shù)據(jù)庫的,訪問數(shù)據(jù)庫的規(guī)則由中間件決定,例如 sharding JDBC。這就導(dǎo)致,這個(gè)應(yīng)用必須和所有的數(shù)據(jù)庫連接,就像我們上面的架構(gòu)圖一樣,一個(gè) RPC 應(yīng)用需要和 3 個(gè) mysql 連接,如果是 30 個(gè) RPC 應(yīng)用,每個(gè) RPC 的數(shù)據(jù)庫連接池大小是8 ,每個(gè) mysql 需要維護(hù) 240 個(gè)連接,我們知道,mysql 默認(rèn)連接數(shù)是 100,最大連接數(shù)是 16384,也就是說,假設(shè)每個(gè)應(yīng)用的連接池大小是 8 ,超過 2048 個(gè)應(yīng)用就無法再繼續(xù)連接了,也就無法繼續(xù)擴(kuò)容了。注意,由于每個(gè)物理庫有很多邏輯庫,再加上微服務(wù)運(yùn)動(dòng)如火如荼, 2048 并沒有看起來那么大。

也許你說,我可以通過前面加一個(gè) proxy 來解決連接數(shù)的問題,實(shí)際上,代理的性能也會(huì)成為問題,為什么?代理的連接數(shù)也是不能超過 16384 的,如果并發(fā)超過 16384,變成 163840,那么 proxy 也解決不了問題。

怎么辦?讓我們?cè)倏纯瓷厦娴募軜?gòu)圖:

我們發(fā)現(xiàn),問題是出在“每個(gè) RPC 應(yīng)用都要連所有的庫”,導(dǎo)致擴(kuò)容應(yīng)用的同時(shí),每個(gè)數(shù)據(jù)庫連接數(shù)就要增加。就算增加數(shù)據(jù)庫,也不能解決連接數(shù)的問題。

那怎么辦呢?

單元化

單元化,聽起來高大上,通常在一些 XXX 大會(huì)上,分享“關(guān)于兩地三中心”,“三地五中心”,“異地多活”等等牛逼的名詞的時(shí)候,單元化也會(huì)一起出現(xiàn)。

這里我們不討論那么牛逼的,就只說“數(shù)據(jù)庫連接數(shù)過多” 的問題。

實(shí)際上,思路很簡(jiǎn)單:我們不讓應(yīng)用連接所有的數(shù)據(jù)庫就可以了。

假設(shè)我們根據(jù) range 分成了 10 個(gè)庫,現(xiàn)在有 10 個(gè)應(yīng)用,我們讓每個(gè)應(yīng)用只連一個(gè)庫,當(dāng)應(yīng)用增多變成 20個(gè),數(shù)據(jù)庫的連接不夠用了,我們就將 10 個(gè)庫分成 20 個(gè)庫,這樣,無論你應(yīng)用擴(kuò)容到多少個(gè),都可以解決數(shù)據(jù)庫連接數(shù)過多的問題。

注意:做這件事的前提是:你必須保證,訪問你這個(gè)應(yīng)用的 request 請(qǐng)求的數(shù)據(jù)庫一定是在這個(gè)應(yīng)用的。

換個(gè)說法,當(dāng)用戶從 DNS 那里進(jìn)來的時(shí)候,就知道自己要去那個(gè)應(yīng)用了,所以,規(guī)則在 DNS 之前就定好了,雖然這有點(diǎn)夸張,但肯定在進(jìn)應(yīng)用之前就知道要去哪個(gè)庫了。

所以,這通常需要一個(gè)規(guī)則,例如通過用戶 ID hash,由配置中心廣播 hash 規(guī)則。這樣,所有的組件都能保持一致的規(guī)則,從而正確的訪問到數(shù)據(jù)庫。如下圖:

到這里,我們終于解決了無限擴(kuò)容的問題。

最后

本文從單體應(yīng)用開始,逐步講述了一個(gè)正常后臺(tái)的演進(jìn)歷程,知道了分庫分表并不能解決“無限擴(kuò)容” 的問題,只有單元化才能解決這問題。而單元化則帶來更多的復(fù)雜性。但是好處不言而喻。

單元化帶來的更多的思路。

有了單元化,解決了無限擴(kuò)容的問題,但是我們還沒有考慮單點(diǎn)的問題,即服務(wù)的可用性。要知道,我們這里的數(shù)據(jù)庫都是單點(diǎn)的。

這就是另一個(gè)話題 —— 異地多活。限于篇幅,下次再聊。

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • ssm
    ssm
    +關(guān)注

    關(guān)注

    0

    文章

    21

    瀏覽量

    11389
  • 程序員
    +關(guān)注

    關(guān)注

    4

    文章

    952

    瀏覽量

    29805

原文標(biāo)題:扎心一問:分庫分表就能無限擴(kuò)容嗎

文章出處:【微信號(hào):DBDevs,微信公眾號(hào):數(shù)據(jù)分析與開發(fā)】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏

    評(píng)論

    相關(guān)推薦

    請(qǐng)問當(dāng)該音頻運(yùn)放的輸出開路時(shí),正常情況下Vout電壓是接近Vcc的嗎?

    請(qǐng)問當(dāng)該音頻運(yùn)放的輸出開路時(shí),正常情況下Vout電壓是接近Vcc的嗎? (此時(shí)輸入V+和V-正常) 如果可以的話,能否從內(nèi)部結(jié)構(gòu)層面上解釋一這種情況下Vout的數(shù)值?
    發(fā)表于 08-20 06:37

    請(qǐng)問正常情況下芯片的操作順序是什么?

    你好:我現(xiàn)在正在調(diào)試DAC161S997片子,現(xiàn)在有個(gè)疑問,正常情況下芯片的操作順序是什么???也就是在輸出電流值之前要做哪些工作???
    發(fā)表于 06-18 09:13

    NRF24L01模塊的status正常情況下有幾種狀態(tài)?

    NRF24L01模塊的status正常情況下 有幾種狀態(tài)。status正常的值是多少
    發(fā)表于 07-21 04:31

    正常情況下家用臺(tái)式電腦電源應(yīng)該怎樣選擇呢

    電腦的心臟喲。正常情況下家用臺(tái)式電腦電源應(yīng)該怎樣選擇呢?應(yīng)該是根據(jù)CPU、顯卡的滿載功耗,再加上一二百瓦就足夠了
    發(fā)表于 12-27 08:12

    常情況下雙面沉金PCB線路板有哪些優(yōu)勢(shì)?

    常情況下雙面沉金PCB線路板有哪些優(yōu)勢(shì)?
    發(fā)表于 04-14 15:20

    零線在什么情況下有電?如何預(yù)防?

    關(guān)于正常情況下零線是否有電,很多人都會(huì)對(duì)此有所爭(zhēng)論。關(guān)于有電沒電,其實(shí)是人們對(duì)帶電的概念混淆,只是從個(gè)人觀點(diǎn)認(rèn)為其有電或者沒電。
    的頭像 發(fā)表于 09-21 14:42 ?5899次閱讀

    零線在什么情況下有電 如何預(yù)防

    關(guān)于正常情況下零線是否有電,很多人都會(huì)對(duì)此有所爭(zhēng)論。關(guān)于有電沒電,其實(shí)是人們對(duì)帶電的概念混淆,只是從個(gè)人觀點(diǎn)認(rèn)為其有電或者沒電。
    的頭像 發(fā)表于 01-18 17:06 ?4308次閱讀

    正常情況下零線到底有沒有電?什么時(shí)候零線是有電的

    關(guān)于正常情況下零線是否有電,很多人都會(huì)對(duì)此有所爭(zhēng)論。反正就兩個(gè)觀點(diǎn),一個(gè)有電;一個(gè)沒電。關(guān)于有電沒電,其實(shí)使人們對(duì)帶電的概念混淆,只是從自己?jiǎn)为?dú)的觀點(diǎn)認(rèn)為其有電或者沒電。
    的頭像 發(fā)表于 07-28 10:02 ?1.9w次閱讀

    變頻電動(dòng)機(jī)在什么情況下要選用

    正常情況下交流異步電動(dòng)機(jī)在選配變頻器時(shí),電動(dòng)機(jī)不需要進(jìn)行更換,這主要是為了減少投資,但在以下要求的場(chǎng)合,必須選用變頻電動(dòng)機(jī)。
    發(fā)表于 07-05 10:14 ?3108次閱讀

    什么情況下使用示波器

    示波器可以把我們看不見的電信號(hào)變換成看得見的圖像,方便來研究各種電現(xiàn)象的變化過程。那么什么情況下使用示波器呢? 使用示波器進(jìn)行測(cè)量需要涂有熒光物質(zhì)的屏面、主機(jī)、探頭配置和穩(wěn)定的信號(hào)。示波器一般都是
    的頭像 發(fā)表于 02-01 11:00 ?5725次閱讀

    為什么短路情況下電流回上升?

    為什么短路電流這么大,還得從歐姆定律I=U/R說起。在正常情況下,無論是感性負(fù)載、容性負(fù)載,還是阻性負(fù)載,都存在一定的感抗、容抗和阻抗。一旦它們發(fā)生故障或短路,感抗、容抗和阻抗都為零,交直流電壓都加到感抗、容抗和阻抗都為0的負(fù)載上,除了導(dǎo)線電阻,它當(dāng)然是接近電源的電動(dòng)勢(shì)。因此,短路電流很大。
    的頭像 發(fā)表于 06-27 14:49 ?1980次閱讀
    為什么短路<b class='flag-5'>情況下</b>電流回上升?

    應(yīng)急燈什么情況下才會(huì)亮?

    應(yīng)急燈什么情況下才會(huì)亮? 應(yīng)急燈指的是電源發(fā)生故障時(shí),正常照明無法使用的情況下,啟動(dòng)的照明燈。比如說因?yàn)榛馂?zāi)導(dǎo)致正常照明系統(tǒng)失效時(shí),消防疏散照明燈、消防應(yīng)急照明燈會(huì)自動(dòng)亮起,起到疏散人
    的頭像 發(fā)表于 07-25 13:57 ?1.5w次閱讀

    斷路器的作用、結(jié)構(gòu)及異常處理方法

    正常情況下:切斷和接通正常情況下的空載電流和負(fù)荷電流
    的頭像 發(fā)表于 07-27 14:46 ?2102次閱讀
    斷路器的作用、結(jié)構(gòu)及異常處理方法

    請(qǐng)問什么原因?qū)е略谄ヅ?b class='flag-5'>正常情況下,插損出現(xiàn)周期性諧振?

    帶狀線插損出現(xiàn)諧振的原因?請(qǐng)問什么原因?qū)е略谄ヅ?b class='flag-5'>正常情況下,插損出現(xiàn)周期性諧振? 帶狀線插損是指帶狀線(stripline)結(jié)構(gòu)中信號(hào)傳輸過程中的信號(hào)損耗,通常是由于信號(hào)在傳輸過程中遇到電磁波的阻力
    的頭像 發(fā)表于 10-20 15:02 ?1289次閱讀

    什么情況下會(huì)產(chǎn)生零序電流

    零序電流是指在三相電力系統(tǒng)中,三相電流的矢量和不為零的情況。在正常情況下,三相電力系統(tǒng)中的三相電流是平衡的,即三相電流的矢量和為零。但是,在某些特殊情況下,三相電流的矢量和不為零,就會(huì)產(chǎn)生零序電流
    的頭像 發(fā)表于 07-15 14:53 ?3991次閱讀