在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

正常情況下的服務演化之路

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

前言

像我這樣的菜鳥,總會有各種疑問,剛開始是對 JDK API 的疑問,對 NIO 的疑問,對 JVM 的疑問,當工作幾年后,對服務的可用性,可擴展性也有了新的疑問,什么疑問呢?其實是老生常談的話題:服務的擴容問題。

正常情況下的服務演化之路

讓我們從最初開始。

1、單體應用 每個創業公司基本都是從類似 SSM 和 SSH 這種架構起來的,沒什么好講的,基本每個程序員都經歷過。

2、RPC 應用 當業務越來越大,我們需要對服務進行水平擴容,擴容很簡單,只要保證服務是無狀態的就可以了,如下圖:

當業務又越來越大,我們的服務關系錯綜復雜,同時,有很多服務訪問都是不需要連接 DB 的,只需要連接緩存即可,那么就可以做成分離的,減少 DB 寶貴的連接。如下圖:

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

分庫分表

如果你的公司產品很受歡迎,業務繼續高速發展,數據越來越多,SQL 操作越來越慢,那么數據庫就會成為瓶頸,那么你肯定會想到分庫分表,不論通過 ID hash 或者 range 的方式都可以。如下圖:

這下應該沒問題了吧。任憑你用戶再多,并發再高,我只要無限擴容數據庫,無限擴容應用,就可以了。

這也是本文的標題,分庫分表就能解決無限擴容嗎?

實際上,像上面的架構,并不能解決。

其實,這個問題和 RPC 的問題有點類似:數據庫連接過多!!!

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

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

怎么辦?讓我們再看看上面的架構圖:

我們發現,問題是出在“每個 RPC 應用都要連所有的庫”,導致擴容應用的同時,每個數據庫連接數就要增加。就算增加數據庫,也不能解決連接數的問題。

那怎么辦呢?

單元化

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

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

實際上,思路很簡單:我們不讓應用連接所有的數據庫就可以了。

假設我們根據 range 分成了 10 個庫,現在有 10 個應用,我們讓每個應用只連一個庫,當應用增多變成 20個,數據庫的連接不夠用了,我們就將 10 個庫分成 20 個庫,這樣,無論你應用擴容到多少個,都可以解決數據庫連接數過多的問題。

注意:做這件事的前提是:你必須保證,訪問你這個應用的 request 請求的數據庫一定是在這個應用的。

換個說法,當用戶從 DNS 那里進來的時候,就知道自己要去那個應用了,所以,規則在 DNS 之前就定好了,雖然這有點夸張,但肯定在進應用之前就知道要去哪個庫了。

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

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

最后

本文從單體應用開始,逐步講述了一個正常后臺的演進歷程,知道了分庫分表并不能解決“無限擴容” 的問題,只有單元化才能解決這問題。而單元化則帶來更多的復雜性。但是好處不言而喻。

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

有了單元化,解決了無限擴容的問題,但是我們還沒有考慮單點的問題,即服務的可用性。要知道,我們這里的數據庫都是單點的。

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

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • ssm
    ssm
    +關注

    關注

    0

    文章

    21

    瀏覽量

    11425
  • 程序員
    +關注

    關注

    4

    文章

    953

    瀏覽量

    29857

原文標題:扎心一問:分庫分表就能無限擴容嗎

文章出處:【微信號:DBDevs,微信公眾號:數據分析與開發】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    請問當該音頻運放的輸出開路時,正常情況下Vout電壓是接近Vcc的嗎?

    請問當該音頻運放的輸出開路時,正常情況下Vout電壓是接近Vcc的嗎? (此時輸入V+和V-正常) 如果可以的話,能否從內部結構層面上解釋一這種情況下Vout的數值?
    發表于 08-20 06:37

    調試DAC161S997,正常情況下芯片的操作順序是什么啊?

    我現在正在調試DAC161S997片子,現在有個疑問,正常情況下芯片的操作順序是什么啊?也就是在輸出電流值之前要做哪些工作啊?
    發表于 01-10 06:39

    請問正常情況下芯片的操作順序是什么?

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

    NRF24L01模塊的status正常情況下有幾種狀態?

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

    正常情況下家用臺式電腦電源應該怎樣選擇呢

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

    常情況下雙面沉金PCB線路板有哪些優勢?

    常情況下雙面沉金PCB線路板有哪些優勢?
    發表于 04-14 15:20

    零線在什么情況下有電?如何預防?

    關于正常情況下零線是否有電,很多人都會對此有所爭論。關于有電沒電,其實是人們對帶電的概念混淆,只是從個人觀點認為其有電或者沒電。
    的頭像 發表于 09-21 14:42 ?5993次閱讀

    零線在什么情況下有電 如何預防

    關于正常情況下零線是否有電,很多人都會對此有所爭論。關于有電沒電,其實是人們對帶電的概念混淆,只是從個人觀點認為其有電或者沒電。
    的頭像 發表于 01-18 17:06 ?4440次閱讀

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

    關于正常情況下零線是否有電,很多人都會對此有所爭論。反正就兩個觀點,一個有電;一個沒電。關于有電沒電,其實使人們對帶電的概念混淆,只是從自己單獨的觀點認為其有電或者沒電。
    的頭像 發表于 07-28 10:02 ?1.9w次閱讀

    變頻電動機在什么情況下要選用

    正常情況下交流異步電動機在選配變頻器時,電動機不需要進行更換,這主要是為了減少投資,但在以下要求的場合,必須選用變頻電動機。
    發表于 07-05 10:14 ?3165次閱讀

    什么情況下使用示波器

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

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

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

    應急燈什么情況下才會亮?

    應急燈什么情況下才會亮? 應急燈指的是電源發生故障時,正常照明無法使用的情況下,啟動的照明燈。比如說因為火災導致正常照明系統失效時,消防疏散照明燈、消防應急照明燈會自動亮起,起到疏散人
    的頭像 發表于 07-25 13:57 ?1.6w次閱讀

    請問什么原因導致在匹配正常情況下,插損出現周期性諧振?

    帶狀線插損出現諧振的原因?請問什么原因導致在匹配正常情況下,插損出現周期性諧振? 帶狀線插損是指帶狀線(stripline)結構中信號傳輸過程中的信號損耗,通常是由于信號在傳輸過程中遇到電磁波的阻力
    的頭像 發表于 10-20 15:02 ?1355次閱讀

    什么情況下會產生零序電流

    零序電流是指在三相電力系統中,三相電流的矢量和不為零的情況。在正常情況下,三相電力系統中的三相電流是平衡的,即三相電流的矢量和為零。但是,在某些特殊情況下,三相電流的矢量和不為零,就會產生零序電流
    的頭像 發表于 07-15 14:53 ?4787次閱讀
    主站蜘蛛池模板: 亚欧免费视频 | 成人最新午夜免费视频 | 种子在线搜索bt | 午夜免费啪在线观看视频网站 | 精品国产第一页 | 影音先锋色偷偷米奇四色 | 婷婷四房综合激情五月性色 | 第四色亚洲 | 天天性视频 | 色婷婷综合和线在线 | 天天操夜夜做 | 手机午夜看片 | 亚洲成a人片在线观看导航 亚洲成a人片在线观看尤物 | 四虎国产欧美成人影院 | 欧美综合精品一区二区三区 | 色色就色色 | 无毒三级 | 亚洲你xx我xx网站 | 色噜噜成人综合网站 | 欧美a色| 国产午夜视频在线观看第四页 | 久久国产乱子伦精品免费强 | 日本亚洲高清乱码中文在线观看 | 国产精品一级香蕉一区 | 欧美另类videos| 黄色avav | 中日韩一级片 | 国产精品17p| 又粗又长又色又爽视频 | 女a男0攻巨肉高h | 激情综合六月 | 午夜一级福利 | 欧美视频色| 黄色录像大全 | 一品毛片 | 狠狠干在线观看 | 亚洲小视频 | 亚洲一区二区三区四区五区六区 | 日本三级2018亚洲视频 | 亚洲网站视频 | 污视频18高清在线观看 |