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

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

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

3天內不再提示

數據庫瓶頸及分庫分表示例

數據分析與開發 ? 來源:數據分析與開發 ? 作者:數據分析與開發 ? 2020-09-24 15:52 ? 次閱讀

一、數據庫瓶頸

不管是IO瓶頸,還是CPU瓶頸,最終都會導致數據庫的活躍連接數增加,進而逼近甚至達到數據庫可承載活躍連接數的閾值。在業務Service來看就是,可用數據庫連接少甚至無連接可用。接下來就可以想象了吧(并發量、吞吐量、崩潰)。

1、IO瓶頸

第一種:磁盤讀IO瓶頸,熱點數據太多,數據庫緩存放不下,每次查詢時會產生大量的IO,降低查詢速度 ->分庫和垂直分表。 第二種:網絡IO瓶頸,請求的數據太多,網絡帶寬不夠 ->分庫。

2、CPU瓶頸

第一種:SQL問題,如SQL中包含join,group by,order by,非索引字段條件查詢等,增加CPU運算的操作 -> SQL優化,建立合適的索引,在業務Service層進行業務計算。 第二種:單表數據量太大,查詢時掃描的行太多,SQL效率低,CPU率先出現瓶頸 ->水平分表。

二、分庫分表

1、水平分庫

概念:以字段為依據,按照一定策略(hash、range等),將一個庫中的數據拆分到多個庫中。

結果:

每個庫的結構都一樣;

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

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

場景:系統絕對并發量上來了,分表難以根本上解決問題,并且還沒有明顯的業務歸屬來垂直分庫。

分析:庫多了,io和cpu的壓力自然可以成倍緩解。

2、水平分表

概念:以字段為依據,按照一定策略(hash、range等),將一個表中的數據拆分到多個表中。

結果:

每個表的結構都一樣;

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

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

場景:系統絕對并發量并沒有上來,只是單表的數據量太多,影響了SQL效率,加重了CPU負擔,以至于成為瓶頸。

分析:表的數據量少了,單次SQL執行效率高,自然減輕了CPU的負擔。

3、垂直分庫

概念:以表為依據,按照業務歸屬不同,將不同的表拆分到不同的庫中。

結果:

每個庫的結構都不一樣;

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

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

場景:系統絕對并發量上來了,并且可以抽象出單獨的業務模塊。

分析:到這一步,基本上就可以服務化了。例如,隨著業務的發展一些公用的配置表、字典表等越來越多,這時可以將這些表拆到單獨的庫中,甚至可以服務化。再有,隨著業務的發展孵化出了一套業務模式,這時可以將相關的表拆到單獨的庫中,甚至可以服務化。

4、垂直分表

概念:以字段為依據,按照字段的活躍性,將表中字段拆到不同的表(主表和擴展表)中。

結果:

每個表的結構都不一樣;

每個表的數據也不一樣,一般來說,每個表的字段至少有一列交集,一般是主鍵,用于關聯數據;

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

場景:系統絕對并發量并沒有上來,表的記錄并不多,但是字段多,并且熱點數據和非熱點數據在一起,單行數據所需的存儲空間較大。以至于數據庫緩存的數據行減少,查詢時會去讀磁盤數據產生大量的隨機讀IO,產生IO瓶頸。

分析:可以用列表頁和詳情頁來幫助理解。垂直分表的拆分原則是將熱點數據(可能會冗余經常一起查詢的數據)放在一起作為主表,非熱點數據放在一起作為擴展表。這樣更多的熱點數據就能被緩存下來,進而減少了隨機讀IO。拆了之后,要想獲得全部數據就需要關聯兩個表來取數據。但記住,千萬別用join,因為join不僅會增加CPU負擔并且會講兩個表耦合在一起(必須在一個數據庫實例上)。關聯數據,應該在業務Service層做文章,分別獲取主表和擴展表數據然后用關聯字段關聯得到全部數據。

三、分庫分表工具

sharding-sphere:jar,前身是sharding-jdbc;

TDDL:jar,Taobao Distribute Data Layer;

Mycat:中間件。

注:工具的利弊,請自行調研,官網和社區優先。

四、分庫分表步驟

根據容量(當前容量和增長量)評估分庫或分表個數 -> 選key(均勻)-> 分表規則(hash或range等)-> 執行(一般雙寫)-> 擴容問題(盡量減少數據的移動)。

五、分庫分表問題

1、非partition key的查詢問題

基于水平分庫分表,拆分策略為常用的hash法。

端上除了partition key只有一個非partition key作為條件查詢

映射法

基因法

注:寫入時,基因法生成user_id,如圖。關于xbit基因,例如要分8張表,23=8,故x取3,即3bit基因。根據user_id查詢時可直接取模路由到對應的分庫或分表。根據user_name查詢時,先通過user_name_code生成函數生成user_name_code再對其取模路由到對應的分庫或分表。id生成常用snowflake算法

端上除了partition key不止一個非partition key作為條件查詢

映射法

冗余法

注:按照order_id或buyer_id查詢時路由到db_o_buyer庫中,按照seller_id查詢時路由到db_o_seller庫中。感覺有點本末倒置!有其他好的辦法嗎?改變技術棧呢?

后臺除了partition key還有各種非partition key組合條件查詢

NoSQL法

冗余法

2、非partition key跨庫跨表分頁查詢問題

基于水平分庫分表,拆分策略為常用的hash法。 注:用**NoSQL法**解決(ES等)。

3、擴容問題

基于水平分庫分表,拆分策略為常用的hash法。

水平擴容庫(升級從庫法)

注:擴容是成倍的。

水平擴容表(雙寫遷移法)

第一步:(同步雙寫)修改應用配置和代碼,加上雙寫,部署;第二步:(同步雙寫)將老庫中的老數據復制到新庫中;第三步:(同步雙寫)以老庫為準校對新庫中的老數據;第四步:(同步雙寫)修改應用配置和代碼,去掉雙寫,部署;

注:雙寫是通用方案。

六、分庫分表總結

分庫分表,首先得知道瓶頸在哪里,然后才能合理地拆分(分庫還是分表?水平還是垂直?分幾個?)。且不可為了分庫分表而拆分。

選key很重要,既要考慮到拆分均勻,也要考慮到非partition key的查詢。

只要能滿足需求,拆分規則越簡單越好。

七、分庫分表示例

示例GitHub地址:https://github.com/littlecharacter4s/study-sharding

責任編輯:xj

原文標題:MySQL 常用分庫分表方案,都在這里了!

文章出處:【微信公眾號:數據分析與開發】歡迎添加關注!文章轉載請注明出處。

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

    關注

    30

    文章

    4803

    瀏覽量

    68766
  • MySQL
    +關注

    關注

    1

    文章

    817

    瀏覽量

    26637

原文標題:MySQL 常用分庫分表方案,都在這里了!

文章出處:【微信號:DBDevs,微信公眾號:數據分析與開發】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    數據庫是哪種數據庫類型?

    數據庫是一種部署在虛擬計算環境中的數據庫,它融合了云計算的彈性和可擴展性,為用戶提供高效、靈活的數據庫服務。云數據庫主要分為兩大類:關系型數據庫
    的頭像 發表于 01-07 10:22 ?92次閱讀

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

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

    數據庫事件觸發的設置和應用

    數據庫無論對于生產管理還是很多的實際應用都非常重要。小編這次聊一下數據庫事件觸發的應用。示例使用了postgresql和Python。
    的頭像 發表于 12-13 15:14 ?172次閱讀

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

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

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

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

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

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

    Oracle數據恢復—異常斷電后Oracle數據庫報錯的數據恢復案例

    Oracle數據庫故障: 機房異常斷電后,Oracle數據庫報錯:“system01.dbf需要更多的恢復來保持一致性,數據庫無法打開”。數據
    的頭像 發表于 09-30 13:31 ?330次閱讀
    Oracle<b class='flag-5'>數據</b>恢復—異常斷電后Oracle<b class='flag-5'>數據庫</b>啟<b class='flag-5'>庫</b>報錯的<b class='flag-5'>數據</b>恢復案例

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

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

    軟件系統數據庫分庫表設計

    軟件系統數據庫分庫表設計 系統讀寫分離、分庫表技術實現采用MyCat中間件,MyCat 是一款開源(遵循 Apache License
    的頭像 發表于 08-22 11:39 ?339次閱讀
    軟件系統<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 ?411次閱讀
    <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 Server數據庫所在分區空間不足報錯的數據恢復案例

    SQL Server數據庫數據恢復環境: 某品牌服務器存儲中有兩組raid5磁盤陣列。操作系統層面跑著SQL Server數據庫,SQL Server數據庫存放在D盤分區中。
    的頭像 發表于 07-10 13:54 ?528次閱讀

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

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

    數據庫數據恢復—raid5陣列上層Sql Server數據庫數據恢復案例

    數據庫數據恢復環境: 5塊硬盤組建一組RAID5陣列,劃分LUN供windows系統服務器使用。windows系統服務器內運行了Sql Server數據庫,存儲空間在操作系統層面劃分了三個邏輯分區
    的頭像 發表于 05-08 11:43 ?530次閱讀
    <b class='flag-5'>數據庫</b><b class='flag-5'>數據</b>恢復—raid5陣列上層Sql Server<b class='flag-5'>數據庫</b><b class='flag-5'>數據</b>恢復案例

    選擇 KV 數據庫最重要的是什么?

    經常有客戶提到 KV 數據庫,但卻偏偏“不要 Redis”。比如有個做安全威脅分析平臺的客戶,他們明確表示自己對可靠性要求非常高,需要的不是開源 Redis 這種內存緩存,而是 KV 數據庫
    的頭像 發表于 03-28 22:11 ?716次閱讀
    選擇 KV <b class='flag-5'>數據庫</b>最重要的是什么?

    數據庫數據恢復】Oracle數據庫ASM實例無法掛載的數據恢復案例

    oracle數據庫ASM磁盤組掉線,ASM實例不能掛載。數據庫管理員嘗試修復數據庫,但是沒有成功。
    的頭像 發表于 02-01 17:39 ?543次閱讀
    【<b class='flag-5'>數據庫</b><b class='flag-5'>數據</b>恢復】Oracle<b class='flag-5'>數據庫</b>ASM實例無法掛載的<b class='flag-5'>數據</b>恢復案例
    主站蜘蛛池模板: jlzzzjizzzjlzzz亚洲| 亚洲成av人影院| 欧美最猛黑人XXXXWWW| 天美传媒MV高清免费看| 亚洲性无码av在线| xx69美国| 精品国产乱码久久久人妻| 欧美激情视频二区| 亚洲欧美日本国产在线观18| 办公室韩国电影免费完整版| 极品少妇高潮啪啪无码吴梦 | 亚洲午夜精品一区二区公牛电影院| 99久久免费视频6| 久久re这里视频精品8| 午夜亚洲动漫精品AV网站| bt天堂午夜国产精品| 九色PORNY丨视频入口| 欧美特黄三级成人| 亚洲看片无码免费视频| acg全彩无遮挡口工漫画网址| 饥渴的40岁熟妇完整版在线| 色妺妺免费影院| 欧美日韩视频一区二区三区| 国际老妇高清在线观看| 色综合久久五月| 国色精品VA在线观看免费视频| 一本道高清码| 女神被调教成了精盆| 高清无码色大片中文| 亚洲精品午夜VA久久成人| 两个吃奶一个添下面视频| www黄色大片| 午夜理伦大片一级| 久久久久99精品成人片三人毛片| 97人妻在线公开视频在线观看| 日日噜噜夜夜躁躁狠狠| 极品美女久久久久久久久久久| a免费在线观看视频| 星空无限传媒视频在线观看视频| 久久精品国产在热亚洲| 草莓视频app深夜福利|