亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

Mysql在大型網站的應用架構演變

2019-11-17 03:07:03
字體:
來源:轉載
供稿:網友

MySQL在大型網站的應用架構演變

原創文章,轉載請注明: 轉載自http://www.49028c.com/Creator/本文鏈接地址: Mysql在大型網站的應用架構演變

本文已經被多處轉載,包括CSDN推薦以及碼農周刊等等,閱讀數超過5w+,回流到我博客流量的還是比較少,不過這不重要, 后續會分享更多技術,盡量試圖把自己理解的東西描述出來(很多時候自己的理解是90分,可是描述出來就只有60分了)

CSDN的轉載 :http://www.csdn.net/article/2014-06-10/2820160

伯樂在線的轉載: http://blog.jobbole.com/70844/

當然還有大量轉載沒有寫明出處的...

寫在最前:

本文主要描述在網站的不同的并發訪問量級下,Mysql架構的演變

可擴展性

架構的可擴展性往往和并發是息息相關,沒有并發的增長,也就沒有必要做高可擴展性的架構,這里對可擴展性進行簡單介紹一下,常用的擴展手段有以下兩種Scale-up : 縱向擴展,通過替換為更好的機器和資源來實現伸縮,提升服務能力Scale-out : 橫向擴展, 通過加節點(機器)來實現伸縮,提升服務能力對于互聯網的高并發應用來說,無疑Scale out才是出路,通過縱向的買更高端的機器一直是我們所避諱的問題,也不是長久之計,在scale out的理論下,可擴展性的理想狀態是什么?

可擴展性的理想狀態

一個服務,當面臨更高的并發的時候,能夠通過簡單增加機器來提升服務支撐的并發度,且增加機器過程中對線上服務無影響(no down time),這就是可擴展性的理想狀態!

架構的演變

V1.0 簡單網站架構

一個簡單的小型網站或者應用背后的架構可以非常簡單, 數據存儲只需要一個mysql instance就能滿足數據讀取和寫入需求(這里忽略掉了數據備份的實例),處于這個時間段的網站,一般會把所有的信息存到一個database instance里面。

在這樣的架構下,我們來看看數據存儲的瓶頸是什么?1.數據量的總大小 一個機器放不下時2.數據的索引(B+ Tree)一個機器的內存放不下時3.訪問量(讀寫混合)一個實例不能承受只有當以上3件事情任何一件或多件滿足時,我們才需要考慮往下一級演變。 從此我們可以看出,事實上對于很多小公司小應用,這種架構已經足夠滿足他們的需求了,初期數據量的準確評估是杜絕過度設計很重要的一環,畢竟沒有人愿意為不可能發生的事情而浪費自己的經歷。

這里簡單舉個我的例子,對于用戶信息這類表 (3個索引),16G內存能放下大概2000W行數據的索引,簡單的讀和寫混合訪問量3000/s左右沒有問題,你的應用場景是否

V2.0 垂直拆分

一般當V1.0 遇到瓶頸時,首先最簡便的拆分方法就是垂直拆分,何謂垂直?就是從業務角度來看,將關聯性不強的數據拆分到不同的instance上,從而達到消除瓶頸的目標。以圖中的為例,將用戶信息數據,和業務數據拆分到不同的三個實例上。對于重復讀類型比較多的場景,我們還可以加一層cache,來減少對DB的壓力。

在這樣的架構下,我們來看看數據存儲的瓶頸是什么?

1.單實例單業務 依然存在V1.0所述瓶頸

遇到瓶頸時可以考慮往本文更高V版本升級, 若是讀請求導致達到性能瓶頸可以考慮往V3.0升級, 其他瓶頸考慮往V4.0升級

V3.0 主從架構

此類架構主要解決V2.0架構下的讀問題,通過給Instance掛數據實時備份的思路來遷移讀取的壓力,在Mysql的場景下就是通過主從結構,主庫抗寫壓力,通過從庫來分擔讀壓力,對于寫少讀多的應用,V3.0主從架構完全能夠勝任

在這樣的架構下,我們來看看數據存儲的瓶頸是什么?1.寫入量主庫不能承受

V4.0 水平拆分

對于V2.0 V3.0方案遇到瓶頸時,都可以通過水平拆分來解決,水平拆分和垂直拆分有較大區別,垂直拆分拆完的結果,在一個實例上是擁有全量數據的,而水平拆分之后,任何實例都只有全量的1/n的數據,以下圖Userinfo的拆分為例,將userinfo拆分為3個cluster,每個cluster持有總量的1/3數據,3個cluster數據的總和等于一份完整數據(注:這里不再叫單個實例 而是叫一個cluster 代表包含主從的一個小mysql集群)

數據如何路由?

1.Range拆分

sharding key按連續區間段路由,一般用在有嚴格自增ID需求的場景上,如Userid, Userid Range的小例子:以userid 3000W 為Range進行拆分 1號cluster userid 1-3000W 2號cluster userid 3001W-6000W

2.List拆分

List拆分與Range拆分思路一樣,都是通過給不同的sharding key來路由到不同的cluster,但是具體方法有些不同,List主要用來做sharding key不是連續區間的序列落到一個cluster的情況,如以下場景:假定有20個音像店,分布在4個有經銷權的地區,如下表所示:

地區

商店ID 號

北區

3, 5, 6, 9, 17

東區

1, 2, 10, 11, 19, 20

西區

4, 12, 13, 14, 18

中心區

7, 8, 15, 16

業務希望能夠把一個地區的所有數據組織到一起來搜索,這種場景List拆分可以輕松搞定

3.Hash拆分

通過對sharding key 進行哈希的方式來進行拆分,常用的哈希方法有除余,字符串哈希等等,除余如按userid%n 的值來決定數據讀寫哪個cluster,其他哈希類算法這里就不細展開講了。

數據拆分后引入的問題:

數據水平拆分引入的問題主要是只能通過sharding key來讀寫操作,例如以userid為sharding key的切分例子,讀userid的詳細信息時,一定需要先知道userid,這樣才能推算出再哪個cluster進而進行查詢,假設我需要按username進行檢索用戶信息,需要引入額外的反向索引機制(類似HBASE二級索引),如在redis上存儲username->userid的映射,以username查詢的例子變成了先通過查詢username->userid,再通過userid查詢相應的信息。實際上這個做法很簡單,但是我們不要忽略了一個額外的隱患,那就是數據不一致的隱患。存儲在redis里的username->userid和存儲在mysql里的userid->username必須需要是一致的,這個保證起來很多時候是一件比較困難的事情,舉個例子來說,對于修改用戶名這個場景,你需要同時修改redis和mysql,這兩個東西是很難做到事務保證的,如mysql操作成功 但是redis卻操作失敗了(分布式事務引入成本較高),對于互聯網應用來說,可用性是最重要的,一致性是其次,所以能夠容忍小量的不一致出現. 畢竟從占比來說,這類的不一致的比例可以微乎其微到忽略不計(一般寫更新也會采用mq來保證直到成功為止才停止重試操作)在這樣的架構下,我們來看看數據存儲的瓶頸是什么?在這個拆分理念上搭建起來的架構,理論上不存在瓶頸(sharding key能確保各cluster流量相對均衡的前提下),不過確有一件惡心的事情,那就是cluster擴容的時候重做數據的成本,如我原來有3個cluster,但是現在我的數據增長比較快,我需要6個cluster,那么我們需要將每個cluster 一拆為二,一般的做法是1.摘下一個slave,停同步, 2.對寫記錄增量log(實現上可以業務方對寫操作 多一次寫持久化mq 或者mysql主創建trigger記錄寫 等等方式)3.開始對靜態slave做數據, 一拆為二4.回放增量寫入,直到追上的所有增量,與原cluster基本保持同步5.寫入切換,由原3 cluster 切換為6cluster 有沒有類似飛機空中加油的感覺,這是一個臟活,累活,容易出問題的活,為了避免這個,我們一般在最開始的時候,設計足夠多的sharding cluster來防止可能的cluster擴容這件事情

V5.0 云計算 騰飛(云數據庫

云計算現在是各大IT公司內部作為節約成本的一個突破口,對于數據存儲的mysql來說,如何讓其成為一個saas(Software as a Service)是關鍵點。在MS的官方文檔中,把構建一個足夠成熟的SAAS(MS簡單列出了SAAS應用的4級成熟度)所面臨的3個主要挑戰:可配置性,可擴展性,多用戶存儲結構設計稱為"three headed monster". 可配置性和多用戶存儲結構設計在Mysql saas這個問題中并不是特別難辦的一件事情,所以這里重點說一下可擴展性。Mysql作為一個saas服務,在架構演變為V4.0之后,依賴良好的sharding key設計, 已經不再存在擴展性問題,只是他在面對擴容縮容時,有一些臟活需要干,而作為saas,并不能避免擴容縮容這個問題,所以只要能把V4.0的臟活變成 1. 擴容縮容對前端APP透明(業務代碼不需要任何改動) 2.擴容縮容全自動化且對在線服務無影響 那么他就拿到了作為Saas的門票.

對于架構實現的關鍵點,需要滿足對業務透明,擴容縮容對業務不需要任何改動,那么就必須eat our own dog food,在你mysql saas內部解決這個問題,一般的做法是我們需要引入一個PRoxy,Proxy來解析sql協議,按sharding key 來尋找cluster, 判斷是讀操作還是寫操作來請求主 或者 從,這一切內部的細節都由proxy來屏蔽。這里借淘寶的圖來列舉一下proxy需要干哪些事情

百度公開的技術方案中也有類似的解決方案,見文章最后資料部分鏈接對于架構實現的關鍵點,擴容縮容全自動化且對在線服務無影響; 擴容縮容對應到的數據操作即為數據拆分和數據合并,要做到完全自動化有非常多不同的實現方式,總體思路和V4.0介紹的瓶頸部分有關,目前來看這個問題比較好的方案就是實現一個偽裝slave的sync slave, 解析mysql同步協議,然后實現數據拆分邏輯,把全量數據進行拆分。具體架構見下圖:

其中Sync slave對于Original Master來說,和一個普通的Mysql Slave沒有任何區別,也不需要任何額外的區分對待。需要擴容/縮容時,掛上一個Sync slave,開始全量同步+增量同步,等待一段時間追數據。以擴容為例,若擴容后的服務和擴容前數據已經基本同步了,這時候如何做到切換對業務無影響? 其實關鍵點還是在引入的proxy,這個問題轉換為了如何讓proxy做熱切換后端的問題。這已經變成一個非常好處理的問題了.另外值得關注的是:2014年5月28日——為了滿足當下對Web及云應用需求,甲骨文宣布推出MySQL Fabric,在對應的資料部分我也放了很多Fabric的資料,有興趣的可以看看,說不定會是以后的一個解決云數據庫擴容縮容的手段

V more ?

等待革命...

其他資料

百度Dbproxy設計 http://tech.it168.com/a2012/0413/1337/000001337034.shtml淘寶RDS 云數據庫設計: http://blog.csdn.net/ywh147/article/details/8954625 http://www.infoq.com/cn/news/2012/10/taobao-umpMysql Fabrichttp://mysqlmusings.blogspot.jp/2013/09/brief-introduction-to-mysql-fabric.htmlhttp://vnwrites.blogspot.jp/2013/09/mysqlfabric-sharding-introduction.htmlhttp://vnwrites.blogspot.in/2013/09/mysqlfabric-sharding-example.htmlhttp://vnwrites.blogspot.in/2013/09/mysqlfabric-sharding-migration.htmlhttp://vnwrites.blogspot.jp/2013/09/mysqlfabric-sharding-maintenance.html


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
久久久久免费视频| 欧美电影在线观看网站| x99av成人免费| 久久久女女女女999久久| 中文字幕久热精品在线视频| 91国产一区在线| 欧美疯狂性受xxxxx另类| 久久精品国产欧美亚洲人人爽| 一区二区三区动漫| 国产精品人成电影| 国产精品jizz在线观看麻豆| 久久久久久久久爱| 亚洲欧美日韩国产中文专区| 亚洲性69xxxbbb| 国产色婷婷国产综合在线理论片a| 成人av番号网| 亚洲一区二区黄| 国产精品久久久久久久久男| 国产欧美va欧美va香蕉在线| 日韩人在线观看| 中文字幕不卡在线视频极品| 欧美乱人伦中文字幕在线| 久久中文精品视频| 亚洲精品免费一区二区三区| 国产精品久久久久影院日本| 久久夜色撩人精品| 国产免费一区视频观看免费| 国产精品久久久久久久久久久久久久| 久久久久一本一区二区青青蜜月| 精品国偷自产在线视频99| 国产裸体写真av一区二区| 91免费在线视频网站| 96国产粉嫩美女| 日韩成人在线免费观看| 欧美久久久精品| 亚洲欧洲午夜一线一品| 欧美一级片一区| 国产亚洲欧美日韩精品| 午夜精品99久久免费| 日韩美女视频在线观看| 国产欧美一区二区三区久久人妖| 欧美性受xxx| 97超级碰碰碰久久久| 欧美激情综合亚洲一二区| 久久视频这里只有精品| 国产成人精品视| 97免费中文视频在线观看| 国产精品一区二区久久久| 久久精品国产2020观看福利| 亚洲片在线观看| 91夜夜未满十八勿入爽爽影院| 国产精品天天狠天天看| 久久99热精品这里久久精品| 亚洲国产古装精品网站| 91在线视频精品| 欧美中文字幕在线| 日韩欧美国产骚| 奇门遁甲1982国语版免费观看高清| 亚洲国产成人精品久久久国产成人一区| 欧美精品一区在线播放| 欧美成人免费全部观看天天性色| 久久91亚洲人成电影网站| 欧美激情在线播放| 国产欧美日韩丝袜精品一区| 最近2019中文字幕大全第二页| 欧美激情第三页| 欧美高清在线播放| 欧美在线中文字幕| 97香蕉久久超级碰碰高清版| 亚洲图片在线综合| 777国产偷窥盗摄精品视频| 日韩在线观看网站| 福利视频第一区| 国产精品亚洲第一区| 久久久久久97| 国产aaa精品| 国产精品一区二区三区在线播放| 日韩va亚洲va欧洲va国产| 日韩免费在线观看视频| 久久久久久国产精品| 欧美激情精品久久久久久大尺度| 91精品啪在线观看麻豆免费| 在线观看91久久久久久| 日本高清视频精品| 日韩精品欧美国产精品忘忧草| 黑人巨大精品欧美一区二区免费| 欧美国产在线电影| 久久夜色精品国产欧美乱| 久久激情五月丁香伊人| 成人av资源在线播放| 欧美精品国产精品日韩精品| 日韩最新中文字幕电影免费看| 亚洲va欧美va国产综合久久| 久久激情视频免费观看| 日韩暖暖在线视频| 精品国内亚洲在观看18黄| 疯狂做受xxxx高潮欧美日本| 97av在线视频免费播放| 成人xxxxx| 欧美亚洲视频在线观看| 中文精品99久久国产香蕉| 亚洲精品资源在线| 在线观看亚洲视频| 欧美一级免费看| 51久久精品夜色国产麻豆| 久久影视三级福利片| 中文字幕九色91在线| 亚洲精品国精品久久99热一| 久久人人爽人人爽人人片av高清| 欧美巨猛xxxx猛交黑人97人| 91精品免费视频| 久久久久久成人精品| 中文字幕欧美日韩在线| 亚洲欧美激情在线视频| 日韩在线视频免费观看高清中文| 蜜月aⅴ免费一区二区三区| 亚洲日本中文字幕免费在线不卡| 亚洲精品视频在线观看视频| 2020久久国产精品| 国产精品美女av| 亚洲精品一区在线观看香蕉| 欧洲亚洲在线视频| 欧美精品国产精品日韩精品| 国产乱人伦真实精品视频| 亚洲视频在线观看网站| 日韩av在线免费| 欧美激情精品久久久久| 992tv在线成人免费观看| 欧美风情在线观看| 成人av在线亚洲| 亚洲欧美一区二区三区情侣bbw| 成人性生交大片免费看小说| 国产精品96久久久久久又黄又硬| 久久不射热爱视频精品| 这里只有精品在线播放| 性色av一区二区咪爱| 亚洲免费小视频| 色综合久久久久久中文网| 久久久久久伊人| 亚洲欧美在线第一页| 欧美大片在线影院| 麻豆国产精品va在线观看不卡| 精品久久久久久久久久久久久久| 欧美日本国产在线| 欧美有码在线观看视频| 欧美午夜精品久久久久久久| 热草久综合在线| 亚洲人成网站999久久久综合| 91在线|亚洲| 中文字幕日韩免费视频| 亚洲精品电影在线| 国产视频久久久久久久| 午夜精品久久久久久99热软件| 国产在线观看精品一区二区三区| 成人免费在线视频网址| 韩国视频理论视频久久| www国产亚洲精品久久网站| 亚洲精品成人久久久| 亚洲人成免费电影| 欧日韩在线观看| 久久久久久久久国产| 国产成人在线一区| 亚洲欧美成人一区二区在线电影| 国产精品欧美日韩一区二区|