精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

業務單表讀寫緩慢如何優化?

數據庫 其他數據庫
關系型數據庫目前市面上主流無非三種:MySQL、Oracle、SqlServer,筆者更傾向于MySQL,也是很多新型企業在用的一種數據庫,因此本篇文章也將重點圍繞MySQL展開。

在前面的文章中探討了架構優化的兩種方案:冷熱分離、查詢分離。

  • 冷熱分離
  • 查詢分離

查詢分離其實就是利用了非關系數據庫的高性能,但是不足之處也很明顯:當主數據量越來越多,寫操作緩慢;這種問題如何破局?可見任何一種優化方案都不是最終的銀彈,只有不斷的優化演變

這篇文章就來介紹一下解決方案:分庫分表,將圍繞以下幾點介紹:

  • 拆分后的存儲選型?
  • 分庫分表的實現思路?
  • 分庫分表的不足?

拆分后的存儲選型?

在介紹選型之前先來介紹下架構背景,筆者曾經做過電商系統的優化,該系統中包含的兩個主體:

  • 用戶:數據量上千萬,每日增長10W+
  • 訂單:數據量上億,每日百萬級的增長

對于如此量級的數據,單庫單表的情況下,無論是IO還是CPU都扛不住,架構上的優化是必然。

經過了多次探討嘗試,最終選擇了分庫分表。

說到分庫分表首先想到的就是存儲選型,關于持久層的選型主流的無非有如下幾種:

  • 關系型數據庫:MySQL、Oracle.........
  • NoSQL:MongoDB、ES......
  • NewSQL:TiDB........

1. 關系型數據庫

關系型數據庫目前市面上主流無非三種:MySQL、Oracle、SqlServer,筆者更傾向于MySQL,也是很多新型企業在用的一種數據庫,因此本篇文章也將重點圍繞MySQL展開

在任何系統中關系型數據庫的地位都是不可或缺的,它的強約束性、事務的控制、SQL語法、鎖....這些功能可謂是久經考驗,因此在功能上 MySQL 能滿足我們所有的業務需求。

2. NoSQL

說到NoSQL,第一個想到就是MongoDB ,它的分片功能從并發性和數據量這兩個角度已經能滿足一般大數據量的需求,但是仍然需要考慮如下幾點:

  • 約束性:MongoDB 不是關系型數據庫而是文檔型數據庫,它的每一行記錄都是一個結構靈活可變的 JSON,比如存儲非常重要的訂單數據時,我們就不能使用 MongoDB,因為訂單數據必須使用強約束的關系型數據庫進行存儲。
  • 業務功能考量:事務的控制、SQL語法、鎖以及各種千奇百怪的SQL在已有的架構上都曾久經考驗,但是MongoDB在這些功能需要上并不能滿足
  • 業務改造考量:未拆分前使用關系型數據庫,使用NoSQL之后對于SQL的改造比較麻煩,項目周期更長

3. NewSQL

NewSQL目前比較主流則是TiDB,該技術比較新,雖然能夠滿足大數據量的存儲,但是在選擇上還是需要做些考量:

熟悉程度考量:如果你所在公司架構組對于NewSQL比較數據或者已經有在使用,則可以選擇

穩定性考量:關系型數據畢竟是久經考驗,在穩定性方面肯定是比較好,但是NewSQL的穩定性卻無法去考量,建議初期階段可以將一些不太重要的數據使用NewSQL存儲

基于MySQL的分庫分表

什么是分表分庫?分表是將一份大的表數據拆分存放至多個結構一樣的拆分表;分庫就是將一個大的數據庫拆分成多個結構一樣的小庫。

前面介紹的三種拆分存儲技術,在我以往的項目中我都沒使用過,而是選擇了基于 MySQL 的分表分庫,主要是有一個重要考量:分表分庫對于第三方依賴較少,業務邏輯靈活可控,它本身并不需要非常復雜的底層處理,也不需要重新做數據庫,只是根據不同邏輯使用不同 SQL 語句和數據源而已。

目前市面上主流的分庫分表分為兩種模式:Proxy模式、Client模式

Proxy模式屬于業務無侵入型,直接代理數據庫,對于開發者一切都是無感知的,SQL 組合、數據庫路由、執行結果合并等功能全部存放在一個代理服務中,比如MyCat、ShardingSphere都對Proxy模式提供了支持

Client模式屬于業務侵入型,將分庫分表的邏輯放在客戶端,客戶端需要引入一個jar,比如Sharding-JDBC,架構圖如下:

圖片

市面上對于分庫分表中間件如下:

圖片

兩種模式的優缺點也很明顯:

  • Proxy模式:資源解耦,業務無侵入;缺點則是運維成本相對較高
  • Client模式:代碼靈活控制,運維成本低;缺點則是語言限制,升級不方便

分庫分表的實現思路

在落實分表分庫解決方案時,我們需要考慮 5 個要點。

1. 分片鍵如何選擇?

針對訂單這個業務,其中涉及到以下幾個主要的字段:

  • user_id:用戶id
  • order_id:訂單id
  • order_time:下單時間
  • store_id:店鋪id

經過考量,最終選擇了user_id作為ShardingKey,為什么呢?

選擇user_id作為ShardingKey需要結合業務場景,訂單系統中常見的業務:

  • C端用戶需要查詢所有的訂單(user_id)
  • 后臺需要根據城市查詢所有訂單(user_city_id)
  • B端商家需要統計自己店鋪的下單量(store_id)

以上三種業務場景,判斷下優先級,C端用戶肯定是需要優先滿足,因此使用user_id作為ShardingKey

這樣在查詢時需要將user_id傳遞過來才能定位到指定庫、表

選擇字段作為分片鍵時,我們一般需要考慮三點要求:數據盡量均勻分布在不同表或庫、跨庫查詢操作盡可能少、這個字段的值不會變(這點尤為重要)。

2. 分片的策略是什么?

選擇user_id作為ShardingKey之后,需要考慮使用分片策略了,主要分為如下三種

  • 范圍分片

假如user_id是自增的數字,則可以根據user_id范圍進行分片,每100萬份分為一個庫,每10萬份分為一個表,此時單個庫中將分為10張表,如下表:

圖片

  • Hash取模

這種方案是根據Hash值進行分片,比如Hash函數為:hash(user_id%8),這里是將user_id對8這個特定值取模,最終分為了8張表;這里一般為了方便后續擴容,建議選擇2的N次方

  • 范圍分片和Hash取模混合

比如先按照范圍對user_id拆分,每100萬份分為一個庫,在對這100萬份數據進行Hash取模(hash(user_id%8))拆分成8個表

當然以上三種方案的優缺點也是非常明顯,這里不再贅述了

需要注意的是:在拆分之前,為了避免頻繁的擴容,一定要對未來5年或者10年數據增長做個判斷,預留更多的分片

3. 業務代碼如何修改

業務代碼的修改這里就不好說了,和自身的業務是強關聯。

但是,在這里我想分享一些個人觀點。近年來,分表分庫操作愈發容易,不過我們需要注意幾個要點。

我們已經習慣微服務了,對于特定表的分表分庫,其影響面只在該表所在的服務中,如果是一個單體架構的應用做分表分庫,那真是傷腦筋。

在互聯網架構中,我們基本不使用外鍵約束。

隨著查詢分離的流行,后臺系統中有很多操作需要跨庫查詢,導致系統性能非常差,這時分表分庫一般會結合查詢分離一起操作:先將所有數據在 ES 索引一份,再使用 ES 在后臺直接查詢數據。如果訂單詳情數據量很大,還有一個常見做法,即先在 ES 中存儲索引字段(作為查詢條件的字段),再將詳情數據存放在 HBase 中(這個方案我們就不展開了)。

4. 歷史數據遷移?

歷史數據的遷移非常耗時,有時遷移幾天幾夜都很正常。而在互聯網行業中,別說幾天幾夜了,就連停機幾分鐘業務都無法接受,這就要求我們給出一個無縫遷移的解決方案。

還記得講解查詢分離時,我們說過的方案嗎?我們再來回顧下,如下圖所示:

圖片

歷史數據遷移時,我們就是采用類似的方案進行歷史數據遷移,如下圖所示:

圖片

此數據遷移方案的基本思路:存量數據直接遷移,增量數據監聽 binlog,然后通過 canal 通知遷移程序搬運數據,新的數據庫擁有全量數據,且校驗通過后逐步切換流量。

數據遷移解決方案詳細的步驟如下:

  • 上線 canal,通過 canal 觸發增量數據的遷移;
  • 遷移數據腳本測試通過后,將老數據遷移到新的分表分庫中;
  • 注意遷移增量數據與遷移老數據的時間差,確保全部數據都被遷移過去,無遺漏;
  • 第二步、第三步都運行完后,新的分表分庫中已經擁有全量數據了,這時我們可以運行數據驗證的程序,確保所有數據都存放在新數據庫中;
  • 到這步數據遷移就算完成了,之后就是新版本代碼上線了,至于是灰度上還是直接上,需要根據你們的實際情況決定,回滾方案也是一樣。

5. 未來的擴容方案是什么?

隨著業務的發展,如果原來的分片設計已經無法滿足日益增長的數據需求,我們就需要考慮擴容了,擴容方案主要依賴以下兩點。

  • 分片策略是否可以讓新表數據的遷移源只是 1 個舊表,而不是多個舊表,這就是前面我們建議使用 2 的 N 次方分表的原因;
  • 數據遷移:我們需要把舊分片的數據遷移到新的分片上,這個方案與上面提及的歷史數據遷移一樣,我們就不重復啰唆了。

分表分庫的不足

分表分庫的解決方案講完了,以上就是業界常用的一些做法,不過此方案仍然存在不足之處。

  • 增量數據遷移:如何保證數據的一致性及高可用性
  • 短時訂單量大爆發:分表分庫仍然扛不住時解決方案是什么?
責任編輯:武曉燕 來源: 碼猿技術專欄
相關推薦

2025-01-14 10:28:34

業務主表讀寫冷熱分離

2022-01-24 08:19:19

業務CRUD場景

2023-09-07 08:59:30

海量數據方案

2020-06-29 19:15:54

MySQL 數據量性能

2023-11-15 18:46:49

HBase數據庫開源

2021-06-29 08:12:22

MySQL數據分頁數據庫

2022-04-01 11:26:19

緩存數據庫讀寫策略

2011-05-05 14:32:10

微軟Exchange

2017-03-27 10:48:03

Hive map優化分析

2011-05-05 13:03:08

深信服廣域網加速

2023-10-04 18:29:24

NFS小文件業務

2023-07-25 16:07:53

CIOAI

2023-12-11 06:27:39

MySQL線上業務優化后臺上傳文件

2016-09-20 22:41:21

Linuxmmapreadahead

2022-01-27 08:14:54

數據優化讀寫分離

2018-07-26 14:50:00

數據庫MySQL大表優化

2013-01-04 10:43:46

IBMdW

2025-04-29 10:24:01

大數據StarRocksJOIN

2022-07-07 09:33:06

MySQL查詢數據優化

2010-11-24 10:35:34

MySQL單表多字段
點贊
收藏

51CTO技術棧公眾號

欧美9999| 在线观看黄av| 亚洲伦伦在线| 亚洲午夜精品视频| 三级黄色片免费观看| 精品精品导航| 中文子幕无线码一区tr| 97人人模人人爽人人喊38tv| 国产手机在线视频| 日韩国产一区| 欧美精品一区二区久久久| 日av中文字幕| 免费看电影在线| 国产精品欧美久久久久一区二区| 91偷拍精品一区二区三区| 超碰超碰超碰超碰| 中文字幕日韩一区二区不卡| 亚洲精品自拍视频| 黄色片免费网址| 国产精品久久久久av电视剧| 亚洲在线一区二区三区| 亚洲一区二区三区加勒比| 亚洲精品喷潮一区二区三区| 免费看日韩精品| 欧美亚州一区二区三区| 2021亚洲天堂| 久久亚洲精品中文字幕蜜潮电影| 日韩国产一区三区| 日本泡妞xxxx免费视频软件| 123成人网| 欧美午夜久久久| 亚洲熟妇无码av在线播放| 秋霞午夜在线观看| 欧美国产日本视频| 免费在线一区二区| 天堂中文在线资源| 国产成人av一区二区三区在线 | 678五月天丁香亚洲综合网| 男人天堂999| 8x8ⅹ拨牐拨牐拨牐在线观看| 亚洲女同女同女同女同女同69| 日韩精品久久一区| 天堂中文在线资| 91原创在线视频| 国产伦精品一区二区三区视频免费| 国产美女三级无套内谢| 蜜芽一区二区三区| 国产精品美女午夜av| 亚洲 欧美 中文字幕| 国产精品久久久久久模特| 国内精品国产三级国产在线专| 精品爆乳一区二区三区无码av| 91精品久久久久久久蜜月| 综合久久五月天| 国产精品suv一区二区88| 精品国产视频| 中文字幕欧美国内| 婷婷激情四射网| 亚洲欧美偷拍自拍| 欧美大片在线看免费观看| 国产大片免费看| 欧美日韩成人| 国精产品一区一区三区有限在线| 久久99久久98精品免观看软件| 亚洲私人影院| 久久久欧美精品| 草久久免费视频| 视频在线观看一区| 国产欧美中文字幕| 国产亲伦免费视频播放| 国产精品一区二区久久不卡 | 国产精品爽爽久久久久久| 国产一区二区三区在线看麻豆 | 人人网欧美视频| 亚洲区在线播放| 日本黄色小视频在线观看| 郴州新闻综合频道在线直播| 中文字幕亚洲专区| 亚洲欧美一区二区三区四区五区| 狠狠入ady亚洲精品| 91精品国产91久久| 青青视频在线免费观看| 麻豆精品在线播放| 成人一区二区三区四区| 毛片在线播放网站| 中文字幕亚洲欧美在线不卡| 成人污网站在线观看| 国产白浆在线免费观看| 欧美性一区二区| 国偷自产av一区二区三区麻豆| 欧美电影免费网站| 中文字幕九色91在线| 国产人妻精品一区二区三区不卡| 好看的亚洲午夜视频在线| 国产97在线播放| www.五月婷婷| 欧美极品少妇xxxxⅹ高跟鞋 | 亚洲资源av| 国产伦精品一区二区三区精品视频 | 欧美va天堂在线| 国产91免费观看| www.国产黄色| 国产精品女同互慰在线看| 欧美黄色免费网址| 成人交换视频| 日韩第一页在线| 99视频只有精品| 久热综合在线亚洲精品| 懂色一区二区三区av片| 成人全视频高清免费观看| 亚洲成av人综合在线观看| 性猛交ⅹ×××乱大交| 伦理一区二区| 久久躁日日躁aaaaxxxx| 91青青草视频| 不卡的av在线| 91免费国产精品| 亚洲男女网站| 国产一区二区日韩精品欧美精品| 国产无码精品在线观看| 精品中文av资源站在线观看| 欧美xxxx黑人又粗又长密月 | 一区二区三区在线影院| 狠狠热免费视频| 欧美黄色网视频| 久99久在线视频| 91成人在线免费| 国产亚洲欧洲一区高清在线观看| 妞干网视频在线观看| www欧美在线观看| 中文字幕欧美专区| 黄色一级视频免费看| www.av亚洲| 精品视频在线观看一区| 中文一区二区三区四区| 久久福利视频导航| 6—12呦国产精品| 中文字幕乱码一区二区免费| 免费av网址在线| 亚洲品质自拍| 欧洲日韩成人av| 欧美色图另类| 色一情一伦一子一伦一区| 9.1成人看片| 亚洲免费婷婷| 精品国产乱码久久久久久88av| 黄色大片在线| 亚洲精品成人久久| 圆产精品久久久久久久久久久| 成人夜色视频网站在线观看| 女人被男人躁得好爽免费视频 | 欧美一区二区女人| 免费国产羞羞网站美图| 国产一二精品视频| 人妻激情另类乱人伦人妻| 91精品尤物| 午夜精品久久久久久久男人的天堂| 欧美熟妇乱码在线一区| 午夜久久久影院| 欧美做受喷浆在线观看| 久久不射网站| 神马影院我不卡午夜| 久久er热在这里只有精品66| 久久精品91久久久久久再现| 亚洲成人中文字幕在线| 午夜精品久久久久久久99水蜜桃| 一级特级黄色片| 日韩国产精品91| 亚洲va久久久噜噜噜久久狠狠| 国产欧美自拍| 欧美日韩国产第一页| 丰满少妇在线观看bd| 精品久久久久久亚洲精品| 天天躁夜夜躁狠狠是什么心态| 日本va欧美va瓶| 日本黄xxxxxxxxx100| 成人高潮a毛片免费观看网站| 青青草一区二区| 91在线看黄| 精品国产一区二区三区不卡| 欧美一区免费看| 亚洲男人天堂av| 亚洲欧美视频在线播放| 美国十次了思思久久精品导航| 天堂av在线中文| 亚洲精品3区| 国产日韩精品视频| 九九精品调教| 亚洲色图色老头| 国产成人免费看一级大黄| 欧美视频在线观看免费| 国产精品精品软件男同| 99久久免费国产| 亚洲三级在线观看视频| 一本久道久久综合婷婷鲸鱼| 亚洲国产成人不卡| 国产精品xxxav免费视频| 国产精品r级在线| heyzo在线欧美播放| 在线观看欧美视频| 三级视频在线看| 欧美猛男男办公室激情| 精品免费囯产一区二区三区| 亚洲色图第一区| 国产真实乱人偷精品人妻| 国产成人欧美日韩在线电影| 日韩视频免费在线播放| 亚洲破处大片| 四虎一区二区| 日韩高清一级| 91亚色免费| 99久久99九九99九九九| 日韩av免费在线播放| www.九色在线| 色与欲影视天天看综合网| 免费黄色电影在线观看| 亚洲人成在线观看| 天堂网av2014| 欧美成人精精品一区二区频| 国产孕妇孕交大片孕| 欧美丝袜丝nylons| 日韩免费av网站| 欧美日韩亚洲精品内裤| 久久久久久天堂| 有码一区二区三区| 午夜爽爽爽男女免费观看| 国产农村妇女毛片精品久久麻豆| 特级西西人体4444xxxx| 成人国产亚洲欧美成人综合网| 日韩av加勒比| 精品一区二区三区免费播放| 亚洲色图久久久| 久久精品一本| 成年人黄色片视频| 久久国产精品亚洲77777| 欧洲精品一区二区三区久久| 欧美极品一区二区三区| 欧美一级中文字幕| 欧美三级第一页| 久久男人资源站| 韩国av一区| 国产尤物av一区二区三区| 亚洲国产日韩欧美在线| 黄色a级在线观看| 91av精品| 精品视频在线观看一区二区| 欧美午夜视频| 男女啪啪免费视频网站| 国产一级久久| 激情婷婷综合网| 免费观看久久久4p| 欧美日韩精品区别| 国产一区高清在线| 9191在线视频| av在线播放成人| wwwwxxxx国产| 国产日韩在线不卡| 日本黄色录像视频| 伊人一区二区三区| 国产午夜精品一区二区理论影院 | 99久久精品费精品国产一区二区| 国产二级一片内射视频播放 | 日韩一区二区三区免费观看| 精品久久久无码中文字幕| 精品少妇一区二区三区在线播放| 人妻一区二区三区免费| 亚洲男人天堂古典| av在线之家电影网站| 久久成年人视频| 国产免费拔擦拔擦8x高清在线人| 日本精品一区二区三区在线| 久久av日韩| 成人看片在线| 国模吧精品视频| 熟妇熟女乱妇乱女网站| 亚洲黄色免费| 亚洲免费一级视频| 国产ts人妖一区二区| 久久精品视频18| 亚洲欧洲制服丝袜| wwwxxx亚洲| 欧美狂野另类xxxxoooo| 天天综合天天色| 日韩在线观看你懂的| a级片在线免费观看| 国产精品美女久久久久久免费| 精品国产亚洲一区二区在线观看| 精品乱子伦一区二区三区| 久久美女精品| 免费看国产一级片| 麻豆国产精品视频| 屁屁影院国产第一页| 国产精品免费aⅴ片在线观看| 久久久全国免费视频| 91福利在线播放| 日本久久一级片| 精品国产美女在线| 色戒汤唯在线| 91精品网站| av一区二区高清| 久久精品国产sm调教网站演员| 老汉av免费一区二区三区| 日韩精品人妻中文字幕有码| 国产精品久久久久一区| 日韩色图在线观看| 欧美r级在线观看| 毛片av在线| 国产精品999| 欧美日韩一区二区三区不卡视频| 制服诱惑一区| 久久亚洲不卡| 国产精品无码网站| 亚洲一区二区三区中文字幕 | 亚洲欧美激情一区| 男女羞羞视频在线观看| 国产精品自拍网| 亚洲春色h网| 黄色大片中文字幕| 国产精品一色哟哟哟| 日韩欧美视频免费观看| 一本一本久久a久久精品综合麻豆| 黄色成人一级片| 欧美日韩第一视频| 精品一区二区三区中文字幕| 亚洲.欧美.日本.国产综合在线 | 日韩不卡的av| 亚洲欧洲精品成人久久奇米网| 天天射天天干天天| 精品小视频在线| 黄色在线观看www| 国产精品一国产精品最新章节| 欧美特黄一区| 日本人妻一区二区三区| 亚洲精品中文在线| 国产视频一区二区三区四区五区| 色阁综合伊人av| 成人在线高清| 亚洲视频欧美在线| 久久99国产乱子伦精品免费| 日韩一卡二卡在线观看| 欧美视频一二三区| eeuss影院在线播放| 国产成人综合一区二区三区| 国产精品一国产精品| 97在线播放视频| 久久久久国产成人精品亚洲午夜| 精品人妻无码一区二区性色| 国产婷婷97碰碰久久人人蜜臀| 亚洲精品mv| 色姑娘综合av| 麻豆国产91在线播放| 艳妇荡乳欲伦69影片| 91精品蜜臀在线一区尤物| 成人三级网址| 国产精品一区在线播放| 亚洲二区在线| 国产熟妇搡bbbb搡bbbb| 在线视频一区二区三| jyzzz在线观看视频| 91精品在线一区| 亚洲无线视频| 大地资源二中文在线影视观看| 色狠狠综合天天综合综合| а天堂8中文最新版在线官网| 国产欧美日韩专区发布| 影视一区二区| av鲁丝一区鲁丝二区鲁丝三区| 色又黄又爽网站www久久| av基地在线| 999久久久| 国产精品一国产精品k频道56| 法国空姐电影在线观看| 欧美日韩不卡一区二区| 久久av色综合| 日韩精品av一区二区三区| 激情综合色综合久久| 国产成人愉拍精品久久| 一本色道久久88综合亚洲精品ⅰ| 99久热在线精品视频观看| 国产v片免费观看| 国产欧美一区二区精品久导航| 国产视频一二三四区| 欧美有码在线视频| 色综合天天爱| 日本黄色录像片| 欧美日韩一区在线| av影院在线免费观看| 亚洲午夜精品国产| 成人午夜在线免费| 最近中文字幕av| 久久免费高清视频| 青青草91久久久久久久久| 在线播放av网址| 欧美色偷偷大香| 黄色激情在线播放| 黄色录像特级片| 国产欧美日韩精品a在线观看| 男人天堂av网| 国产中文字幕日韩| 蜜桃av一区|