主頁 > 資料庫 > 實踐丨GaussDB(DWS)資源管理排隊原理與問題定位

實踐丨GaussDB(DWS)資源管理排隊原理與問題定位

2022-12-20 07:26:12 資料庫

摘要:GaussDB(DWS)提供了資源管理功能,用戶可以根據自身業務情況對資源進行劃分,將資源按需劃分成不同的資源池,不同資源池之間資源互相隔離,

本文分享自華為云社區《GaussDB(DWS)資源管理排隊原理與問題定位》,作者: 門前一棵葡萄樹 ,

一、記憶體管控原理

GaussDB(DWS)提供了資源管理功能,用戶可以根據自身業務情況對資源進行劃分,將資源按需劃分成不同的資源池,不同資源池之間資源互相隔離,再通過用戶關聯資源池的方式將資料庫用戶關聯至不同的資源池,用戶查詢依據“用戶-資源池”的關聯關系將查詢路由至對應資源池執行,以此實作對查詢并發、記憶體及CPU資源的管控,從而實作對不同業務之間的資源限制和隔離,滿足資料庫混合負載需求,保證查詢執行時資源調度的有序可控,防止爛SQL影響整個集群,

1.1 自適應記憶體

傳統記憶體管理場景下,使用work_mem限制算子可以使用的記憶體上限,通常復雜查詢的執行計劃中包含多個算子,每個算子可能需要使用的記憶體并不相同,但是每個算子可用的記憶體上限均為work_mem,很難找到一個最優的work_mem取值,一方面保證查詢性能滿足預期,一方面還需要保證不會導致記憶體報錯,在查詢并發場景下,靜態記憶體管理的work_mem及并發上限就更難設定了,單查詢算子數量從0~N不等,設定work_mem后無法實作陳述句級記憶體資源使用的控制,多并發場景下可能會導致記憶體資源不受控,進而導致OOM,

針對傳統記憶體管理的弊端,GaussDB(DWS)設計實作了記憶體自適應技術:

  • 解除對work_mem的依賴,優化器依據統計資訊對查詢使用記憶體進行估算;
  • 執行器執行SQL程序中,如果使用記憶體超過估算記憶體即觸發下盤;
  • 資源管理依據優化器估算的查詢記憶體,對查詢進行調度和管控,

另外,為保證多CN場景下的記憶體可控,設計實作CCN用于查詢的統一調度,以此保證所有CN上運行的查詢使用記憶體之和不會超過記憶體上限,進而導致記憶體不足,引發報錯,CM在第一次集群啟動時,通過集群部署形式,選擇編號最小的CN作為CCN,CCN故障之后,由CM選擇新的CCN進行替換,

CCN管控與CN管控間差異及優劣:

  • CN管控查詢由各CN單獨調度,各CN間互相不感知負載情況,無法準確感知和控制整個集群并發,記憶體管控效果有限,有可能出現記憶體報錯;
  • CCN管控查詢由CCN統一調度,結合DN記憶體負反饋機制,CCN可以感知集群整體負載,記憶體管控更加精準,可以消除記憶體不足報錯;
  • CCN管控涉及CN與CCN之間的通信,通信延遲可能帶來查詢性能的不穩定;通信延遲與網路環境及查詢并發度有關,大概10ms~ 1s不等;
  • CCN管控相對CN管控邏輯更加復雜,除涉及資源池記憶體/并發管控外,還包含CCN全域記憶體管控,在作業管控和喚醒時都需要進行兩層邏輯判斷;
  • CCN管控因為所有查詢都需要由CCN統一調度,因此管控時發生所沖突的可能性就更大,

綜上所述,CN管控對查詢性能影響較小,但是記憶體管控效果有限,CCN管控對查詢性能影響可能較大,但是可以實作記憶體精準管控,消除記憶體不足報錯,

為實作更為精細的管控,我們根據查詢預期執行時間和資源消耗,將查詢劃分為執行時間長、資源消耗多的復雜查詢和執行時間短、資源消耗少的簡單查詢,簡單查詢和復雜查詢的劃分與資源消耗密切相關,同時因為查詢執行前就需要劃分簡單/復雜查詢,因此根據估算記憶體(代價)對查詢進行劃分:

  • 簡單查詢:估算記憶體小于32MB;
  • 復雜查詢:估算記憶體大于等于32MB,

混合負載場景下,雖然簡單查詢本身執行時間短、消耗資源少,但是因為復雜查詢可能會長時間大量占用資源,進而導致資源耗盡,使得簡單查詢不得不在佇列中等待復雜查詢執行完成,為提升執行效率、提高資料庫整體吞吐量, 設計實作“短查詢加速”功能,實作對簡單查詢的單獨管控,

  • 開啟短查詢加速后,簡單查詢與復雜查詢分別進行管控,
  • 關閉短查詢加速后,簡單查詢與復雜查詢一起進行管控,

雖然單個簡單查詢資源消耗少,但是大量簡單查詢并發運行還是可能占用大量資源,另外對簡單查詢進行CCN管控可能會影響查詢性能,降低吞吐量,因此為降低對查詢的性能影響,同時實作記憶體管控目的,我們僅對復雜查詢進行CCN并發和記憶體管控,簡單查詢由各自CN單獨進行并發控制,

1.2 記憶體管控能力

GaussDB(DWS) 記憶體管控分為三級,分別是:

  1. 實體級記憶體管控:通過max_process_memory限制CN、DN可以使用的記憶體上限;
  2. 資源池記憶體管控:通過資源池引數mem_percent限制資源池記憶體使用,結合優化器估算的查詢記憶體,實作資源池之間的記憶體隔離;
  3. 作業記憶體管控:查詢優化器根據統計資訊估算查詢執行時使用記憶體的最大值,查詢以估算記憶體為準向資源管理申請記憶體資源,查詢執行程序中使用記憶體超過估算記憶體即觸發下盤,

基于優化器給出的查詢估算記憶體,資源管理提供了兩種記憶體管控方式:

  1. 靜態記憶體管控(單CN管控):各CN互不感知,分別進行管控,多CN同時下發作業可能導致記憶體不可控;
  2. 動態記憶體管控(CCN管控):估算記憶體大于32MB的查詢統一由CCN調度,結合DN記憶體負反饋機制,CCN感知集群整體負載,實作記憶體的精準管控,

特例:

  1. 靜態記憶體管控關閉(資源池mem_percent=0)或查詢估算記憶體為0情況下,查詢執行程序中使用work_mem控制每個算子可以使用的記憶體上限,多算子并行可能導致記憶體不受控;
  2. 默認資源池支持DN上記憶體擴展,DN記憶體資源充足情況下查詢可以使用更多記憶體,提升查詢執行性能,

通過以上描述,其實不難看出記憶體管控的基礎是優化器的記憶體估算,記憶體估算準確可以實作記憶體的精準管控,記憶體估算不準可能引起一系列的問題:

  1. 記憶體估算小使用大(DN記憶體擴展),可能導致記憶體報錯;
  2. 記憶體估算大使用小,可能導致記憶體利用率低,吞吐量上不去;
  3. 記憶體估算過大,可能導致CCN/CN例外排隊,

基于以上問題,資源管理做了以下功能降低估算不準帶來的影響:

  1. 資源池增加引數memory_limit,用于配置單查詢估算記憶體上限,默認情況下查詢估算記憶體上限為資源池記憶體*0.4,實際場景下可按需設定該值大小,理論上查詢估算記憶體不應超過該值;
  2. 記憶體負反饋:正在執行的作業查詢估算記憶體之和超過總記憶體40%,實際使用記憶體低于估算記憶體60%時觸發記憶體負反饋,按照一定比例逐步降低查詢估算記憶體記賬值,以此下發更多查詢,提升記憶體使用率;

查詢估算記憶體兜底機制(820-1230):在查詢估算記憶體超過單查詢估算記憶體上限時,對查詢估算記憶體進行修正,按照單查詢估算記憶體上限進行管控,

二、排隊原理與問題排查

2.1 排隊原理

GaussDB(DWS)可能在以下情況下發生排隊:

  1. 單CN并發控制:單個CN上查詢并發超過max_active_statements引發排隊;
  2. 資源池快車道并發控制:資源池上簡單查詢并發超過資源池引數max_dop引發排隊;
  3. 資源池慢車道并發控制:資源池上復雜查詢并發超過資源池引數active_statements引發排隊;
  4. 資源池慢車道記憶體管控:資源池上運行的復雜查詢估算記憶體之和超過資源池引數mem_percent配置的資源池記憶體上限引發排隊;
  5. CCN全域記憶體管控:所有CN上運行的查詢記憶體估算記憶體/使用記憶體超過DN記憶體上限(max_dynamic_memory)引發排隊,

特例:初始用戶及白名單陳述句不受控,

2.2 常見視圖

GaussDB(DWS)對外提供諸多系統視圖,可以用來輔助資源管理及資源使用相關問題的分析定位,常用視圖及用法說明如下表所示,(☆代表常用程度)

除過上述常用視圖,資源管理問題定位程序需要根據實際場景,結合實體日志、集群狀態等共同分析定位,

2.3 自定義視圖

為方便迅速定位問題,根據現網實踐經驗對以上常見視圖進行組合,整合了三個問題定位程序中的常用視圖:資源池監控視圖、用戶監控視圖以及作業監控視圖,與上面內置視圖相比,這幾個視圖依據現網定位經驗與分布式資料庫特點,對查詢結果做了針對性優化,同時優化了欄位顯示,用戶更易理解,可以作為常規監控視圖使用,具體視圖定義可參考附件,

2.4 排隊問題排查

出現業務阻塞、性能下降、查詢無回應等類似現網問題時,通過以下方法可以排查是否排隊問題并定位排隊原因,同時根據排隊原因給出相應規避措施,

Step1 確認是否排隊

首先確認是否排隊問題,其次排查排隊原因,確認是否屬于正常排隊:

  • 813及以上版本可以查詢資源池監控視圖
SELECT * FROM pgxc_respool_runtime_info ORDER BY 1,2,3;
  • 811及以上版本可以作業運行監控視圖
SELECT 
s.resource_pool AS rpname, s.node_group, 
count(1) AS session_cnt,
SUM(CASE WHEN a.enqueue = 'waiting in global queue' THEN 1 ELSE 0 END) AS global_wait,
SUM(CASE WHEN s.lane= 'fast' AND a.state = 'active' AND (a.enqueue IS NULL OR a.enqueue = 'no waiting queue') THEN 1 ELSE 0 END) AS fast_run,
SUM(CASE WHEN s.lane= 'fast' AND a.enqueue = 'waiting in respool queue' THEN 1 ELSE 0 END) AS fast_wait,
SUM(CASE WHEN s.lane= 'slow' AND a.state = 'active' AND (a.enqueue IS NULL OR a.enqueue = 'no waiting queue') THEN 1 ELSE 0 END) AS slow_run,
SUM(CASE WHEN s.lane= 'slow' AND (a.enqueue = 'waiting in ccn queue' OR a.enqueue = 'waiting in respool queue') THEN 1 ELSE 0 END) AS slow_wait,
SUM(CASE WHEN (a.enqueue IS NULL OR a.enqueue = 'no waiting queue') AND a.state = 'active' THEN statement_mem ELSE 0 END) AS est_mem
FROM pgxc_session_wlmstat s,pgxc_stat_activity a
WHERE s.threadid=a.pid(+) AND s.attribute != 'Internal' 
GROUP BY 1,2
  • 800版本查詢作業運行監控視圖
SELECT 
s.resource_pool AS rpname, s.node_group, 
count(1) AS session_cnt,
SUM(CASE WHEN a.enqueue = 'waiting in global queue' THEN 1 ELSE 0 END) AS global_wait,
SUM(CASE WHEN s.attribute= 'Simple' AND a.state = 'active' AND (a.enqueue IS NULL OR a.enqueue = 'no waiting queue') THEN 1 ELSE 0 END) AS fast_run,
SUM(CASE WHEN s.attribute= 'Simple' AND a.enqueue = 'waiting in respool queue' THEN 1 ELSE 0 END) AS fast_wait,
SUM(CASE WHEN s.attribute= 'Complicated' AND a.state = 'active' AND (a.enqueue IS NULL OR a.enqueue = 'no waiting queue') THEN 1 ELSE 0 END) AS slow_run,
SUM(CASE WHEN s.attribute= 'Complicated' AND (a.enqueue = 'waiting in ccn queue' OR a.enqueue = 'waiting in respool queue') THEN 1 ELSE 0 END) AS slow_wait,
SUM(CASE WHEN (a.enqueue IS NULL OR a.enqueue = 'no waiting queue') AND a.state = 'active' THEN statement_mem ELSE 0 END) AS est_mem
FROM pgxc_session_wlmstat s,pgxc_stat_activity a
WHERE s.threadid=a.pid(+) AND s.attribute != 'Internal' 
GROUP BY 1,2;

某些老版本不存在pgxc_session_wlmstat視圖,可以參考附件創建類似函式/視圖,

  • 直接查詢自定義視圖

通過查詢自定義視圖可以獲取到各資源池快慢車道作業運行資訊以及作業排隊資訊,據此可以直接判斷是否排隊問題,

Step2 排查排隊原因

常見排隊原因及解決措施

1.全域并發排隊

  • 單CN實際運行作業數≥全域并發上限,則全域并發排隊正常;
  • 單CN實際運行作業數長時間小于全域并發上限,則可能存在計數泄露,

2.快車道排隊

  • 快車道實際運行作業數≥快車道并發上限,則快車道并發排隊正常;
  • 快車道實際運行作業數長時間小于快車道并發上限,則可能存在計數泄露,

3.靜態慢車道排隊

  • 慢車道實際運行作業數≥慢車道并發上限,則慢車道并發排隊正常;
  • 慢車道實際運行作業累計估算記憶體≥慢車道記憶體上限,則慢車道記憶體占用達到上限導致排隊,關注是否有查詢估算記憶體過大;
  • 如果慢車道并發和記憶體占用長時間達不到上限,則可能存在計數泄露,

4.動態CCN排隊

如果查詢在CCN排隊,可使用附件中自定義資源池監控視圖和作業監控視圖確認排隊原因,或查詢CCN開發者視圖確認排隊原因(不推薦):

SELECT * FROM pg_stat_get_workload_struct_info();

CCN上可能的排隊原因:

  • CCN全域可用記憶體不足導致排隊,此時需特別關注是否有查詢估算記憶體過大;
  • 資源池實際運行作業數≥慢車道車道并發上限,資源池并發上限,正常排隊;
  • 資源池實際運行作業累計估算記憶體≥慢車道記憶體上限,則慢車道記憶體占用達到上限導致排隊,此時需特別關注是否有查詢估算記憶體過大;
  • 資源池實際運行作業數或占用記憶體與記賬值不符,則可能存在計數泄露BUG;
  • 隊首作業在CCN哈希中不存在,說明隊首作業殘留導致查詢不能正常下發;
  • CN/CCN處于recover狀態或收集DN記憶體資訊失敗(多CCN)導致所有查詢等待5s下發,現象為所有查詢排隊時間均為5~6s,

附件:自定義監控視圖.rar18.11KB

 

點擊關注,第一時間了解華為云新鮮技術~

轉載請註明出處,本文鏈接:https://www.uj5u.com/shujuku/540325.html

標籤:其它

上一篇:Redis——02 學習

下一篇:關系型資料庫設計三大范式

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • GPU虛擬機創建時間深度優化

    **?桔妹導讀:**GPU虛擬機實體創建速度慢是公有云面臨的普遍問題,由于通常情況下創建虛擬機屬于低頻操作而未引起業界的重視,實際生產中還是存在對GPU實體創建時間有苛刻要求的業務場景。本文將介紹滴滴云在解決該問題時的思路、方法、并展示最終的優化成果。 從公有云服務商那里購買過虛擬主機的資深用戶,一 ......

    uj5u.com 2020-09-10 06:09:13 more
  • 可編程網卡芯片在滴滴云網路的應用實踐

    **?桔妹導讀:**隨著云規模不斷擴大以及業務層面對延遲、帶寬的要求越來越高,采用DPDK 加速網路報文處理的方式在橫向縱向擴展都出現了局限性。可編程芯片成為業界熱點。本文主要講述了可編程網卡芯片在滴滴云網路中的應用實踐,遇到的問題、帶來的收益以及開源社區貢獻。 #1. 資料中心面臨的問題 隨著滴滴 ......

    uj5u.com 2020-09-10 06:10:21 more
  • 滴滴資料通道服務演進之路

    **?桔妹導讀:**滴滴資料通道引擎承載著全公司的資料同步,為下游實時和離線場景提供了必不可少的源資料。隨著任務量的不斷增加,資料通道的整體架構也隨之發生改變。本文介紹了滴滴資料通道的發展歷程,遇到的問題以及今后的規劃。 #1. 背景 資料,對于任何一家互聯網公司來說都是非常重要的資產,公司的大資料 ......

    uj5u.com 2020-09-10 06:11:05 more
  • 滴滴AI Labs斬獲國際機器翻譯大賽中譯英方向世界第三

    **桔妹導讀:**深耕人工智能領域,致力于探索AI讓出行更美好的滴滴AI Labs再次斬獲國際大獎,這次獲獎的專案是什么呢?一起來看看詳細報道吧! 近日,由國際計算語言學協會ACL(The Association for Computational Linguistics)舉辦的世界最具影響力的機器 ......

    uj5u.com 2020-09-10 06:11:29 more
  • MPP (Massively Parallel Processing)大規模并行處理

    1、什么是mpp? MPP (Massively Parallel Processing),即大規模并行處理,在資料庫非共享集群中,每個節點都有獨立的磁盤存盤系統和記憶體系統,業務資料根據資料庫模型和應用特點劃分到各個節點上,每臺資料節點通過專用網路或者商業通用網路互相連接,彼此協同計算,作為整體提供 ......

    uj5u.com 2020-09-10 06:11:41 more
  • 滴滴資料倉庫指標體系建設實踐

    **桔妹導讀:**指標體系是什么?如何使用OSM模型和AARRR模型搭建指標體系?如何統一流程、規范化、工具化管理指標體系?本文會對建設的方法論結合滴滴資料指標體系建設實踐進行解答分析。 #1. 什么是指標體系 ##1.1 指標體系定義 指標體系是將零散單點的具有相互聯系的指標,系統化的組織起來,通 ......

    uj5u.com 2020-09-10 06:12:52 more
  • 單表千萬行資料庫 LIKE 搜索優化手記

    我們經常在資料庫中使用 LIKE 運算子來完成對資料的模糊搜索,LIKE 運算子用于在 WHERE 子句中搜索列中的指定模式。 如果需要查找客戶表中所有姓氏是“張”的資料,可以使用下面的 SQL 陳述句: SELECT * FROM Customer WHERE Name LIKE '張%' 如果需要 ......

    uj5u.com 2020-09-10 06:13:25 more
  • 滴滴Ceph分布式存盤系統優化之鎖優化

    **桔妹導讀:**Ceph是國際知名的開源分布式存盤系統,在工業界和學術界都有著重要的影響。Ceph的架構和演算法設計發表在國際系統領域頂級會議OSDI、SOSP、SC等上。Ceph社區得到Red Hat、SUSE、Intel等大公司的大力支持。Ceph是國際云計算領域應用最廣泛的開源分布式存盤系統, ......

    uj5u.com 2020-09-10 06:14:51 more
  • es~通過ElasticsearchTemplate進行聚合~嵌套聚合

    之前寫過《es~通過ElasticsearchTemplate進行聚合操作》的文章,這一次主要寫一個嵌套的聚合,例如先對sex集合,再對desc聚合,最后再對age求和,共三層嵌套。 Aggregations的部分特性類似于SQL語言中的group by,avg,sum等函式,Aggregation ......

    uj5u.com 2020-09-10 06:14:59 more
  • 爬蟲日志監控 -- Elastc Stack(ELK)部署

    傻瓜式部署,只需替換IP與用戶 導讀: 現ELK四大組件分別為:Elasticsearch(核心)、logstash(處理)、filebeat(采集)、kibana(可視化) 下載均在https://www.elastic.co/cn/downloads/下tar包,各組件版本最好一致,配合fdm會 ......

    uj5u.com 2020-09-10 06:15:05 more
最新发布
  • day02-2-商鋪查詢快取

    功能02-商鋪查詢快取 3.商鋪詳情快取查詢 3.1什么是快取? 快取就是資料交換的緩沖區(稱作Cache),是存盤資料的臨時地方,一般讀寫性能較高。 快取的作用: 降低后端負載 提高讀寫效率,降低回應時間 快取的成本: 資料一致性成本 代碼維護成本 運維成本 3.2需求說明 如下,當我們點擊商店詳 ......

    uj5u.com 2023-04-20 08:33:24 more
  • MySQL中binlog備份腳本分享

    關于MySQL的二進制日志(binlog),我們都知道二進制日志(binlog)非常重要,尤其當你需要point to point災難恢復的時侯,所以我們要對其進行備份。關于二進制日志(binlog)的備份,可以基于flush logs方式先切換binlog,然后拷貝&壓縮到到遠程服務器或本地服務器 ......

    uj5u.com 2023-04-20 08:28:06 more
  • day02-短信登錄

    功能實作02 2.功能01-短信登錄 2.1基于Session實作登錄 2.1.1思路分析 2.1.2代碼實作 2.1.2.1發送短信驗證碼 發送短信驗證碼: 發送驗證碼的介面為:http://127.0.0.1:8080/api/user/code?phone=xxxxx<手機號> 請求方式:PO ......

    uj5u.com 2023-04-20 08:27:27 more
  • 快取與資料庫雙寫一致性幾種策略分析

    本文將對幾種快取與資料庫保證資料一致性的使用方式進行分析。為保證高并發性能,以下分析場景不考慮執行的原子性及加鎖等強一致性要求的場景,僅追求最終一致性。 ......

    uj5u.com 2023-04-20 08:26:48 more
  • sql陳述句優化

    問題查找及措施 問題查找 需要找到具體的代碼,對其進行一對一優化,而非一直把關注點放在服務器和sql平臺 降低簡化每個事務中處理的問題,盡量不要讓一個事務拖太長的時間 例如檔案上傳時,應將檔案上傳這一步放在事務外面 微軟建議 4.啟動sql定時執行計劃 怎么啟動sqlserver代理服務-百度經驗 ......

    uj5u.com 2023-04-20 08:26:35 more
  • 云時代,MySQL到ClickHouse資料同步產品對比推薦

    ClickHouse 在執行分析查詢時的速度優勢很好的彌補了MySQL的不足,但是對于很多開發者和DBA來說,如何將MySQL穩定、高效、簡單的同步到 ClickHouse 卻很困難。本文對比了 NineData、MaterializeMySQL(ClickHouse自帶)、Bifrost 三款產品... ......

    uj5u.com 2023-04-20 08:26:29 more
  • sql陳述句優化

    問題查找及措施 問題查找 需要找到具體的代碼,對其進行一對一優化,而非一直把關注點放在服務器和sql平臺 降低簡化每個事務中處理的問題,盡量不要讓一個事務拖太長的時間 例如檔案上傳時,應將檔案上傳這一步放在事務外面 微軟建議 4.啟動sql定時執行計劃 怎么啟動sqlserver代理服務-百度經驗 ......

    uj5u.com 2023-04-20 08:25:13 more
  • Redis 報”OutOfDirectMemoryError“(堆外記憶體溢位)

    Redis 報錯“OutOfDirectMemoryError(堆外記憶體溢位) ”問題如下: 一、報錯資訊: 使用 Redis 的業務介面 ,產生 OutOfDirectMemoryError(堆外記憶體溢位),如圖: 格式化后的報錯資訊: { "timestamp": "2023-04-17 22: ......

    uj5u.com 2023-04-20 08:24:54 more
  • day02-2-商鋪查詢快取

    功能02-商鋪查詢快取 3.商鋪詳情快取查詢 3.1什么是快取? 快取就是資料交換的緩沖區(稱作Cache),是存盤資料的臨時地方,一般讀寫性能較高。 快取的作用: 降低后端負載 提高讀寫效率,降低回應時間 快取的成本: 資料一致性成本 代碼維護成本 運維成本 3.2需求說明 如下,當我們點擊商店詳 ......

    uj5u.com 2023-04-20 08:24:03 more
  • day02-短信登錄

    功能實作02 2.功能01-短信登錄 2.1基于Session實作登錄 2.1.1思路分析 2.1.2代碼實作 2.1.2.1發送短信驗證碼 發送短信驗證碼: 發送驗證碼的介面為:http://127.0.0.1:8080/api/user/code?phone=xxxxx<手機號> 請求方式:PO ......

    uj5u.com 2023-04-20 08:23:11 more