精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

分類樹,我從2s優化到0.1s

開發 前端
我們的網站使用了SpringBoot推薦的模板引擎:Thymeleaf,進行動態渲染。它是一個XML/XHTML/HTML5模板引擎,可用于Web與非Web環境中的應用開發。它提供了一個用于整合SpringMVC的可選模塊,在應用開發中,我們可以使用Thymeleaf來完全代替JSP或其他模板引擎,如Velocity\FreeMarker等。

前言

分類樹查詢功能,在各個業務系統中可以說隨處可見,特別是在電商系統中。

圖片

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

到底是怎么回事呢?

背景

我們的網站使用了SpringBoot推薦的模板引擎:Thymeleaf,進行動態渲染。

它是一個XML/XHTML/HTML5模板引擎,可用于Web與非Web環境中的應用開發。

它提供了一個用于整合SpringMVC的可選模塊,在應用開發中,我們可以使用Thymeleaf來完全代替JSP或其他模板引擎,如Velocity\FreeMarker等。

前端開發寫好Thymeleaf的模板文件,調用后端接口獲取數據,進行動態綁定,就能把想要的內容展示給用戶。

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

通過這種方式,簡化了數據流程,快速把整個頁面功能調通了。

第1次優化

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

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

我們不得不做優化了。

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

流程圖如下:

圖片

于是暫時這樣優化了一下:

  1. 用戶訪問接口獲取分類樹時,先從Redis中查詢數據。
  2. 如果Redis中有數據,則直接數據。
  3. 如果Redis中沒有數據,則再從數據庫中查詢數據,拼接成分類樹返回。
  4. 將從數據庫中查到的分類樹的數據,保存到Redis中,設置過期時間5分鐘。
  5. 將分類樹返回給用戶。

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

經過這樣優化之后,dev環境的聯調和自測順利完成了。

第2次優化

我們將這個功能部署到st環境了。

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

于是,我們馬上進行了第2次優化。

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

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

于是,流程圖改成了這樣:

圖片

增加了一個job每隔5分鐘執行一次,從數據庫中查詢分類數據,封裝成分類樹,更新到Redis緩存中。

其他的流程保持不變。

此外,Redis的過期時間之前設置的5分鐘,現在要改成永久。

通過這次優化之后,st環境就沒有再出現過分類樹查詢的性能問題了。

第3次優化

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

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

果然測出問題了,網站首頁最大的qps是100多,最后發現是每次都從Redis獲取分類樹導致的網站首頁的性能瓶頸。

我們需要做第3次優化。

該怎么優化呢?

答:加內存緩存。

如果加了內存緩存,就需要考慮數據一致性問題。

內存緩存是保存在服務器節點上的,不同的服務器節點更新的頻率可能有點差異,這樣可能會導致數據的不一致性。

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

因此,分類樹這種業務場景,是可以使用內存緩存的。

于是,我們使用了Spring推薦的caffine作為內存緩存。

改造后的流程圖如下:

圖片

  1. 用戶訪問接口時改成先從本地緩存分類數查詢數據。
  2. 如果本地緩存有,則直接返回。
  3. 如果本地緩存沒有,則從Redis中查詢數據。
  4. 如果Redis中有數據,則將數據更新到本地緩存中,然后返回數據。
  5. 如果Redis中也沒有數據(說明Redis掛了),則從數據庫中查詢數據,更新到Redis中(萬一Redis恢復了呢),然后更新到本地緩存中,返回返回數據。

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

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

第4次優化

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

使用了很長一段時間沒有出現問題。

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

我們排查了一下原因發現,分類樹的數據太多了,一次性返回了上萬個分類。

原來在系統上線的這兩年多的時間內,運營同學在系統后臺增加了很多分類。

我們需要做第4次優化。

這時要如何優化呢?

限制分類樹的數量?

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

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

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

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

這樣簡單的優化之后,性能提升了一些。

第5次優化

經過上面優化之后,用戶很長一段時間都沒有反饋性能問題。

但有一天公司同事在排查Redis中大key的時候,揪出了分類樹。之前的分類樹使用key/value的結構保存數據的。

我們不得不做第5次優化。

為了優化在Redis中存儲數據的大小,我們首先需要對數據進行瘦身。

只保存需要用到的字段。

例如:

@AllArgsConstructor
@Data
public class Category {

    private Long id;
    private String name;
    private Long parentId;
    private Date inDate;
    private Long inUserId;
    private String inUserName;
    private List<Category> children;
}

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

修改自動名稱。

例如:

@AllArgsConstructor
@Data
public class Category {
    /**
     * 分類編號
     */
    @JsonProperty("i")
    private Long id;

    /**
     * 分類層級
     */
    @JsonProperty("l")
    private Integer level;

    /**
     * 分類名稱
     */
    @JsonProperty("n")
    private String name;

    /**
     * 父分類編號
     */
    @JsonProperty("p")
    private Long parentId;

    /**
     * 子分類列表
     */
    @JsonProperty("c")
    private List<Category> children;
}

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

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

這還不夠,需要對存儲的數據做壓縮。

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

其實RedisTemplate支持,value保存byte數組。

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

再獲取數據時,將byte數組轉換成json字符串,然后再轉換成分類樹。

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

責任編輯:姜華 來源: 蘇三說技術
相關推薦

2024-09-29 08:21:06

2023-12-25 08:24:03

雙異步數據庫Excel

2024-10-28 07:00:00

分頁查詢優化索引數據歸檔

2019-01-02 09:10:56

2024-07-30 14:26:52

2019-06-20 11:20:25

sql優化數據庫

2022-06-30 19:40:36

查詢接口索引優化

2025-02-14 09:30:42

2024-10-16 12:45:01

2021-09-10 08:31:36

技術Prometheus監控

2025-11-11 04:00:00

2018-08-21 17:33:00

中小企業軟件

2022-09-27 08:40:44

慢查詢MySQL定位優化

2022-09-19 08:41:02

數據查詢分離

2023-09-27 08:21:00

查詢分離數據API

2024-05-28 08:47:52

2025-11-04 01:45:00

2013-09-02 10:55:31

錘子ROM小米Alpha

2025-08-08 00:00:00

2024-08-30 09:31:36

點贊
收藏

51CTO技術棧公眾號

欧美经典三级视频一区二区三区| 亚洲一卡久久| 精品国产乱码久久久久久图片| 人妻少妇精品久久| 国产高清一区在线观看| 蜜桃av一区二区| 九色精品免费永久在线| 亚洲AV无码国产精品| 99只有精品| 亚洲一级二级三级| 日韩影视精品| 欧美 日韩 国产 精品| 久久精品国语| 欧美乱人伦中文字幕在线| 37p粉嫩大胆色噜噜噜| 国产美女精品视频免费播放软件| 午夜精品久久久久久久久久久 | 99久久久久久久久| 亚洲精品二区三区| 亚洲天堂av高清| 日本中文字幕有码| 激情亚洲小说| 欧美性xxxx极品hd满灌| 国产精品igao激情视频| a√资源在线| www.欧美亚洲| 91青草视频久久| 日日夜夜操视频| 亚洲高清成人| 九色精品美女在线| 国产日产精品一区二区三区的介绍| 日本福利一区| 精品嫩草影院久久| 天天综合天天添夜夜添狠狠添| 亚洲最新无码中文字幕久久| 夜夜嗨av一区二区三区四季av| 午夜精品一区二区在线观看的| 天堂中文资源在线观看| 国产福利一区在线| 成人免费激情视频| 一区二区美女视频| 久久性色av| 欧美一区二区三区免费视| 久久久久久久久久99| 久久久久美女| 久久五月情影视| 日韩国产第一页| 欧美电影免费观看高清| 色婷婷**av毛片一区| 午夜在线观看一区| 亚洲综合图色| 亚洲人成电影在线观看天堂色| 亚洲天堂2024| 红杏成人性视频免费看| 亚洲精品一区二区三区蜜桃下载| 在线观看免费看片| 在线精品国产亚洲| 日韩欧美一区中文| av在线天堂网| 国产香蕉精品| 国产丝袜高跟一区| 3d动漫精品啪啪一区二区下载| 任我爽精品视频在线播放| 国产视频综合在线| 丁香花五月婷婷| 成人羞羞动漫| 久久精品成人欧美大片| 日韩av手机在线免费观看| 伊人久久大香线| 欧美福利小视频| 亚洲伊人成人网| 日韩av成人高清| 国产拍精品一二三| 精品国产av鲁一鲁一区 | 成人精品视频99在线观看免费 | 精品少妇一区二区| 中文在线观看免费视频| 欧美一级二级三级视频| 欧美国产精品中文字幕| 麻豆亚洲一区| 国内av一区二区三区| 欧美国产综合一区二区| 一区中文字幕在线观看| 欧美v亚洲v| 欧美色另类天堂2015| 成人性生生活性生交12| 91麻豆精品国产综合久久久| 欧美刺激脚交jootjob| 朝桐光av一区二区三区| 北条麻妃国产九九九精品小说| 日韩中文字幕免费看| 1024手机在线视频| 裸体一区二区| 91青草视频久久| 色视频免费在线观看| 国产精品无码永久免费888| 特级西西人体www高清大胆| 九色porny丨入口在线| 欧美三级午夜理伦三级中视频| 一级黄色大片免费看| 狠狠色狠狠色综合婷婷tag| 久久中文精品视频| 国产成人精品777777| 国产盗摄精品一区二区三区在线| 欧美福利精品| 青草视频在线免费直播| 在线观看亚洲成人| 男男一级淫片免费播放| 久久一级电影| 欧美在线观看网站| 草草视频在线播放| 中文字幕免费观看一区| 日韩欧美不卡在线| 国产精品久久久久久久久久辛辛| 日韩精品中文字幕在线观看| 国产大学生自拍| 日日夜夜免费精品| 国产中文一区二区| 最新黄网在线观看| 欧美色网站导航| 日韩无码精品一区二区| 中文字幕日韩一区二区不卡| 国产福利视频一区| 亚洲国产欧美另类| 中文字幕制服丝袜一区二区三区| 亚洲乱码中文字幕久久孕妇黑人| 视频一区视频二区欧美| 日韩中文字幕av| 国产亚洲欧美日韩高清| 91色视频在线| 拔插拔插海外华人免费| 日本在线视频一区二区三区| 日韩视频欧美视频| 中文字幕一区二区免费| 久久综合久久综合亚洲| 日本在线xxx| 91麻豆精品激情在线观看最新| www国产亚洲精品久久网站| 天天天天天天天干| 久久久久久久一区| 日本精品一区二区三区四区| 青青草这里只有精品| 久久久久成人精品| www.五月激情| 一区二区三区精品视频在线| 自拍一级黄色片| 自拍偷拍欧美专区| 91精品国产高清久久久久久91裸体| 日本在线看片免费人成视1000| 91久久久免费一区二区| 国内精品卡一卡二卡三| 日韩av一级电影| 亚洲精品电影在线一区| 成人精品动漫| 色狠狠久久aa北条麻妃| 国产精品久久无码一三区| 中文字幕在线不卡| 一级片免费在线观看视频| 一区二区日韩欧美| 999精品视频一区二区三区| 97超碰资源站在线观看| 日韩欧美国产高清| 日韩欧美视频在线免费观看| www国产精品av| 日韩无套无码精品| 色97色成人| 91在线|亚洲| 2021天堂中文幕一二区在线观| 亚洲成年人在线播放| 五月天综合激情网| 国产欧美日韩在线观看| 亚洲涩涩在线观看| 午夜国产精品视频| 精品产品国产在线不卡| 成人爱爱网址| 日韩视频精品在线| 国产小视频一区| 欧美视频在线观看免费| 99在线视频免费| 国产成人精品综合在线观看| 国产日韩亚洲欧美在线| 美日韩中文字幕| 亚洲精品免费网站| 牛牛精品一区二区| 在线日韩av观看| 午夜精品久久久久久久第一页按摩 | 中文字幕有码在线播放| 久久99精品久久久| 成年人午夜免费视频| 欧美色图一区| 99国产超薄丝袜足j在线观看 | 国产精品午夜视频| 日本在线观看大片免费视频| 国产丝袜一区视频在线观看 | 亚洲va久久久噜噜噜久久狠狠| 成人污版视频| 国产91av在线| 成人在线观看亚洲| 亚洲欧美国产精品va在线观看| 国产精品久久久久久久久毛片 | 久久久99精品免费观看| 天天av天天操| 久久综合激情| 精品人妻人人做人人爽| 精品国产一区二区三区小蝌蚪 | 国产无遮挡猛进猛出免费软件 | 亚洲日本一区二区| www.自拍偷拍| 国产成人免费在线视频| 密臀av一区二区三区| 欧美亚韩一区| 亚洲一区二区三区乱码| 性欧美xxxx免费岛国不卡电影| 7777精品久久久大香线蕉小说| av综合电影网站| 欧美极品少妇xxxxx| 99免在线观看免费视频高清| 亚洲国产精彩中文乱码av| 夜夜嗨av禁果av粉嫩avhd| 欧美日韩综合视频| 日韩免费不卡视频| 亚洲精品乱码久久久久久久久| 91麻豆精品国产91久久综合| 99精品国产热久久91蜜凸| 国产老头和老头xxxx×| 精品亚洲国产成人av制服丝袜| 日韩欧美黄色大片| 亚洲专区一区| 国产免费黄色小视频| 欧美婷婷在线| 992tv快乐视频| 亚洲激情五月| 国产高清免费在线| 97人人精品| 中文精品一区二区三区| 欧美日韩中字| 日韩精品久久久毛片一区二区| 神马香蕉久久| 久久草.com| 婷婷激情久久| 欧美午夜精品久久久久久蜜| 亚洲桃色综合影院| 欧美成人综合一区| 欧美激情在线精品一区二区三区| 国内精品二区| 日韩欧美ww| 欧美日韩一区在线观看视频| 免费视频国产一区| 日韩成人在线资源| 成人久久久久| 亚洲午夜在线观看| 91精品国产自产拍在线观看蜜 | 午夜免费福利在线观看| 色悠悠久久88| 大片免费在线看视频| 久久国产色av| 白白色在线观看| 国内自拍欧美激情| 蜜桃麻豆av在线| 国产不卡在线观看| 成人在线免费av| 91精品在线国产| 色妞ww精品视频7777| www.久久艹| 日韩欧美美女在线观看| 日本婷婷久久久久久久久一区二区| 国产欧美日韩| 中文字幕久久综合| 欧美精品一线| 91免费视频网站在线观看| 人妖欧美一区二区| 性色av浪潮av| 99精品1区2区| 亚洲最大成人综合网| 亚洲欧美韩国综合色| 亚洲一区欧美在线| 欧美亚洲高清一区二区三区不卡| 一级片一区二区三区| 精品国产不卡一区二区三区| 内衣办公室在线| xvideos成人免费中文版| 另类视频在线| 国产成人精品视频在线观看| 外国成人毛片| 九九九九久久久久| 亚洲成人国产| 红桃av在线播放| 国产一区二区三区免费观看| 成人在线视频免费播放| 中文一区二区在线观看 | 在线亚洲欧美专区二区| 国产裸体无遮挡| 日韩精品免费在线| 免费观看久久久久| 国产91精品久久久久久久| 日本欧美在线| 久久久人人爽| 伊人久久大香线蕉综合四虎小说| 69堂免费视频| 国产一区二区三区日韩 | 精品久久电影| 丁香花在线影院观看在线播放| 奇米精品一区二区三区在线观看 | 久久久久九九九九| 欧美高清你懂的| 久久综合色一本| 欧美精品综合| av免费一区二区| 2020国产成人综合网| 唐朝av高清盛宴| 欧美无乱码久久久免费午夜一区| 秋霞av鲁丝片一区二区| 菠萝蜜影院一区二区免费| 第一福利在线视频| 91色在线视频| 日韩电影在线视频| 免费在线观看的av网站| 国产ts人妖一区二区| 青青青视频在线播放| 欧美日韩激情视频| 亚洲av无码国产精品久久不卡| 主播福利视频一区| 欧美大胆成人| 欧美人与性禽动交精品| 亚洲国产高清一区| 日本少妇xxxx软件| 亚洲欧美日韩国产另类专区| 影音先锋国产在线| 亚洲香蕉成人av网站在线观看 | 96国产粉嫩美女| 日韩欧美不卡| 国产小视频精品| 国产日韩av一区| 久久国产乱子伦精品| 亚洲欧美在线免费| 日韩精品99| 日韩成人在线资源| 日韩精品91亚洲二区在线观看| 中国黄色a级片| 欧美日韩精品在线| 完全免费av在线播放| 久久久久久女乱国产| 欧美伊久线香蕉线新在线| 欧美美女黄色| www.com毛片| 久久久另类综合| 国产美女www| 在线观看日韩欧美| 亚洲第一会所001| 日韩av影视| 久久99久久99小草精品免视看| 国产一区二区三区四区在线| 欧美日韩综合不卡| 欧美成人高清在线| 2014亚洲精品| 日韩一级网站| 欧美亚一区二区三区| 色综合久久久久久久久久久| 国内三级在线观看| 成人黄色av网| 欧美婷婷在线| 内射中出日韩无国产剧情| 日韩欧美极品在线观看| www.在线播放| 亚洲综合在线小说| 亚洲精品日本| 国产精品毛片一区二区| 欧美性猛交xxxx乱大交退制版| 麻豆网站在线看| 国产精品国产三级欧美二区| 美女被久久久| 欧美风情第一页| 亚洲激情在线观看视频免费| 久久久久久久| 一区二区三区一级片| 国产成人精品免费网站| aaa人片在线| 久久精品最新地址| 成人台湾亚洲精品一区二区| 国产日韩一区二区在线| 国产精品久久久久aaaa| 亚洲毛片欧洲毛片国产一品色| 欧洲成人在线观看| 图片区亚洲欧美小说区| www.日本高清| 欧美三片在线视频观看| 2021中文字幕在线| 一区二区三区的久久的视频| 成人午夜碰碰视频| 五月天中文字幕| 欧美精品久久久久a| av资源久久| 美女黄色一级视频| 欧美日韩夫妻久久| 午夜影院一区| 欧美 日韩 国产精品| 国产欧美精品一区二区三区四区| 性生交生活影碟片| 国产精品黄色影片导航在线观看| 亚洲一级二级|