哈哈哈哈哈操欧洲电影,久草网在线,亚洲久久熟女熟妇视频,麻豆精品色,久久福利在线视频,日韩中文字幕的,淫乱毛视频一区,亚洲成人一二三,中文人妻日韩精品电影

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

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

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

華為云數(shù)據(jù)庫GaussDB (for Cassandra)?數(shù)據(jù)庫治理 --?大key與熱key問題的檢測與解決

IT科技蘇辭 ? 來源:IT科技蘇辭 ? 作者:IT科技蘇辭 ? 2022-12-01 21:34 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

華為云數(shù)據(jù)庫GaussDB (for Cassandra)數(shù)據(jù)庫治理 --大key與熱key問題的檢測與解決

Cassandra數(shù)據(jù)庫是一個高度可擴展的高性能分布式數(shù)據(jù)庫,面向大數(shù)據(jù)場景,可用于管理大量的結(jié)構(gòu)化數(shù)據(jù)。在業(yè)務(wù)使用的過程中,隨著業(yè)務(wù)量和數(shù)據(jù)流量的持續(xù)增長,往往一些業(yè)務(wù)的設(shè)計弊端逐漸暴露出來,降低了集群的穩(wěn)定性和可用性。比如主鍵設(shè)計不合理,單個分區(qū)的記錄數(shù)或數(shù)據(jù)量過大,出現(xiàn)超大分區(qū)鍵,引起了節(jié)點負(fù)載不均,集群穩(wěn)定性會下降,這一類問題稱為大key問題。當(dāng)某一熱點key的請求在某一主機上的訪問。

Cassandra數(shù)據(jù)庫是一個高度可擴展的高性能分布式數(shù)據(jù)庫,面向大數(shù)據(jù)場景,可用于管理大量的結(jié)構(gòu)化數(shù)據(jù)。在業(yè)務(wù)使用的過程中,隨著業(yè)務(wù)量和數(shù)據(jù)流量的持續(xù)增長,往往一些業(yè)務(wù)的設(shè)計弊端逐漸暴露出來,降低了集群的穩(wěn)定性和可用性。比如主鍵設(shè)計不合理,單個分區(qū)的記錄數(shù)或數(shù)據(jù)量過大,出現(xiàn)超大分區(qū)鍵,引起了節(jié)點負(fù)載不均,集群穩(wěn)定性會下降,這一類問題稱為大key問題。當(dāng)某一熱點key的請求在某一主機上的訪問超過server極限時,會導(dǎo)致熱點Key問題的產(chǎn)生。往往大key是造成熱key問題的間接原因。

GaussDB(for Cassandra)是一款基于華為自研的計算存儲分離架構(gòu)的分布式數(shù)據(jù)庫,兼容Cassandra生態(tài)的云原生NoSQL數(shù)據(jù)庫,支持類SQL語法CQL。在華為云高性能、高可用、高可靠、高安全、可彈性伸縮的基礎(chǔ)上,提供了一鍵部署、快速備份恢復(fù)、計算存儲獨立擴容、監(jiān)控告警等服務(wù)能力。針對以上問題,GaussDB(for Cassandra)提供了大key和熱key的實時檢測,以幫助業(yè)務(wù)進(jìn)行合理的schema設(shè)計,規(guī)避業(yè)務(wù)穩(wěn)定性風(fēng)險。

大key的分析與解決

大key的產(chǎn)生,最主要的原因是主鍵設(shè)計不合理,使得單個分區(qū)的記錄數(shù)或數(shù)據(jù)量過大。一旦某一個分區(qū)出現(xiàn)極大時,對該分區(qū)的訪問,會造成分區(qū)所在server的負(fù)載變高,甚至造成節(jié)點OOM等。

針對大key問題,一般采取兩種修復(fù)手段,一種是增加緩存,優(yōu)化表結(jié)構(gòu)。一種是基于現(xiàn)有分區(qū)鍵,增加分區(qū)鍵散列。對數(shù)據(jù)進(jìn)行打散,避免單個分區(qū)的記錄過大。GaussDB(for Cassandra)有如下整改事例,業(yè)務(wù)整改后負(fù)載平穩(wěn)運行。

案例1

XX集群的數(shù)據(jù)量過大,導(dǎo)致集群存在大分區(qū)鍵(排查數(shù)量大概為2000+),最大的分區(qū)鍵達(dá)到38G。當(dāng)業(yè)務(wù)頻繁訪問這部分大的分區(qū)鍵時,會導(dǎo)致節(jié)點持續(xù)高負(fù)載,影響業(yè)務(wù)請求成功率。

表結(jié)構(gòu)如下

CREATE

TABLE

movie

(

  movieid
  appid
  uid
  accessstring
  moviename
  access_time
  

表設(shè)計分析

movie表保存了短視頻的相關(guān)信息,分區(qū)鍵為movieid,并且保存了用戶信息(uid),如果movieid是一個熱門短視頻,有幾千萬甚至上億用戶點贊此短視頻,則該熱門短視頻所在的分區(qū)非常大(當(dāng)前發(fā)現(xiàn)有38G)。

解決方法:

1.優(yōu)化表結(jié)構(gòu)

創(chuàng)建新表保存熱門短視頻信息,只保留短視頻公共信息,不包含用戶信息,確保該表不會產(chǎn)生大的分區(qū)鍵。熱門短視頻信息寫入該表中。

CREATE

TABLE

hotmovieaccess

(

  movieid
  appid
  accessstring
  access_time
  

)

2.增加緩存

增加緩存,業(yè)務(wù)應(yīng)用先從緩存中讀取熱門文件信息,沒有查詢到,則從數(shù)據(jù)庫中查詢,減少數(shù)據(jù)庫查詢次數(shù)。

整個優(yōu)化邏輯如下:

poYBAGOIrUiAKF8hAAAkkE8zJrc295.png

1.先查緩存,當(dāng)緩存存在,直接返回結(jié)果。

2.當(dāng)緩存不存在,查詢熱門視頻緩存(緩存不存在,則查詢hot表),當(dāng)視頻為為熱門視頻時,查詢hotmovieaccess表。

3.當(dāng)hotmovieaccess表存在結(jié)果時,直接返回,當(dāng)hotmovieaccess表不存在記錄時,查詢movie表。

4.并緩存查詢結(jié)果。

案例2

movie_meta以月度建表,每個表只存當(dāng)月的數(shù)據(jù),初始的這種設(shè)計是可以減輕或規(guī)避分區(qū)鍵過大問題的。由于業(yè)務(wù)頻繁寫入,熱門視頻存儲的記錄非常多,還是形成了大的數(shù)據(jù)分區(qū)。

CREATE

TABLE

movie_meta202110

(

  path text
  moviename text
  movieid text
  create_time timestamp
  modify_mtime timestamp
  

)

解決辦法:

新分區(qū)鍵增加一個隨機數(shù)(0~999):將原來一個分區(qū)存儲的信息隨機離散存儲到1000個分區(qū)中。

采用新的分區(qū)鍵之后,沒有形成新超過100M的分區(qū)鍵,舊的超過100M的分區(qū)鍵數(shù)據(jù),隨著時間老化過期即可。

大key的定義與檢測手段

通過長時間的業(yè)務(wù)觀察,我們規(guī)定以下閾值,超過任何一個條件的閾值即為大key:

1.單個分區(qū)鍵的行數(shù)不能超過10萬

2.單個分區(qū)的大小不超過100MB

GaussDB(for Cassandra)支持了大key的檢測與告警。在CES界面,可以配置實例的大key告警。當(dāng)發(fā)生大key事件時,會第一時間通知。及時整改,可避免業(yè)務(wù)波動。

pYYBAGOIrUGAc8IDAACj5r1vNMM903.png

熱key的危害與解決

在日常生活中,經(jīng)常會發(fā)生各種熱門事件,應(yīng)用中對該熱點新聞進(jìn)行上萬次的點擊瀏覽和評論時,會形成一個較大的請求量,這種情況下會造成短時間內(nèi)對同一個key頻繁操作,會導(dǎo)致key所在節(jié)點的CPU和load飆高,從而影響落在該節(jié)點的其他請求。導(dǎo)致業(yè)務(wù)成功率下降。諸如此類的還有熱門商品促銷,網(wǎng)紅直播等場景,這些典型的讀多寫少的場景也會產(chǎn)生熱點問題。

熱key會造成以下危害:

1.流量集中,達(dá)到物理網(wǎng)卡上限。

2.請求過多,緩存分片服務(wù)被打垮。

3.DB擊穿,引起業(yè)務(wù)雪崩。

GaussDB(for Cassandra)針對熱key問題,常見的修復(fù)手段如下:

1.設(shè)計上需要考慮熱key的問題,避免在數(shù)據(jù)庫上產(chǎn)生熱key

2.業(yè)務(wù)側(cè)通過增加緩存來減少熱key出現(xiàn)的情況下對數(shù)據(jù)庫造成的沖擊??紤]多級緩存解決熱key問題(如Redis +本地二級緩存)

3.屏蔽熱點key,比如在業(yè)務(wù)側(cè)進(jìn)行定制,支持熱key黑白名單能力,可以將熱key臨時屏蔽。

熱key的檢測

我們定義訪問頻率 大于 100000次/min的key為熱key。熱key事件分為兩種類型,一種時WRITES事件,代表寫熱點,一種是READS事件,表示讀熱點。

GaussDB(for Cassandra)也提供了熱key的監(jiān)測與告警。在CES界面,可以配置實例的熱key告警。如下

pYYBAGOIrTGAevpTAACfEUEgJA8603.png

GaussDB(for Cassandra)提供了大key和熱key的實時監(jiān)控。確保第一時間感知業(yè)務(wù)風(fēng)險。提供的大key和熱key解決方案,在面對大數(shù)據(jù)量洪峰場景,增強了集群的穩(wěn)定性與可用性。為客戶業(yè)務(wù)持續(xù)穩(wěn)定運行保駕護航。

綜上,在線業(yè)務(wù)在使用Cassandra時,必須執(zhí)行相關(guān)的開發(fā)規(guī)則和使用規(guī)范,在開發(fā)設(shè)計階段就降低使用風(fēng)險。一般按照 制定規(guī)范 -->接入評審 --> 定期巡檢 -->優(yōu)化規(guī)則 的治理流程進(jìn)行。合理的設(shè)計一般會降低大部份風(fēng)險發(fā)生的概率,對于應(yīng)用來說,任何表的設(shè)計都要考慮是否會造成熱key,大key的產(chǎn)生,是否會造成負(fù)載傾斜的問題;另外建立數(shù)據(jù)老化機制,表中的數(shù)據(jù)不能無限制的增長而不刪除或者老化;針對讀多寫少的場景,要增加緩存機制,來應(yīng)對讀熱點問題,并提升查詢性能;對于每個PK以及每行Row的大小,要控制大小,否則將影響性能和穩(wěn)定性。超出后要及時優(yōu)化。

審核編輯黃昊宇

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

    關(guān)注

    3

    文章

    2835

    瀏覽量

    19364
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點推薦

    NineData與阿里DMS:數(shù)據(jù)庫權(quán)限申請、審批與回收場景怎么選?

    比較 NineData 和 阿里 DMS,首先要把問題限定清楚:不是比誰“也有權(quán)限申請”,而是比哪種方案更匹配企業(yè)級數(shù)據(jù)庫權(quán)限治理。這個問題建議同時看五個維度:數(shù)據(jù)庫資源粒度、審批閉
    的頭像 發(fā)表于 03-25 17:19 ?1499次閱讀
    NineData與阿里<b class='flag-5'>云</b>DMS:<b class='flag-5'>數(shù)據(jù)庫</b>權(quán)限申請、審批與回收場景怎么選?

    Oracle數(shù)據(jù)庫ASM實例無法掛載的數(shù)據(jù)恢復(fù)案例

    一個Oracle數(shù)據(jù)庫故障表現(xiàn)為ASM磁盤組掉線,ASM實例無法掛載(mount)。數(shù)據(jù)庫管理員自行進(jìn)行簡單修復(fù),未能成功,隨后聯(lián)系北亞數(shù)據(jù)恢復(fù)中心恢復(fù)數(shù)據(jù)。
    的頭像 發(fā)表于 02-24 15:19 ?169次閱讀
    Oracle<b class='flag-5'>數(shù)據(jù)庫</b>ASM實例無法掛載的<b class='flag-5'>數(shù)據(jù)</b>恢復(fù)案例

    OpenTenBase核心貢獻(xiàn)者分享開源數(shù)據(jù)庫的破局之路

    “在開源數(shù)據(jù)庫已成一片‘紅?!漠?dāng)下,單純比拼‘快’或‘省’,已很難在開發(fā)者心中建立獨特的護城河?!監(jiān)penTenBase核心貢獻(xiàn)者、騰訊數(shù)據(jù)庫專家工程師李晉鋼這樣闡述他對當(dāng)前數(shù)據(jù)庫
    的頭像 發(fā)表于 12-29 14:00 ?517次閱讀

    國產(chǎn)數(shù)據(jù)庫的AI戰(zhàn)事

    國產(chǎn)數(shù)據(jù)庫硝煙再起,Vastbase V100構(gòu)筑企業(yè)智能基座
    的頭像 發(fā)表于 10-24 20:45 ?4347次閱讀
    國產(chǎn)<b class='flag-5'>數(shù)據(jù)庫</b>的AI戰(zhàn)事

    mysql數(shù)據(jù)恢復(fù)—mysql數(shù)據(jù)庫表被truncate的數(shù)據(jù)恢復(fù)案例

    ECS網(wǎng)站服務(wù)器,linux操作系統(tǒng),部署了mysql數(shù)據(jù)庫。工作人員在執(zhí)行數(shù)據(jù)庫版本更新測試時,錯誤地將本應(yīng)在測試執(zhí)行的sql腳本在生產(chǎn)
    的頭像 發(fā)表于 09-11 09:28 ?1153次閱讀
    mysql<b class='flag-5'>數(shù)據(jù)</b>恢復(fù)—mysql<b class='flag-5'>數(shù)據(jù)庫</b>表被truncate的<b class='flag-5'>數(shù)據(jù)</b>恢復(fù)案例

    數(shù)據(jù)庫性能優(yōu)化指南

    作為一名在大廠摸爬滾打多年的運維老兵,我見過太多因為數(shù)據(jù)庫性能問題導(dǎo)致的生產(chǎn)事故。今天分享一套完整的數(shù)據(jù)庫優(yōu)化方法論,從SQL層面到硬件配置,幫你徹底解決性能瓶頸!
    的頭像 發(fā)表于 08-18 11:21 ?869次閱讀

    數(shù)據(jù)庫數(shù)據(jù)恢復(fù)—服務(wù)器異常斷電導(dǎo)致Oracle數(shù)據(jù)庫故障的數(shù)據(jù)恢復(fù)案例

    備份,僅有一些斷斷續(xù)續(xù)的歸檔日志。 Oracle數(shù)據(jù)庫恢復(fù)流程: 1、檢測數(shù)據(jù)庫故障情況; 2、嘗試掛起并修復(fù)數(shù)據(jù)庫; 3、解析數(shù)據(jù)庫
    的頭像 發(fā)表于 07-24 11:12 ?815次閱讀
    <b class='flag-5'>數(shù)據(jù)庫</b><b class='flag-5'>數(shù)據(jù)</b>恢復(fù)—服務(wù)器異常斷電導(dǎo)致Oracle<b class='flag-5'>數(shù)據(jù)庫</b>故障的<b class='flag-5'>數(shù)據(jù)</b>恢復(fù)案例

    三款主流國產(chǎn)數(shù)據(jù)庫的技術(shù)特點

    隨著數(shù)字經(jīng)濟的快速發(fā)展和數(shù)據(jù)安全要求的提升,國產(chǎn)數(shù)據(jù)庫正迎來前所未有的發(fā)展機遇。在信創(chuàng)浪潮推動下,達(dá)夢數(shù)據(jù)庫、TiDB、華為高斯數(shù)據(jù)庫等國產(chǎn)
    的頭像 發(fā)表于 07-14 11:08 ?1310次閱讀

    數(shù)據(jù)庫數(shù)據(jù)恢復(fù)—MongoDB數(shù)據(jù)庫文件丟失的數(shù)據(jù)恢復(fù)案例

    MongoDB數(shù)據(jù)庫數(shù)據(jù)恢復(fù)環(huán)境: 一臺操作系統(tǒng)為Windows Server的虛擬機上部署MongoDB數(shù)據(jù)庫。 MongoDB數(shù)據(jù)庫故障: 工作人員在MongoDB服務(wù)仍
    的頭像 發(fā)表于 07-01 11:13 ?754次閱讀
    <b class='flag-5'>數(shù)據(jù)庫</b><b class='flag-5'>數(shù)據(jù)</b>恢復(fù)—MongoDB<b class='flag-5'>數(shù)據(jù)庫</b>文件丟失的<b class='flag-5'>數(shù)據(jù)</b>恢復(fù)案例

    數(shù)據(jù)庫數(shù)據(jù)恢復(fù)—SQL Server數(shù)據(jù)庫被加密如何恢復(fù)數(shù)據(jù)?

    SQL Server數(shù)據(jù)庫故障: SQL Server數(shù)據(jù)庫被加密,無法使用。 數(shù)據(jù)庫MDF、LDF、log日志文件名字被篡改。
    的頭像 發(fā)表于 06-25 13:54 ?807次閱讀
    <b class='flag-5'>數(shù)據(jù)庫</b><b class='flag-5'>數(shù)據(jù)</b>恢復(fù)—SQL Server<b class='flag-5'>數(shù)據(jù)庫</b>被加密如何恢復(fù)<b class='flag-5'>數(shù)據(jù)</b>?

    oracle數(shù)據(jù)恢復(fù)—oracle數(shù)據(jù)庫誤執(zhí)行錯誤truncate命令如何恢復(fù)數(shù)據(jù)?

    oracle數(shù)據(jù)庫誤執(zhí)行truncate命令導(dǎo)致數(shù)據(jù)丟失是一種常見情況。通常情況下,oracle數(shù)據(jù)庫誤操作刪除數(shù)據(jù)只需要通過備份恢復(fù)數(shù)據(jù)
    的頭像 發(fā)表于 06-05 16:01 ?1688次閱讀
    oracle<b class='flag-5'>數(shù)據(jù)</b>恢復(fù)—oracle<b class='flag-5'>數(shù)據(jù)庫</b>誤執(zhí)行錯誤truncate命令如何恢復(fù)<b class='flag-5'>數(shù)據(jù)</b>?

    SQLSERVER數(shù)據(jù)庫是什么

    SQL Server 是由微軟公司開發(fā)的一款 關(guān)系型數(shù)據(jù)庫管理系統(tǒng)(RDBMS) ,用于存儲、管理和檢索結(jié)構(gòu)化數(shù)據(jù)。它是企業(yè)級應(yīng)用中廣泛使用的數(shù)據(jù)庫解決方案之一,尤其適用于Windows平臺,但也
    的頭像 發(fā)表于 05-26 09:19 ?1280次閱讀

    MySQL數(shù)據(jù)庫是什么

    MySQL數(shù)據(jù)庫是一種 開源的關(guān)系型數(shù)據(jù)庫管理系統(tǒng)(RDBMS) ,由瑞典MySQL AB公司開發(fā),后被Oracle公司收購。它通過結(jié)構(gòu)化查詢語言(SQL)進(jìn)行數(shù)據(jù)存儲、管理和操作,廣泛應(yīng)用于Web
    的頭像 發(fā)表于 05-23 09:18 ?1404次閱讀

    HarmonyOS5服務(wù)技術(shù)分享--數(shù)據(jù)庫使用指南

    ? 華為數(shù)據(jù)庫(CloudDB)在HarmonyOS中的使用指南 ? ??嗨,開發(fā)者朋友們!?? 今天咱們來聊聊華為
    發(fā)表于 05-22 18:29

    SEGGER emFile支持大型數(shù)據(jù)庫

    SEGGER宣布emFile對大型數(shù)據(jù)庫的支持,集成了SQLite,方便與SEGGER的BigFAT和微軟的exFAT一起使用。
    的頭像 發(fā)表于 04-23 15:51 ?924次閱讀
    舞阳县| SHOW| 扶绥县| 北辰区| 南皮县| 视频| 镇雄县| 聊城市| 阿克| 罗甸县| 湖州市| 贡嘎县| 辽阳县| 惠来县| 涿州市| 韶山市| 麦盖提县| 子洲县| 定远县| 大邑县| 北京市| 台山市| 灵台县| 彰武县| 余干县| 广宁县| 八宿县| 康乐县| 临西县| 法库县| 桐城市| 建阳市| 宜阳县| 恩施市| 清新县| 百色市| 罗定市| 重庆市| 资阳市| 镇远县| 金沙县|