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

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

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

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

SpringBoot模板分類樹查詢功能介紹

jf_ro2CN3Fa ? 來源:芋道源碼 ? 2023-05-22 11:39 ? 次閱讀

背景

第1次優(yōu)化

第2次優(yōu)化

第3次優(yōu)化

第4次優(yōu)化

第5次優(yōu)化

分類樹查詢功能,在各個業(yè)務(wù)系統(tǒng)中可以說隨處可見,特別是在電商系統(tǒng)中。

但就是這樣一個簡單的分類樹查詢功能,我們卻優(yōu)化了5次。

到底是怎么回事呢?

背景

我們的網(wǎng)站使用了SpringBoot推薦的模板引擎:Thymeleaf,進行動態(tài)渲染。

它是一個XML/XHTML/HTML5模板引擎,可用于Web與非Web環(huán)境中的應(yīng)用開發(fā)。

它提供了一個用于整合SpringMVC的可選模塊,在應(yīng)用開發(fā)中,我們可以使用Thymeleaf來完全代替JSP或其他模板引擎,如VelocityFreeMarker等。

前端開發(fā)寫好Thymeleaf的模板文件,調(diào)用后端接口獲取數(shù)據(jù),進行動態(tài)綁定,就能把想要的內(nèi)容展示給用戶。

由于當時這個是從0-1的新項目,為了開快速開發(fā)功能,我們第一版接口,直接從數(shù)據(jù)庫中查詢分類數(shù)據(jù),組裝成分類樹,然后返回給前端。

通過這種方式,簡化了數(shù)據(jù)流程,快速把整個頁面功能調(diào)通了。

基于 Spring Boot + MyBatis Plus + Vue & Element 實現(xiàn)的后臺管理系統(tǒng) + 用戶小程序,支持 RBAC 動態(tài)權(quán)限、多租戶、數(shù)據(jù)權(quán)限、工作流、三方登錄、支付、短信、商城等功能

項目地址:https://github.com/YunaiV/ruoyi-vue-pro

視頻教程:https://doc.iocoder.cn/video/

第1次優(yōu)化

我們將該接口部署到dev環(huán)境,剛開始沒啥問題。

隨著開發(fā)人員添加的分類越來越多,很快就暴露出性能瓶頸。

我們不得不做優(yōu)化了。

我們第一個想到的是:加Redis緩存。

流程圖如下:57cc4acc-f7ce-11ed-90ce-dac502259ad0.png于是暫時這樣優(yōu)化了一下:

用戶訪問接口獲取分類樹時,先從Redis中查詢數(shù)據(jù)。

如果Redis中有數(shù)據(jù),則直接數(shù)據(jù)。

如果Redis中沒有數(shù)據(jù),則再從數(shù)據(jù)庫中查詢數(shù)據(jù),拼接成分類樹返回。

將從數(shù)據(jù)庫中查到的分類樹的數(shù)據(jù),保存到Redis中,設(shè)置過期時間5分鐘。

將分類樹返回給用戶。

我們在Redis中定義一個了key,value是一個分類樹的json格式轉(zhuǎn)換成了字符串,使用簡單的key/value形式保存數(shù)據(jù)。

經(jīng)過這樣優(yōu)化之后,dev環(huán)境的聯(lián)調(diào)和自測順利完成了。

基于 Spring Cloud Alibaba + Gateway + Nacos + RocketMQ + Vue & Element 實現(xiàn)的后臺管理系統(tǒng) + 用戶小程序,支持 RBAC 動態(tài)權(quán)限、多租戶、數(shù)據(jù)權(quán)限、工作流、三方登錄、支付、短信、商城等功能

項目地址:https://github.com/YunaiV/yudao-cloud

視頻教程:https://doc.iocoder.cn/video/

第2次優(yōu)化

我們將這個功能部署到st環(huán)境了。

剛開始測試同學沒有發(fā)現(xiàn)什么問題,但隨著后面不斷地深入測試,隔一段時間就出現(xiàn)一次首頁訪問很慢的情況。

于是,我們馬上進行了第2次優(yōu)化。

我們決定使用Job定期異步更新分類樹到Redis中,在系統(tǒng)上線之前,會先生成一份數(shù)據(jù)。

當然為了保險起見,防止Redis在哪條突然掛了,之前分類樹同步寫入Redis的邏輯還是保留。

于是,流程圖改成了這樣:57d51760-f7ce-11ed-90ce-dac502259ad0.png增加了一個job每隔5分鐘執(zhí)行一次,從數(shù)據(jù)庫中查詢分類數(shù)據(jù),封裝成分類樹,更新到Redis緩存中。

其他的流程保持不變。

此外,Redis的過期時間之前設(shè)置的5分鐘,現(xiàn)在要改成永久。

通過這次優(yōu)化之后,st環(huán)境就沒有再出現(xiàn)過分類樹查詢的性能問題了。

第3次優(yōu)化

測試了一段時間之后,整個網(wǎng)站的功能快要上線了。

為了保險起見,我們需要對網(wǎng)站首頁做一次壓力測試。

果然測出問題了,網(wǎng)站首頁最大的qps是100多,最后發(fā)現(xiàn)是每次都從Redis獲取分類樹導致的網(wǎng)站首頁的性能瓶頸。

我們需要做第3次優(yōu)化。

該怎么優(yōu)化呢?

答:加內(nèi)存緩存。

如果加了內(nèi)存緩存,就需要考慮數(shù)據(jù)一致性問題。

內(nèi)存緩存是保存在服務(wù)器節(jié)點上的,不同的服務(wù)器節(jié)點更新的頻率可能有點差異,這樣可能會導致數(shù)據(jù)的不一致性。

但分類本身是更新頻率比較低的數(shù)據(jù),對于用戶來說不太敏感,即使在短時間內(nèi),用戶看到的分類樹有些差異,也不會對用戶造成太大的影響。

因此,分類樹這種業(yè)務(wù)場景,是可以使用內(nèi)存緩存的。

于是,我們使用了Spring推薦的caffine作為內(nèi)存緩存。

改造后的流程圖如下:57e80e92-f7ce-11ed-90ce-dac502259ad0.png

用戶訪問接口時改成先從本地緩存分類數(shù)查詢數(shù)據(jù)。

如果本地緩存有,則直接返回。

如果本地緩存沒有,則從Redis中查詢數(shù)據(jù)。

如果Redis中有數(shù)據(jù),則將數(shù)據(jù)更新到本地緩存中,然后返回數(shù)據(jù)。

如果Redis中也沒有數(shù)據(jù)(說明Redis掛了),則從數(shù)據(jù)庫中查詢數(shù)據(jù),更新到Redis中(萬一Redis恢復了呢),然后更新到本地緩存中,返回返回數(shù)據(jù)。

需要注意的是,需要改本地緩存設(shè)置一個過期時間,這里設(shè)置的5分鐘,不然的話,沒辦法獲取新的數(shù)據(jù)。

這樣優(yōu)化之后,再次做網(wǎng)站首頁的壓力測試,qps提升到了500多,滿足上線要求。

第4次優(yōu)化

之后,這個功能順利上線了。

使用了很長一段時間沒有出現(xiàn)問題。

兩年后的某一天,有用戶反饋說,網(wǎng)站首頁有點慢。

我們排查了一下原因發(fā)現(xiàn),分類樹的數(shù)據(jù)太多了,一次性返回了上萬個分類。

原來在系統(tǒng)上線的這兩年多的時間內(nèi),運營同學在系統(tǒng)后臺增加了很多分類。

我們需要做第4次優(yōu)化。

這時要如何優(yōu)化呢?

限制分類樹的數(shù)量?

答:也不太現(xiàn)實,目前這個業(yè)務(wù)場景就是有這么多分類,不能讓用戶選擇不到他想要的分類吧?

這時我們想到最快的辦法是開啟nginx的GZip功能。

讓數(shù)據(jù)在傳輸之前,先壓縮一下,然后進行傳輸,在用戶瀏覽器中,自動解壓,將真實的分類樹數(shù)據(jù)展示給用戶。

之前調(diào)用接口返回的分類樹有1MB的大小,優(yōu)化之后,接口返回的分類樹的大小是100Kb,一下子縮小了10倍。

這樣簡單的優(yōu)化之后,性能提升了一些。

第5次優(yōu)化

經(jīng)過上面優(yōu)化之后,用戶很長一段時間都沒有反饋性能問題。

但有一天公司同事在排查Redis中大key的時候,揪出了分類樹。之前的分類樹使用key/value的結(jié)構(gòu)保存數(shù)據(jù)的。

我們不得不做第5次優(yōu)化。

為了優(yōu)化在Redis中存儲數(shù)據(jù)的大小,我們首先需要對數(shù)據(jù)進行瘦身。

只保存需要用到的字段。

例如:

@AllArgsConstructor
@Data
publicclassCategory{

privateLongid;
privateStringname;
privateLongparentId;
privateDateinDate;
privateLonginUserId;
privateStringinUserName;
privateListchildren;
}

像這個分類對象中inDate、inUserId和inUserName字段是可以不用保存的。

修改自動名稱。

例如:

@AllArgsConstructor
@Data
publicclassCategory{
/**
*分類編號
*/
@JsonProperty("i")
privateLongid;

/**
*分類層級
*/
@JsonProperty("l")
privateIntegerlevel;

/**
*分類名稱
*/
@JsonProperty("n")
privateStringname;

/**
*父分類編號
*/
@JsonProperty("p")
privateLongparentId;

/**
*子分類列表
*/
@JsonProperty("c")
privateListchildren;
}

由于在一萬多條數(shù)據(jù)中,每條數(shù)據(jù)的字段名稱是固定的,他們的重復率太高了。

由此,可以在json序列化時,改成一個簡短的名稱,以便于返回更少的數(shù)據(jù)大小。

這還不夠,需要對存儲的數(shù)據(jù)做壓縮。

之前在Redis中保存的key/value,其中的value是json格式的字符串。

其實RedisTemplate支持,value保存byte數(shù)組。

先將json字符串數(shù)據(jù)用GZip工具類壓縮成byte數(shù)組,然后保存到Redis中。

再獲取數(shù)據(jù)時,將byte數(shù)組轉(zhuǎn)換成json字符串,然后再轉(zhuǎn)換成分類樹。

這樣優(yōu)化之后,保存到Redis中的分類樹的數(shù)據(jù)大小,一下子減少了10倍,Redis的大key問題被解決了。

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

    關(guān)注

    33

    文章

    8575

    瀏覽量

    151015
  • 模板
    +關(guān)注

    關(guān)注

    0

    文章

    108

    瀏覽量

    20560
  • 分類樹
    +關(guān)注

    關(guān)注

    0

    文章

    3

    瀏覽量

    5739
  • SpringBoot
    +關(guān)注

    關(guān)注

    0

    文章

    173

    瀏覽量

    177

原文標題:分類樹菜單,我從2s優(yōu)化到0.1s

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

收藏 人收藏

    評論

    相關(guān)推薦

    示波器模板測試功能介紹及應(yīng)用詳解

    在電子產(chǎn)品的可靠性驗證測試中,模板測試非常實用,長時間監(jiān)控波形的故障率,并根據(jù)故障波形定位原因是保證品控質(zhì)量的重要手段,本文將對示波器的模板測試功能做詳細的解讀。 1.1模板測試概述
    發(fā)表于 08-01 18:16 ?2758次閱讀
    示波器<b class='flag-5'>模板</b>測試<b class='flag-5'>功能</b><b class='flag-5'>介紹</b>及應(yīng)用詳解

    SpringBoot中的Druid介紹

    SpringBoot中Druid數(shù)據(jù)源配置
    發(fā)表于 05-07 09:21

    Java模板引擎FreeMaker介紹

    史上最簡單Spring Boot教程:第四篇SpringBoot之freemarker模板(四)
    發(fā)表于 08-30 08:59

    springboot的thymeleaf模板與freemarker模板的用法

    springboot的thymeleaf模板與freemarker模板的基礎(chǔ)用法
    發(fā)表于 05-05 18:23

    介紹支持向量機與決策集成等模型的應(yīng)用

    本文主要介紹支持向量機、k近鄰、樸素貝葉斯分類 、決策、決策集成等模型的應(yīng)用。講解了支持向量機SVM線性與非線性模型的適用環(huán)境,并對核函數(shù)技巧作出深入的分析,對線性Linear核函
    發(fā)表于 09-01 06:57

    如何創(chuàng)建小型模板設(shè)備

    如何創(chuàng)建小型模板設(shè)備
    發(fā)表于 12-23 07:43

    基于java springboot電影購票小程序源碼相關(guān)資料推薦

    后臺springboot mybatis 前端微信小程序電影院訂票系統(tǒng)用戶信息管理:用戶注冊后,可修改個人信息、登錄密碼等影片分類:對影片進行分類,按類型、國家區(qū)域分類,有篩選
    發(fā)表于 12-30 06:14

    基于啟發(fā)式搜索算法的網(wǎng)格信息查詢優(yōu)化

    如何提高網(wǎng)格信息系統(tǒng)的查詢效率是提高網(wǎng)格性能的關(guān)鍵問題之一。在基于資源分類(將計算資源按其屬性和數(shù)值組織成平衡二叉)的網(wǎng)格信息系統(tǒng)中,資源分類
    發(fā)表于 04-14 09:03 ?15次下載

    傳感器大全分類查詢

    傳感器大全分類查詢
    發(fā)表于 03-23 11:04 ?3659次下載
    傳感器大全<b class='flag-5'>分類</b><b class='flag-5'>查詢</b>表

    什么是中圖分類號_中圖分類查詢

    本內(nèi)容介紹了什么是中圖分類號,中圖分類號是什么意思?中圖分類號怎么查詢,在內(nèi)容中都一一為大家列舉
    發(fā)表于 12-19 16:24 ?1.4w次閱讀

    基于關(guān)系代數(shù)查詢優(yōu)化方法實例分析

    提出了基于關(guān)系代數(shù)樹結(jié)構(gòu)的SQL查詢優(yōu)化策略。利用改進查詢計劃的代數(shù)定律,分析基于關(guān)系代數(shù)的關(guān)系代數(shù)式查詢優(yōu)化方法、研究關(guān)系代數(shù)表達式與SQL查詢
    發(fā)表于 05-07 10:11 ?21次下載
    基于關(guān)系代數(shù)<b class='flag-5'>樹</b>的<b class='flag-5'>查詢</b>優(yōu)化方法實例分析

    基于關(guān)系的知識查詢算法研究

    在關(guān)系模型基礎(chǔ)上,進一步深入研究,將關(guān)系模型轉(zhuǎn)換成關(guān)系。基于此關(guān)系模型,作者提出一般直接知識的正向,逆向知識查詢算法,對不能直接查詢的知識,進一步提出隱含知識
    發(fā)表于 11-07 15:56 ?0次下載
    基于關(guān)系<b class='flag-5'>樹</b>的知識<b class='flag-5'>查詢</b>算法研究

    什么是決策模型,決策模型的繪制方法

    決策是一種解決分類問題的算法,本文將介紹什么是決策模型,常見的用途,以及如何使用“億圖圖示”軟件繪制決策模型。
    發(fā)表于 02-18 10:12 ?1.3w次閱讀
    什么是決策<b class='flag-5'>樹</b>模型,決策<b class='flag-5'>樹</b>模型的繪制方法

    基于java springboot 電影購票小程序源碼

    后臺springboot mybatis 前端微信小程序電影院訂票系統(tǒng)用戶信息管理:用戶注冊后,可修改個人信息、登錄密碼等影片分類:對影片進行分類,按類型、國家區(qū)域分類,有篩選
    發(fā)表于 01-10 09:25 ?13次下載
    基于java <b class='flag-5'>springboot</b> 電影購票小程序源碼

    什么是 SpringBoot

    本文從為什么要有 `SpringBoot`,以及 `SpringBoot` 到底方便在哪里開始入手,逐步分析了 `SpringBoot` 自動裝配的原理,最后手寫了一個簡單的 `start` 組件,通過實戰(zhàn)來體會了 `
    的頭像 發(fā)表于 04-07 11:28 ?1305次閱讀
    什么是 <b class='flag-5'>SpringBoot</b>?
    主站蜘蛛池模板: 亚洲精品久久久午夜麻豆| 国产一区二区精品视频| 欧美性爱-第1页| 97视频精品| 免费在线观看一区| 99久久精品国产亚洲AV| 欧美丰满白嫩bbxx| jazzjazzjazz欧美| 日本污ww视频网站| 高清国产在线观看| 婷婷开心激情综合五月天| 国产精品久久久久久亚洲影视| 午夜伦理网| 国产综合在线视频| 亚洲午夜AV久久久精品影院色戒| 黄色三级网址| 伊人久久综合影院| 麻豆精品一区二正一三区| 99国产精品久久久久久久日本竹| 欧美乱妇15p图| 成人小视频在线观看免费| 少妇厨房愉情理9伦片视频| 国产精品久久久精品a级小说| 羞羞答答的免费视频在线观看| 国拍在线精品视频免费观看| 夜月视频直播免费观看| 麻美ゆま夫の目の前で犯| ppypp午夜限制不卡影院私人| 日本又黄又爽又色又刺激的视频| 国产VA精品午夜福利视频| 亚洲国产高清在线| 久久免费视频在线观看6| 99热国产这里只有精品6| 日韩一区二区三区免费体验| 国产精品高清在线观看93| 亚洲国产在线精品国自产拍五月| 久久re热线视频国产| 97免费视频观看| 少妇无码吹潮久久精品AV| 国产在线观看黄| 6 10young俄罗斯|