精品欧美一区二区三区在线观看 _久久久久国色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| 日韩欧美三区| 久久一区二区三区国产精品| 国产精品日韩电影| 免费高清在线观看电视| 久久久免费毛片| 欧美人动与zoxxxx乱| 亚洲国产精品无码av| 国产三级在线免费| 国产精品99久久久久| 国产成人精品日本亚洲| 亚洲最大的黄色网址| 免费成人蒂法| 91精品中文字幕一区二区三区| 一二三四视频社区在线| 欧美激情二区| 久久久五月婷婷| 91观看网站| 波多野结衣视频在线观看| 欧美国产高潮xxxx1819| 主播福利视频一区| www.超碰97| 亚洲欧洲国产精品一区| 欧美性大战久久久| 精品视频免费在线播放| 91黄色在线| 国产精品久久久久久一区二区三区| 国产精品一区二区三区观看| 国产口爆吞精一区二区| 日韩精品一区第一页| 欧美一级高清免费播放| 九九热国产精品视频| 亚洲网色网站| 最新91在线视频| 国产精品无码一区二区三区| 国产毛片精品| 日韩精品一区二区三区视频| 亚洲色图偷拍视频| 韩国成人在线| 欧美性猛片xxxx免费看久爱| 成人小视频在线看| 麻豆成全视频免费观看在线看| 一区二区三区在线播放| 激情图片qvod| 国产精品实拍| 超碰成人av| 精品日本12videosex| 亚洲精品国产电影| 中文视频在线观看| 国产无遮挡裸体免费久久| 日韩欧美电影一二三| 亚洲三级在线视频| 国产精品中文| 欧美白人最猛性xxxxx69交| 不用播放器的免费av| 日韩一级特黄| 91麻豆精品国产91久久久资源速度| 美女网站视频黄色| 国产亚洲精彩久久| 欧美日韩国产在线播放网站| 国产精品区在线| 欧美xxxx性| 91精品在线麻豆| 91亚洲一线产区二线产区| 91精品啪在线观看国产手机| 欧美成人性福生活免费看| 俄罗斯女人裸体性做爰| 黄色欧美网站| 亚洲老头同性xxxxx| 亚洲区免费视频| 欧美一区二区三区高清视频| 久久精品国产v日韩v亚洲| 91久久国产综合| 欧美日韩在线大尺度| 国内精品400部情侣激情| 亚洲日本韩国在线| 水蜜桃久久夜色精品一区的特点 | 欧美日韩一区在线| 91精品无人成人www| 伊人久久大香线蕉综合影院首页| 91麻豆精品国产91久久久| 久久久久亚洲av无码网站| 国产一级成人av| 亚洲色图17p| 国产一二三四区| 欧美激情在线| 日本道色综合久久影院| 怡春院在线视频| 国产成人精品一区二区三区网站观看| 国产一区二区三区四区五区加勒比| 色天堂在线视频| 日韩精品视频中文字幕| 中文字幕免费一区二区| 欧美超级乱淫片喷水| 日韩精品无码一区二区| 日日夜夜精品视频免费| 91日韩久久| 黄色av免费在线观看| 亚洲三级在线免费| 久久免费视频3| 91国产一区| 国产偷国产偷亚洲清高网站| 久久精品一区二区三区四区五区| 亚洲精品日本| 成人午夜高潮视频| 日韩a在线观看| 亚洲欧美国产三级| 免费av网址在线| 日韩中文在线| 一区二区在线视频| 日韩网红少妇无码视频香港| 加勒比av一区二区| 秋霞毛片久久久久久久久| 日本在线视频中文有码| 欧美综合亚洲图片综合区| 性高潮免费视频| 国产精品毛片久久| 国产mv免费观看入口亚洲| 亚洲精品久久久久久无码色欲四季| 久久久精品人体av艺术| 久久这里只有精品8| 欧洲亚洲精品久久久久| 亚洲男女自偷自拍图片另类| 久久久久久久久久久网| 精品一区二区三区久久久| 欧美精品一区在线| 九九色在线视频| 欧美精品日日鲁夜夜添| 精品日韩在线视频| 视频一区在线播放| 国产一区在线免费| 秋霞在线午夜| 欧美大黄免费观看| 三级影片在线看| 久久精品久久综合| 婷婷四月色综合| 日韩高清中文字幕一区二区| 亚洲国产精品久久久久秋霞蜜臀| 黑人巨大精品一区二区在线| 久久99精品网久久| 亚洲欧美在线网| 玖玖精品在线| 欧美大片免费高清观看| 欧美色网一区二区| 日本二区在线观看| 久久精品网址| 日本黑人久久| 亚洲成人av观看| 中文字幕精品在线| 国产亚洲久一区二区| 国产色91在线| 第四色婷婷基地| 欧美激情777| 91免费国产网站| 好吊日视频在线观看| 6080午夜不卡| 妺妺窝人体色www聚色窝仙踪| 国产精品1区二区.| bt天堂新版中文在线地址| aiai久久| 欧美一区二粉嫩精品国产一线天| 深夜福利免费在线观看| 色一区在线观看| jizz中文字幕| 麻豆成人av在线| 中国女人做爰视频| 成人福利免费在线观看| 2019中文字幕在线免费观看| 男操女在线观看| 欧美三片在线视频观看| 国产真实乱在线更新| 丁香一区二区三区| 国产av无码专区亚洲精品| 欧美三级美国一级| 成人在线中文字幕| www.51av欧美视频| 国产一区二区三区欧美| 亚洲天堂avav| 亚洲国产日韩av| 欧美图片第一页| 麻豆成人在线观看| www.av片| 91麻豆国产自产在线观看亚洲| 91在线中文字幕| 涩涩网在线视频| 日韩小视频网址| 日本波多野结衣在线| 欧美在线免费观看亚洲| 欧美日韩成人免费观看| 久久久午夜精品| 三级黄色片免费看| 久久免费黄色| 潘金莲一级淫片aaaaa免费看| 欧美a一欧美| 国产日韩欧美91| bbw在线视频| 国产毛片精品视频| 成人免费看黄网站| 日韩电影免费看| 久久精品视频导航| 日韩电影网址| 91精品国产欧美一区二区成人 | 欧美一区视频| 欧美一区二区在线| 中文字幕一区二区三区中文字幕 | 国产aaa免费视频| 日韩国产在线| 极品校花啪啪激情久久| 9999在线精品视频| 国产va免费精品高清在线| 青草视频在线免费直播| 最新的欧美黄色| 激情综合闲人网| 亚洲国产99精品国自产| 91禁在线观看| 色美美综合视频| 1级黄色大片儿| 亚洲免费av观看| xxxxx99| 91丨九色porny丨蝌蚪| 三级黄色片播放| 免费成人美女在线观看| 国产a级一级片| 亚洲视频综合| 成年人视频网站免费| 亚洲九九在线| 一区二区三区我不卡| 国产伦精品一区二区三区视频 | 中国黄色片一级| 奇米888四色在线精品| 欧美s码亚洲码精品m码| 亚洲黄色大片| 黄色一级片在线看| 国产精品xvideos88| 法国空姐在线观看免费| 91亚洲人成网污www| 午夜久久资源| 成人6969www免费视频| 日韩美女一区| 精品美女久久久| 欧美一区激情视频在线观看| 亚洲欧洲av| 欧美日韩国产综合视频在线| 秋霞在线一区| 精品一区二区三区自拍图片区| 国产精品超碰| 久久国产精品高清| 亚洲福利天堂| 欧洲精品亚洲精品| 狠狠综合久久av一区二区蜜桃| 欧美成人综合一区| 日本不卡免费高清视频在线| 国产亚洲网站| 一区二区不卡在线观看| 久久精品高清| 无码毛片aaa在线| 激情欧美一区| 日韩国产欧美亚洲| 免费中文字幕日韩欧美| www.xxx亚洲| 久久99国产精品久久99果冻传媒| 手机av在线免费| 国产成人在线色| 亚洲欧美高清在线| 2021中文字幕一区亚洲| 妺妺窝人体色WWW精品| 国产精品初高中害羞小美女文| 亚洲欧美综合7777色婷婷| 亚洲色图一区二区三区| 久久精品黄色片| 精品国产鲁一鲁一区二区张丽| 欧美一区二区三区不卡视频| 欧美日韩一区中文字幕| 国产99视频在线| 日韩电影中文 亚洲精品乱码| 免费在线看v| 久久亚洲欧美日韩精品专区| 欧美性受ⅹ╳╳╳黑人a性爽| 68精品国产免费久久久久久婷婷 | 国产视频在线看| 色妞一区二区三区| 国产三级视频在线看| 一区二区国产精品视频| 免费黄色在线| 久久免费福利视频| 成人性生活av| 91久久精品久久国产性色也91| 中文字幕一区二区三区中文字幕 | 日韩一级片播放| 黄色精品一二区| 黄色免费看视频| 中文字幕不卡三区| 精品无码一区二区三区电影桃花 | 国产精品毛片一区二区在线看舒淇| 欧美精品久久一区二区三区| 天堂av中文字幕| 久久国内精品一国内精品| 成人国产电影在线观看| 成人国产精品色哟哟| 日韩欧美国产大片| 公共露出暴露狂另类av| 久久在线91| 国产精久久久久| 国产精品欧美一区喷水| 毛片在线免费视频| 日韩免费电影一区| 福利视频在线播放| 91av在线国产| 成人av综合网| 2021狠狠干| www.国产免费| 欧美日韩国产精品一区二区三区四区| 91久久精品无码一区二区| 日韩精品免费在线视频观看| 天堂亚洲精品| 91久久精品美女| 日本久久精品| 欧美性大战久久久久xxx| 懂色av噜噜一区二区三区av| 中文字幕观看av| 欧美伊人久久大香线蕉综合69| 午夜在线视频观看| 久久免费国产精品1| 久久久久毛片免费观看| 亚洲精品一区二| 日韩激情av在线| 少妇大叫太粗太大爽一区二区| 亚洲制服欧美中文字幕中文字幕| 在线播放国产一区| 中文字幕亚洲无线码a| 伊人久久综合一区二区| 国产一区二区在线网站| 欧美黄色精品| 佐佐木明希电影| 亚洲精品亚洲人成人网在线播放| 国产一区二区三区视频免费观看| 一级做a爰片久久毛片美女图片| 国产精品扒开腿做爽爽爽视频软件| 狠狠色狠狠色综合人人| 激情欧美日韩一区| 中文字幕乱码一区| 亚洲成av人**亚洲成av**| 性生活视频软件| 海角国产乱辈乱精品视频| 视频成人永久免费视频| 四虎永久免费网站| 国产精品一区一区三区| 亚洲成人生活片| 日韩精品一区二区三区在线播放 | 久久经典视频| 热久久美女精品天天吊色| 亚洲日产av中文字幕| 久久精品99国产| 亚洲国产精品t66y| 国产又黄又爽视频| 另类色图亚洲色图| 亚洲国产欧美国产第一区| 久久久久99精品成人片| 91一区一区三区| 日本中文字幕在线观看视频| 中文字幕无线精品亚洲乱码一区 | 精品国产免费人成网站| 日韩高清av电影| 久草中文综合在线| avtt天堂在线| 亚洲国产成人精品电影| 亚洲第一影院| 久久久一二三四| 成人精品鲁一区一区二区| 在线观看日韩中文字幕| 自拍偷拍亚洲在线| 日韩精品成人| 欧美色图另类小说| 欧美韩国日本不卡| 九色91在线视频| 日韩精品1区| 日本55丰满熟妇厨房伦| 午夜私人影院久久久久| 国产美女性感在线观看懂色av | 91国在线视频| 欧美激情精品久久久久久久变态| 天天做夜夜做人人爱精品 | 色七七影院综合| 91精品短视频| 欧美精品aaaa| 一区二区久久久久| 成人午夜在线观看视频| 91在线视频免费| 亚洲一区亚洲| www.av成人| 国产丝袜高跟一区| 成人噜噜噜噜| 日韩视频免费在线播放| 一区二区三区中文免费| 国产小视频在线观看| 成人午夜电影在线播放| 日本美女一区二区| 国产精品白浆一区二小说| 日韩中文字幕亚洲| 精品在线91|