成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

Mysql 單表適合的數據量是多少?如何優(yōu)化其性能?

數據庫 MySQL
Mysql 的 B+樹索引存儲在磁盤上,Mysql 每次讀取磁盤 Page 的大小是 16KB,為了保證每次查詢的效率,需要保證每次查詢訪問磁盤的次數,一般設計為 2-3 次磁盤訪問,再多性能將嚴重不足。Mysql B+樹索引的每個節(jié)點需要存儲一個指針(8Byte)和一個鍵值(8Byte)。

 我們說 Mysql 單表適合存儲的最大數據量,自然不是說能夠存儲的最大數據量,如果是說能夠存儲的最大量,那么,如果你使用自增 ID,最大就可以存儲 2^32 或 2^64 條記錄了,這是按自增 ID 的數據類型 int 或 bigint 來計算的;如果你不使用自增 id,且沒有 id 最大值的限制,如使用足夠長度的隨機字符串,那么能夠限制單表最大數據量的就只剩磁盤空間了。顯然我們不是在討論這個問題。

[[331633]]

影響 Mysql 單表的最優(yōu)最大數量的一個重要因素其實是索引。

我們知道 Mysql 的主要存儲引擎 InnoDB 采用 B+樹結構索引。(至于為什么 Mysql 選擇 b+樹而不是其他數據結構來組織索引,不是本文討論的話題,之后的文章會講到。)那么 B+樹索引是如何影響 Mysql 單表數據量的呢?

B+樹

一棵 B+樹如下所示:

Mysql 的 B+樹索引存儲在磁盤上,Mysql 每次讀取磁盤 Page 的大小是 16KB,為了保證每次查詢的效率,需要保證每次查詢訪問磁盤的次數,一般設計為 2-3 次磁盤訪問,再多性能將嚴重不足。Mysql B+樹索引的每個節(jié)點需要存儲一個指針(8Byte)和一個鍵值(8Byte)。因此計算16KB/(8B+8B)=1K 16KB 可以存儲 1K 個節(jié)點,3 次磁盤訪問(即 B+樹 3 的深度)可以存儲 1K _ 1K _ 1K 即 10 億數據。

如果查詢依賴非主鍵索引,那么還涉及二級索引。這樣數據量將更小。

拆分

分而治之——沒有什么問題不能通過拆分一次來解決,不行就拆多次。

Mysql 單表存儲的數據量有限。一個解決大數據量存儲的辦法就是分庫分表。說白了就是一個數據庫一張表放不下那么多數據,那就分多個數據庫多張表存儲。

拆分可分為垂直拆分和水平拆分。

垂直拆分是按照不同的表(或者 Schema)來切分到不同的數據庫(主機)之上,水平拆分則是根據表中的數據的邏輯關系,將同一個表中的數據按照某種條件拆分到多臺數據庫(主機)上面或多張相同 Schema 的不同表中。

垂直拆分的最大特點就是規(guī)則簡單,實施也更為方便,尤其適合各業(yè)務之間的耦合度非常低,相互影響很小,業(yè)務邏輯非常清晰的系統。在這種系統中,可以很容易做到將不同業(yè)務模塊所使用的表分拆到不同的數據庫中。根據不同的表來進行拆分,對應用程序的影響也更小,拆分規(guī)則也會比較簡單清晰。

水平拆分與垂直切分相比,相對來說稍微復雜一些。因為要將同一個表中的不同數據拆分到不同的數據庫中,對于應用程序來說,拆分規(guī)則本身就較根據表名來拆分更為復雜,后期的數據維護也會更為復雜一些。

垂直拆分最直接的就是按領域拆分服務,隔離領域數據庫。如此每個庫所承擔的數據壓力就減少了。

水平拆分就是將同一個 Schema 的數據拆分到不同的庫或不同的表中,這樣每個表的數據量也將減小,查詢效率將更高效。水平拆分就涉及到表的分片規(guī)則問題。

幾種典型的分片規(guī)則包括:

按照用戶 ID 求模,將數據分散到不同的數據庫,具有相同數據用戶的數據都被分散到一個庫中。

按照日期,將不同月甚至日的數據分散到不同的庫中。

按照某個特定的字段求摸,或者根據特定范圍段分散到不同的庫中。

實現

門面模式——沒有什么問題不能通過添加一個中間層來解決。

垂直拆分的一個方案就是在應用層使用多個數據源,按業(yè)務訪問不同的數據源。另外更好方案其實就是微服務化。按不同的業(yè)務領域來拆分微服務,明確領域邊界,隔離領域數據庫。這樣將對數據的存取內聚到獨立的服務之中,對外提供統一的接口。在需要同時依賴多個服務時,我們可以通過添加門面應用來組合底層服務的數據,以提供更符合上層業(yè)務需求的接口,這些服務往往更接近真實的業(yè)務。而底層的服務則是更加內聚的資源服務。

代理模式——沒有什么問題不能通過添加一個中間層來解決。

對于水平拆分應該盡量屏蔽拆分帶來的數據訪問困惱,為了讓上層業(yè)務無需關心下層數據組織方式。水平拆分往往通過添加一個代理層來做這些事情,代理層對上提供虛擬表,這些虛擬表就像我們在單庫上設計的單表一樣;代理層對下解析和拆分執(zhí)行 sql,然后按相應規(guī)則在不同的庫和表執(zhí)行相應的 sql 請求,再合并數據,并將合并后的結果返回給上層調用者。

一般代理方式分為如下兩種:

進程內代理進程內代理即將代理層嵌入到業(yè)務服務內部,攔截 sql 請求并做相應的處理。這樣的好處是簡單,但是侵入性大,且不夠靈活。

進程外代理進程外代理即將代理獨立成服務,代理真實業(yè)務服務和數據庫之間的請求。這樣是比較復雜的,需要高可用的代理服務架構。但是這樣對業(yè)務的侵入性低,且易于升級擴展。

問題

分布式事務問題

什么是分布式事務?本地事務的定義就是一系列相關的數據庫操作完成后要滿足 ACID 四大特性,而分布式事務就是將同一進程的操作放到不同的微服務進程中,即不同微服務應用進程的數據庫操作滿足事務要求,或者對不同數據庫的一系列操作需滿足事務要求。

這里就有兩個問題需要解決。一個是因為應用的分布式造成的,一個是因為數據庫本身的分布式造成的。數據庫本身的分布式事務問題一般由數據庫自身解決,大多數分布式數據庫都可以做到一定的數據一致性保證,如 HBase 保證的強一致性,Cassandra 保證的最終一致性。

應用數據的一致性事務方案我們也可以參考分布式數據庫的實現原理來實現。業(yè)界也有很多分布式事務的解決思路,如:

  • XA 方案
  • TCC 方案
  • 本地消息表
  • 可靠消息最終一致性方案
  • 最大努力通知方案

多表 Join 問題

通過分析 Join sql,將 sql 拆分成獨立的查詢請求,然后分別執(zhí)行,并將結果合并計算返回給調用者。這個地方會涉及到很多執(zhí)行優(yōu)化的問題。

數據統計問題

當數據被分片到不同的數據庫或不同的表中時,要對數據做一些全局的或涉及大量數據的統計時便會遇到一些問題。如求 Max,Min,Sum 等聚合問題。如果統計的數據有一定的業(yè)務規(guī)則,如只會按用戶維度去統計,如統計某個用戶的訂單量,那么對訂單表的分片,其實可以采用按用戶 id 來分片,如此就可以解決這類統計問題。但是這種方案不通用。很多分片代理服務都需要將 sql 分片到不同的節(jié)點上去執(zhí)行,然后再合并結果返回。

ID 問題

使用分庫分表之后,就無法使用 Mysql 的表自增作為 id,因為不同庫和表的自增將出現沖突的 id。解決這個問題就需要引入分布式 id 生成技術。

 

責任編輯:武曉燕 來源: 今日頭條
相關推薦

2019-06-27 16:40:30

MySQL單表數據數據庫

2022-10-14 17:24:35

MySQLSQL優(yōu)化

2018-07-11 20:07:06

數據庫MySQL索引優(yōu)化

2018-09-06 16:46:33

數據庫MySQL分頁查詢

2015-03-09 10:40:44

MySQL大量數據插入

2011-03-03 10:32:07

Mongodb億級數據量

2024-11-15 09:54:58

2011-08-16 09:21:30

MySQL大數據量快速語句優(yōu)化

2020-03-27 15:40:10

MySQL索引數據庫

2024-01-23 12:56:00

數據庫微服務MySQL

2010-12-01 09:18:19

數據庫優(yōu)化

2022-09-25 22:09:09

大數據量技術HDFS客戶端

2017-11-22 15:33:56

MySQL快速插入語句優(yōu)化

2021-04-07 10:20:31

MySQL數據庫命令

2012-12-26 09:23:56

數據庫優(yōu)化

2020-07-19 10:53:42

數據庫MySQL遷移

2021-06-29 08:12:22

MySQL數據分頁數據庫

2011-04-21 10:47:29

Webjavascript

2022-10-20 09:26:24

MySQLOracleSqlServer
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 黄色一级网| 欧美一级久久 | 黑人一级黄色大片 | a毛片 | 免费日韩av | 国产成人精品午夜 | 国产精品一区一区三区 | 伊人狼人影院 | 国产在线精品一区二区三区 | 国产精品久久久久久久久污网站 | 国产亚洲网站 | av第一页| 在线观看亚洲 | 色综合久久久 | 精产国产伦理一二三区 | 欧美日韩大片 | 一区二区成人 | 国产精品自产av一区二区三区 | 一区视频在线 | 日本欧美黄色片 | 91视频免费 | 激情久久网 | 国产精品欧美一区二区三区不卡 | 免费在线看黄视频 | 国产亚洲欧美在线 | 久久成人av | 91精品国产91久久久久久不卞 | 日韩高清国产一区在线 | 天堂在线www | 国产精品a一区二区三区网址 | 欧日韩不卡在线视频 | 日韩av第一页 | 成人小视频在线 | 日日干天天干 | 91极品尤物在线播放国产 | 日韩理论电影在线观看 | 国产精品毛片无码 | 亚洲成人国产 | 91精品国产99久久 | 一区二区三区精品在线视频 | 国产精品精品视频一区二区三区 |