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

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

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

優(yōu)化MySQL數(shù)據(jù)庫中樸實無華的分表和花里胡哨的分庫

5jek_harmonyos ? 來源:CSDN博客 ? 作者:_陳哈哈 ? 2021-08-26 16:33 ? 次閱讀

blog.csdn.net/qq_39390545/article/details/116248222

一、樸實無華的 - 分表

1、垂直分表

2、水平分表

二、花里胡哨的 - 分庫

3、垂直分庫

4、水平分庫

總結(jié)

首先我們要知道分庫、分表都是干啥的,本文主角還是我們的MySQL為第一視角。首先從字面意思來看:

分庫:由單個數(shù)據(jù)庫實例拆分成多個數(shù)據(jù)庫實例,將數(shù)據(jù)分布到多個數(shù)據(jù)庫實例中。

分表:由單張表拆分成多張表,將數(shù)據(jù)劃分到多張表內(nèi)。

要知道,對于大型互聯(lián)網(wǎng)項目,數(shù)據(jù)量級可能不是我們能想到的,每日新增數(shù)據(jù)量過千萬是常有的事兒,想靠單臺MySQL服務(wù)器是不現(xiàn)實的。你項羽在牛B,也頂不住四個隊友掛機啊?。№椨穑????

隨著業(yè)務(wù)數(shù)據(jù)量和網(wǎng)站QPS日益增高,對數(shù)據(jù)庫壓力也越來越大,單機版數(shù)據(jù)庫很快會到達存儲和并發(fā)瓶頸,就需要做數(shù)據(jù)庫性能方面的優(yōu)化,分庫分表采取的是分而治之的策略,分庫目的是減輕單臺MySQL實例存儲壓力及可擴展性,而分表是解決單張表數(shù)據(jù)過大以后查詢的瓶頸問題,坦白說,這些問題也是所有關(guān)系型數(shù)據(jù)庫的“硬傷”。

今天我們就基于常見分庫、分表的策略方式以及場景,來搞清楚我們到底啥時候用的到。常用策略包括:垂直分表、水平分表、垂直分庫、水平分庫。

一、樸實無華的 - 分表

1、垂直分表

垂直分表,或者叫豎著切表,是不是感受到該策略是以字段為依據(jù)的!主要按照字段的活躍性、字段長度,將表中字段拆分到不同的表(主表和擴展表)中。

特點:

每個表的結(jié)構(gòu)都不一樣;

每個表的數(shù)據(jù)也不一樣,

有一個關(guān)聯(lián)字段,一般是主鍵或外鍵,用于關(guān)聯(lián)兄弟表數(shù)據(jù);

所有兄弟表的并集是該表的全量數(shù)據(jù);

場景 :

有幾個字段屬于熱點字段,更新頻率很高,要把這些字段單獨切到一張表里,不然innodb行鎖很惡心的,鎖死你呀~~如用戶表里的余額字段?不,我的余額就很穩(wěn)定,一直是0。。

有大字段,如text,存儲壓力很大,畢竟innodb數(shù)據(jù)和索引是同一個文件;同時,我又喜歡用SELECT *,你懂得,這磁盤IO消耗的,跟玩兒似的,誰都扛不住的。

有明顯的業(yè)務(wù)區(qū)分,或表結(jié)構(gòu)設(shè)計時字段冗余;有些小伙伴看到第一點時,就發(fā)現(xiàn)陳哈哈是個菜雞,用戶表怎么會有余額字段?明顯有問題啊!趕緊先到評論區(qū)噴陳哈哈一波~~然后笑嘻嘻的發(fā)現(xiàn)原來是個小尾巴,真不要臉是吧。。是的,因此不同業(yè)務(wù)我們要把具體字段拆開,這樣才有利于業(yè)務(wù)后續(xù)擴展哦。

2、水平分表

水平分表,也叫“橫著切”。。以行數(shù)據(jù)為依據(jù)進行切分,一般按照某列的自容進行切分。

手機號表,我們可以通過前兩位或前三位進行切分,如131、132、133 → phone_131、phone_132、phone_133,手機號有11位(100億),量大是很正常的事兒,這年頭誰家老頭老太太每個手機呢是吧。這樣切就把一張大表切成了好幾十張小表,數(shù)據(jù)量不就下來了。有同學(xué)就問了那我怎么知道我這手機號查哪個表呢?一看你就沒認真看前兩行標紅的點,為啥標紅嘞?比如我查13100001111,那我截取前三位,動態(tài)拼接到查詢的表名上,就行了。

特點:

每個表的結(jié)構(gòu)都一樣;

每個表的數(shù)據(jù)都不一樣,沒有交集;

所有表的并集是該表的全量數(shù)據(jù);

場景 :單表的數(shù)據(jù)量過大或增長速度很快,已經(jīng)影響或即將會影響SQL查詢效率,加重了CPU負擔,提前到達瓶頸。記得水平分表越早越好,別問我為什么。。

你要有興趣試一試,就關(guān)注我,讓csdn研發(fā)同學(xué)給我的粉絲們分個表哈哈。。算了,別做夢了,忘了你是個菜狗了么~

二、花里胡哨的 - 分庫

需要你注意的是,傳統(tǒng)的分庫和我們熟悉的集群、主從復(fù)制可不是一個事兒;多節(jié)點集群是將一個庫復(fù)制成N個庫,從而通過讀寫分離實現(xiàn)多個MySQL服務(wù)的負載均衡,實際是圍繞一個庫來搞的,這個庫稱為Master主庫。而分庫就不同了,分庫是將這個主庫一分為N,比如一分為二,然后針對這兩個主庫,再配置2N個從庫節(jié)點。

3、垂直分庫

縱向切庫,太經(jīng)典的切分方式,基于表進行切分,通常是把新的業(yè)務(wù)模塊或集成公共模塊拆分出去,比如我們最熟悉的單點登錄、鑒權(quán)模塊。熟悉的味道,記得有一次我把一些沒用的表切到一個性能很好的服務(wù)器中,這服務(wù)器我專門用來學(xué)習,后來也不知被哪個狗腿子告密了~ 我**你個**,有種站出來,你個**東西。

特點:

每個庫的表都不一樣;

表不一樣,數(shù)據(jù)就更不一樣了~ 沒有任何交集;

每個庫相對獨立,模塊化

場景 :可以抽象出單獨的業(yè)務(wù)模塊時,可以抽象出公共區(qū)時(如字典、公共時間、公共配置等),或者想有一臺屬于自己的服務(wù)器時?

4、水平分庫

以行數(shù)據(jù)為依據(jù),將一個庫中的數(shù)據(jù)拆分到多個庫中。大型分表體驗一下?坦白說這種策略并不實用,因為會對后臺開發(fā)很不友好,有很多坑,不建議采用,理解即可。

特點:

每個庫的結(jié)構(gòu)都一樣;

每個庫的數(shù)據(jù)都不一樣,沒有交集;

所有庫的并集是全量數(shù)據(jù);

場景 :系統(tǒng)絕對并發(fā)量上來了,CPU內(nèi)存壓力大。分表難以根本上解決量的問題,并且還沒有明顯的業(yè)務(wù)歸屬來垂直分庫,主庫磁盤接近飽和。

總結(jié)

本文就到這里,希望你學(xué)廢了!其實,在實際工作中,我們在選擇分庫分表策略前,想到的應(yīng)該是從緩存、讀寫分離、SQL優(yōu)化等方面,因為這些能夠更直接、代價更小的解決問題。要記住動表就是動根本,你永遠不知道這張表后面會連帶多少歷史遺留問題,如果是個很大型的項目,遇到些問題你就跟經(jīng)理提議要分庫分表,小心被呼死~

責任編輯:haq

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

    關(guān)注

    8

    文章

    6715

    瀏覽量

    88307
  • MySQL
    +關(guān)注

    關(guān)注

    1

    文章

    789

    瀏覽量

    26283

原文標題:老大讓我優(yōu)化數(shù)據(jù)庫,我上來就分庫分表。。。

文章出處:【微信號:harmonyos_developer,微信公眾號:harmonyos_developer】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦

    軟件系統(tǒng)數(shù)據(jù)庫分庫設(shè)計

    的分布式集群,實現(xiàn)分庫表功能,解決數(shù)據(jù)庫中海量數(shù)據(jù)存儲和查詢性能的問題。MyCat 還是一個數(shù)據(jù)庫的集群中間件,主要實現(xiàn) RDBMS
    的頭像 發(fā)表于 08-22 11:39 ?215次閱讀
    軟件系統(tǒng)<b class='flag-5'>數(shù)據(jù)庫</b>的<b class='flag-5'>分庫</b><b class='flag-5'>分</b><b class='flag-5'>表</b>設(shè)計

    mysql怎么新建一個數(shù)據(jù)庫

    mysql怎么新建一個數(shù)據(jù)庫 如何新建一個數(shù)據(jù)庫MySQL 創(chuàng)建一個數(shù)據(jù)庫
    的頭像 發(fā)表于 12-28 10:01 ?714次閱讀

    數(shù)據(jù)庫數(shù)據(jù)恢復(fù)—未開啟binlog的Mysql數(shù)據(jù)庫數(shù)據(jù)恢復(fù)案例

    mysql數(shù)據(jù)庫數(shù)據(jù)恢復(fù)環(huán)境: 本地服務(wù)器,windows server操作系統(tǒng) ,部署有mysql單實例,數(shù)據(jù)庫引擎類型為innodb,
    的頭像 發(fā)表于 12-08 14:18 ?926次閱讀
    <b class='flag-5'>數(shù)據(jù)庫</b><b class='flag-5'>數(shù)據(jù)</b>恢復(fù)—未開啟binlog的<b class='flag-5'>Mysql</b><b class='flag-5'>數(shù)據(jù)庫</b><b class='flag-5'>數(shù)據(jù)</b>恢復(fù)案例

    eclipse怎么連接數(shù)據(jù)庫mysql

    連接Eclipse和MySQL數(shù)據(jù)庫可以通過JDBC(Java Database Connectivity)來實現(xiàn)。以下是詳細步驟: 下載并安裝MySQL數(shù)據(jù)庫:你首先需要下載并安裝
    的頭像 發(fā)表于 12-06 11:06 ?1029次閱讀

    mysql數(shù)據(jù)庫基礎(chǔ)命令

    MySQL是一個流行的關(guān)系型數(shù)據(jù)庫管理系統(tǒng),經(jīng)常用于存儲、管理和操作數(shù)據(jù)。在本文中,我們將詳細介紹MySQL的基礎(chǔ)命令,并提供與每個命令相關(guān)的詳細解釋。 登錄
    的頭像 發(fā)表于 12-06 10:56 ?438次閱讀

    mysql數(shù)據(jù)庫備份與還原

    法、備份文件的恢復(fù)以及一些常見問題的解決方案。 第一部MySQL備份的不同方法 1.1 使用mysqldump命令備份 mysqldump是MySQL提供的一個命令行工具,用于備份數(shù)據(jù)
    的頭像 發(fā)表于 11-23 14:32 ?1008次閱讀

    MySQL數(shù)據(jù)庫基礎(chǔ)知識

    的基礎(chǔ)知識,包括其架構(gòu)、數(shù)據(jù)類型、操作、查詢語句和數(shù)據(jù)導(dǎo)入導(dǎo)出等方面。 MySQL 數(shù)據(jù)庫架構(gòu) MyS
    的頭像 發(fā)表于 11-21 11:09 ?834次閱讀

    mysql數(shù)據(jù)庫如何創(chuàng)建數(shù)據(jù)表

    MySQL是一種常用的關(guān)系型數(shù)據(jù)庫管理系統(tǒng),可以用于創(chuàng)建和管理數(shù)據(jù)表。下面是一篇詳細的關(guān)于MySQL數(shù)據(jù)庫如何創(chuàng)建
    的頭像 發(fā)表于 11-21 11:08 ?1641次閱讀

    數(shù)據(jù)庫mysql基本增刪改查

    的基本增刪改查操作。 一、增加數(shù)據(jù)(INSERT) 在MySQL,可以使用INSERT語句來向數(shù)據(jù)庫添加
    的頭像 發(fā)表于 11-16 16:35 ?1352次閱讀

    mysql數(shù)據(jù)庫的增刪改查sql語句

    SQL語句,以幫助讀者全面了解MySQL的基本操作。 一、增加數(shù)據(jù)MySQL數(shù)據(jù)庫,我們可以使用INSERT語句來向
    的頭像 發(fā)表于 11-16 15:41 ?1017次閱讀

    mysql是一個什么類型的數(shù)據(jù)庫

    強、易于使用和管理。在本文中,我們將詳盡、詳實、細致地介紹MySQL的功能、優(yōu)勢、架構(gòu)、語法等方面。 一、MySQL的功能: 數(shù)據(jù)庫管理:MySQL具備創(chuàng)建和管理
    的頭像 發(fā)表于 11-16 14:43 ?1434次閱讀

    數(shù)據(jù)庫數(shù)據(jù)恢復(fù)—MySQL數(shù)據(jù)庫誤刪除記錄的數(shù)據(jù)恢復(fù)案例

    binlog。 數(shù)據(jù)庫故障&分析: 工作人員在執(zhí)行Delete命令刪除數(shù)據(jù)時未添加where子句進行篩選,導(dǎo)致全數(shù)據(jù)被刪除,刪除后未對該
    的頭像 發(fā)表于 11-09 15:16 ?1126次閱讀
    <b class='flag-5'>數(shù)據(jù)庫</b><b class='flag-5'>數(shù)據(jù)</b>恢復(fù)—<b class='flag-5'>MySQL</b><b class='flag-5'>數(shù)據(jù)庫</b><b class='flag-5'>表</b>誤刪除記錄的<b class='flag-5'>數(shù)據(jù)</b>恢復(fù)案例

    數(shù)據(jù)庫優(yōu)化那些事

    數(shù)據(jù)庫 設(shè)計 sql語句優(yōu)化 數(shù)據(jù)庫 大型項目拆分為小項目,每個項目有自己獨立的數(shù)據(jù)庫 原來所有數(shù)
    的頭像 發(fā)表于 10-08 11:49 ?481次閱讀
    <b class='flag-5'>數(shù)據(jù)庫</b><b class='flag-5'>優(yōu)化</b>那些事

    如何在Rust連接和使用MySQL數(shù)據(jù)庫

    MySQL是一個廣泛使用的關(guān)系型數(shù)據(jù)庫,Rust作為一門相對較新的系統(tǒng)級編程語言,具有C語言般的高性能、安全、并發(fā)等特性,因此與MySQL一起使用是一種非常有趣的選擇。在本教程,我們
    的頭像 發(fā)表于 09-30 17:05 ?1403次閱讀

    數(shù)據(jù)庫分區(qū)、分庫

    今天先說說數(shù)據(jù)庫數(shù)據(jù)分區(qū),分庫以及的內(nèi)容吧! 數(shù)據(jù)庫分區(qū)、
    的頭像 發(fā)表于 09-30 11:24 ?2039次閱讀