色哟哟视频在线观看-色哟哟视频在线-色哟哟欧美15最新在线-色哟哟免费在线观看-国产l精品国产亚洲区在线观看-国产l精品国产亚洲区久久

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

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

3天內不再提示

優化MySQL數據庫中樸實無華的分表和花里胡哨的分庫

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

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

一、樸實無華的 - 分表

1、垂直分表

2、水平分表

二、花里胡哨的 - 分庫

3、垂直分庫

4、水平分庫

總結

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

分庫:由單個數據庫實例拆分成多個數據庫實例,將數據分布到多個數據庫實例中。

分表:由單張表拆分成多張表,將數據劃分到多張表內。

要知道,對于大型互聯網項目,數據量級可能不是我們能想到的,每日新增數據量過千萬是常有的事兒,想靠單臺MySQL服務器是不現實的。你項羽在牛B,也頂不住四個隊友掛機啊!!項羽:???

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

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

一、樸實無華的 - 分表

1、垂直分表

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

特點:

每個表的結構都不一樣;

每個表的數據也不一樣,

有一個關聯字段,一般是主鍵或外鍵,用于關聯兄弟表數據;

所有兄弟表的并集是該表的全量數據;

場景 :

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

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

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

2、水平分表

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

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

特點:

每個表的結構都一樣;

每個表的數據都不一樣,沒有交集;

所有表的并集是該表的全量數據;

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

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

二、花里胡哨的 - 分庫

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

3、垂直分庫

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

特點:

每個庫的表都不一樣;

表不一樣,數據就更不一樣了~ 沒有任何交集;

每個庫相對獨立,模塊化

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

4、水平分庫

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

特點:

每個庫的結構都一樣;

每個庫的數據都不一樣,沒有交集;

所有庫的并集是全量數據;

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

總結

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

責任編輯:haq

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

    關注

    8

    文章

    7067

    瀏覽量

    89107
  • MySQL
    +關注

    關注

    1

    文章

    816

    瀏覽量

    26605

原文標題:老大讓我優化數據庫,我上來就分庫分表。。。

文章出處:【微信號:harmonyos_developer,微信公眾號:harmonyos_developer】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    數據庫數據恢復—Mysql數據庫表記錄丟失的數據恢復流程

    Mysql數據庫故障: Mysql數據庫表記錄丟失。 Mysql數據庫故障表現: 1、
    的頭像 發表于 12-16 11:05 ?170次閱讀
    <b class='flag-5'>數據庫</b><b class='flag-5'>數據</b>恢復—<b class='flag-5'>Mysql</b><b class='flag-5'>數據庫</b>表記錄丟失的<b class='flag-5'>數據</b>恢復流程

    Mybatis 攔截器實現單數據源內多數據庫切換

    數據庫 現在需要上線報表服務來查詢所有數據庫數據進行統計,那么現在的問題來了,該如何 滿足在配置一個數據源的情況下來查詢該
    的頭像 發表于 12-12 10:23 ?746次閱讀

    數據庫數據恢復—MYSQL數據庫ibdata1文件損壞的數據恢復案例

    mysql數據庫故障: mysql數據庫文件ibdata1、MYI、MYD損壞。 故障表現:1、數據庫無法進行查詢等操作;2、使用my
    的頭像 發表于 12-09 11:05 ?165次閱讀

    香港云服務器怎么部署MySQL數據庫

    在香港云服務器上部署MySQL數據庫的步驟如下: 步驟 1: 更新軟件包列表 首先,確保軟件包列表是最新的。在終端執行以下命令: sudo apt update 步驟 2: 安裝 MySQL
    的頭像 發表于 11-14 16:15 ?182次閱讀

    數據庫數據恢復—通過拼接數據庫碎片恢復SQLserver數據庫

    一個運行在存儲上的SQLServer數據庫,有1000多個文件,大小幾十TB。數據庫每10天生成一個NDF文件,每個NDF幾百GB大小。數據庫包含兩個LDF文件。 存儲損壞,數據庫
    的頭像 發表于 10-31 13:21 ?239次閱讀
    <b class='flag-5'>數據庫</b><b class='flag-5'>數據</b>恢復—通過拼接<b class='flag-5'>數據庫</b>碎片恢復SQLserver<b class='flag-5'>數據庫</b>

    MySQL性能優化淺析及線上案例

    手段則會對用戶的使用體驗造成影響,嚴重的則會直接導致訂單、金額直接受損,因而就需要時刻關注數據庫的性能問題。 2、 性能優化的幾個常見措施 數據庫性能優化的常見手段有很多,比如添加索引
    的頭像 發表于 10-22 15:17 ?699次閱讀
    <b class='flag-5'>MySQL</b>性能<b class='flag-5'>優化</b>淺析及線上案例

    數據庫數據恢復—SQL Server數據庫出現823錯誤的數據恢復案例

    SQL Server數據庫故障: SQL Server附加數據庫出現錯誤823,附加數據庫失敗。數據庫沒有備份,無法通過備份恢復數據庫
    的頭像 發表于 09-20 11:46 ?361次閱讀
    <b class='flag-5'>數據庫</b><b class='flag-5'>數據</b>恢復—SQL Server<b class='flag-5'>數據庫</b>出現823錯誤的<b class='flag-5'>數據</b>恢復案例

    華納云:MySQL初始化操作如何創建新的數據庫

    要在MySQL創建一個新的數據庫,可以按照以下步驟進行操作: 登錄到MySQL數據庫管理系統
    的頭像 發表于 09-04 14:30 ?275次閱讀

    軟件系統數據庫分庫設計

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

    數據庫數據恢復—SqlServer數據庫底層File Record被截斷為0的數據恢復案例

    SQL Server數據庫數據無法被讀取。 經過數據庫數據恢復工程師的初步檢測,發現SQL Server數據庫文件無法被讀取的原因是底層
    的頭像 發表于 07-26 11:27 ?401次閱讀
    <b class='flag-5'>數據庫</b><b class='flag-5'>數據</b>恢復—SqlServer<b class='flag-5'>數據庫</b>底層File Record被截斷為0的<b class='flag-5'>數據</b>恢復案例

    恒訊科技分析:sql數據庫怎么用?

    SQL數據庫的使用通常包括以下幾個基本步驟: 1、選擇數據庫系統: 選擇適合您需求的SQL數據庫系統,如MySQL、PostgreSQL、Microsoft SQL Server、SQ
    的頭像 發表于 07-15 14:40 ?364次閱讀

    分庫后復雜查詢的應對之道:基于DTS實時性ES寬構建技術實踐

    1 問題域 業務發展的初期,我們的數據庫架構往往是單,外加讀寫分離來快速的支撐業務,隨著用戶量和訂單量的增加,數據庫的計算和存儲往往會成為我們系統的瓶頸,業界的實踐多數采用分而治
    的頭像 發表于 06-25 18:30 ?876次閱讀
    <b class='flag-5'>分庫</b><b class='flag-5'>分</b><b class='flag-5'>表</b>后復雜查詢的應對之道:基于DTS實時性ES寬<b class='flag-5'>表</b>構建技術實踐

    ?通過Modbus讀寫數據庫數據

    本文是將數據庫數據轉為Modbus服務端/從站,實現數據庫內的數據也可以走Modbus協議通過網口或串口讀寫的案例,下圖是通過智能網關的參數軟件(在附件
    發表于 03-14 13:44

    怎么簡單實現由Labview讀取的串口數據自增寫入mysql5.7數據庫

    怎么簡單實現由Labview讀取的串口數據自增寫入mysql5.7數據庫? 已實現:串口數據的接收處理
    發表于 01-11 22:05

    MySQL數據庫通用空間詳解

    MySQL 數據庫中有效管理存儲和性能至關重要,通用空間為實現這一目標提供了靈活性。本文討論通用空間并探討其功能、優點和實際用法,并附有說明性示例。
    的頭像 發表于 01-10 09:33 ?2243次閱讀
    主站蜘蛛池模板: 好男人在线观看免费视频WWW| 国产 亚洲 日韩 欧美 在线观看| 99精品影视| 国内精品国内自产视频| 日韩视频中文字幕精品偷拍| 999精品免费视频| 久久综合一个色综合网| 野草观看免费高清视频| 韩国污动漫无遮掩无删减电脑版| 翁用力的抽插| 国产av在线看的| 色哦色哦哦色天天综合| 俄罗斯美幼| 双性大乳浪受噗呲噗呲h总| 国产成人精品自线拍| 手机在线播放成人亚洲影院电影| 俄罗斯9一14 young处| 四虎国产精品免费观看视频| 敌伦小芳的第一次| 偷偷鲁手机在线播放AV| 国产曰批试看免费视频播放免费 | 久久内在线视频精品mp4| 一级特黄aa大片欧美| 巨爆乳中文字幕爆乳区| 99久久爱re热6在线播放| 漂亮的保姆6在线观看中文| 国产CHINESE HD精品| 羞羞影院午夜男女爽爽免费| 狠狠操伊人| 999久久国产精品免费人妻| 秋霞电影伦网理最新在线看片| 父皇轻点插好疼H限| 亚洲aaaa级特黄毛片| 久久久97人妻无码精品蜜桃| aaaaaa级特色特黄的毛片| 2019久久视频这里有精品15| 免费成人高清在线视频| 高H高肉强J短篇NP| 亚洲日本va中文字幕久久| 免费亚洲视频在线观看| 国产精品成人免费观看|