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

從2s優化到0.1s,我用了這五步

開發 架構
我們的網站使用了SpringBoot推薦的模板引擎:Thymeleaf,進行動態渲染。它是一個XML/XHTML/HTML5模板引擎,可用于Web與非Web環境中的應用開發。

前言

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

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

到底是怎么回事呢?

背景

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

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

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

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

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

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

第1次優化

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

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

我們不得不做優化了。

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

流程圖如下:

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

  • 用戶訪問接口獲取分類樹時,先從Redis中查詢數據。
  • 如果Redis中有數據,則直接數據。
  • 如果Redis中沒有數據,則再從數據庫中查詢數據,拼接成分類樹返回。
  • 將從數據庫中查到的分類樹的數據,保存到Redis中,設置過期時間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作為內存緩存。

改造后的流程圖如下:

  • 用戶訪問接口時改成先從本地緩存分類數查詢數據。
  • 如果本地緩存有,則直接返回。
  • 如果本地緩存沒有,則從Redis中查詢數據。
  • 如果Redis中有數據,則將數據更新到本地緩存中,然后返回數據。
  • 如果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問題被解決了。

性能優化問題,無論在面試,還是工作中,都會經常遇到。

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

2023-05-14 17:16:22

分類樹SpringBoot

2023-12-25 08:24:03

雙異步數據庫Excel

2022-06-30 19:40:36

查詢接口索引優化

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優化數據庫

2024-03-04 08:29:33

數據定制化Java

2025-02-14 09:30:42

2024-10-16 12:45:01

2021-09-10 08:31:36

技術Prometheus監控

2024-09-12 14:51:27

2025-11-11 04:00:00

2022-09-29 11:35:34

數據分析體系

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
點贊
收藏

51CTO技術棧公眾號

日韩免费va| 日韩一级在线播放| 天天综合网91| 日韩女优制服丝袜电影| r级无码视频在线观看| 日本午夜在线| 精品影视av免费| 欧美激情欧美激情| 日韩精品无码一区二区三区久久久| 亚洲承认视频| 亚洲精品国产a久久久久久| 国产伦精品一区| 蜜臀99久久精品久久久久小说| 我不卡影院28| 亚洲精品成人久久电影| 一区二区三区韩国| 96av在线| 亚洲欧美色图小说| 久久综合久久久| jlzzjlzz亚洲女人18| 性欧美videos另类喷潮| 美女精品久久久| 99久久久久久久久久| 免费精品一区二区三区在线观看| 狠狠躁夜夜躁久久躁别揉| 在线视频不卡一区二区| 狠狠狠综合7777久夜色撩人| 国产乱色国产精品免费视频| 国产精品扒开腿做| 日本亚洲欧美在线| 在线成人超碰| 中文字幕国产亚洲2019| 国产制服丝袜在线| 亚洲一区二区三区四区电影 | 日韩av一区二区在线播放| 欧洲福利电影| 国产午夜精品久久久 | 久久成人精品一区二区三区| 亚洲色图14p| 538任你躁精品视频网免费| 精品视频一区二区不卡| 国产精品免费成人| 国产黄大片在线观看| 一区av在线播放| 欧美xxxx吸乳| 国产黄网站在线观看| 国产精品电影一区二区三区| 日韩精品久久久| 日本电影一区二区在线观看 | 国产ts在线播放| 欧美综合自拍| 日韩av在线播放资源| 国产精品二区视频| 欧美视频精品全部免费观看| 欧美日韩国产一二三| mm1313亚洲国产精品无码试看| 高端美女服务在线视频播放| 亚洲精品国产品国语在线app| 一区二区三区电影| 在线观看的av| 亚洲国产精品高清| 亚洲午夜精品福利| 在线观看麻豆蜜桃| 亚洲欧洲日产国产综合网| 一区二区不卡在线视频 午夜欧美不卡' | 亚洲欧美日本一区| 里番精品3d一二三区| 精品国产麻豆免费人成网站| 中文在线字幕观看| 99精品在免费线中文字幕网站一区| 717成人午夜免费福利电影| 一区二区在线免费看| 五月天色综合| 91精品国产aⅴ一区二区| 日日夜夜精品视频免费观看| 欧美a在线观看| 日韩视频永久免费| 亚洲熟女一区二区| 亚洲人亚洲人色久| 国产亚洲欧美日韩一区二区| 韩国女同性做爰三级| 欧美日韩中文字幕一区二区三区 | 国产精品swag| 少妇高潮久久久| 久久亚洲一区二区三区明星换脸| 欧美一区二区三区四区五区六区| 国产福利在线看| 中文字幕一区二区在线播放| 粉嫩av一区二区三区天美传媒| 色操视频在线| 欧美视频中文在线看| 男人的天堂日韩| 91成人在线网站| 精品对白一区国产伦| 久久精品成人av| 婷婷丁香综合| 91爱视频在线| 91超薄丝袜肉丝一区二区| 国产不卡高清在线观看视频| 蜜桃精品久久久久久久免费影院| 成年人视频在线观看免费| 亚洲精品成a人| 亚洲人成无码www久久久| 电影一区二区三区久久免费观看| 精品国产区一区| 欧美激情亚洲色图| 激情综合在线| 国产欧美日韩精品丝袜高跟鞋| 超碰在线观看av| 国产视频一区二区在线观看| 大胆欧美熟妇xx| 日韩视频网站在线观看| 日韩欧美一区在线观看| 亚欧洲乱码视频| 好看的av在线不卡观看| 国产精品永久免费观看| www.亚洲黄色| 国产精品久久久久9999吃药| 日本大胆人体视频| 欧美一级二级视频| 亚洲成色999久久网站| 国产亚洲精品精品精品| 午夜亚洲激情| 国产精品乱码视频| 看黄网站在线| 在线国产亚洲欧美| 私密视频在线观看| 欧美日韩国产色综合一二三四| 国产精品成人v| 人妻91麻豆一区二区三区| 亚洲天堂免费在线观看视频| 已婚少妇美妙人妻系列| 噜噜噜狠狠夜夜躁精品仙踪林| 爱福利视频一区| 中文字幕乱码视频| 久久精品日产第一区二区三区高清版 | 捆绑裸体绳奴bdsm亚洲| 欧美激情日韩| 91免费的视频在线播放| 91亚洲精选| 在线看一区二区| 国产精品毛片一区二区| 宅男噜噜噜66国产日韩在线观看| 国产99午夜精品一区二区三区| 色网站在线看| 欧美日韩国产精品成人| 日本成人免费视频| 日本成人中文字幕在线视频| 欧美性天天影院| 欧美18av| 亚洲欧洲日本专区| 波多野结衣不卡| 国产人伦精品一区二区| www.99在线| blacked蜜桃精品一区| 日韩美女视频在线观看| 亚洲人成色777777精品音频| 午夜激情一区二区三区| 日本wwwwwww| 欧美激情成人在线| 不卡的av一区| 日本h片在线| 精品国产在天天线2019| 青青草偷拍视频| 久久国产麻豆精品| 亚洲国产精品视频一区| 欧洲成人一区| 伊人久久大香线蕉av一区二区| 九九热精品视频在线| 国产午夜亚洲精品不卡| www.色就是色| 欧美激情777| 91精品免费看| av网站网址在线观看| 精品国产露脸精彩对白| 精品视频一区二区在线观看| 国产98色在线|日韩| 欧美乱做爰xxxⅹ久久久| 亚洲日本va| 热久久这里只有精品| 国产在线视频网址| 欧美美女一区二区三区| 免费三级在线观看| 精品在线视频一区| 国产精品自拍合集| 国产精品x8x8一区二区| 2019精品视频| 成年女人的天堂在线| 在线不卡a资源高清| 免费视频网站www| 成人午夜电影久久影院| 国产亚洲精品网站| 日韩免费高清| 国产偷国产偷亚洲高清97cao| 国产精品迅雷| www国产亚洲精品久久网站| 亚洲精品人妻无码| 精品人伦一区二区三区蜜桃网站| 久久视频一区二区三区| 国产精品一级二级三级| 免费在线观看日韩视频| 欧美一级本道电影免费专区| 91亚洲va在线va天堂va国| 白浆视频在线观看| 一区二区三区久久精品| 国产肥老妇视频| 色综合网站在线| 久久久精品国产sm调教网站| 久久久久高清精品| 毛毛毛毛毛毛毛片123| 香蕉亚洲视频| 亚洲精品在线免费看| 久久久亚洲欧洲日产| 日韩视频精品在线观看| 91黄色国产视频| 波多野结衣在线播放| 亚洲精品国产suv| 亚洲综合视频在线播放| 亚洲国产一二三| 337人体粉嫩噜噜噜| 国产精品夜夜嗨| 五月婷婷之婷婷| 一本久久综合| 欧美与动交zoz0z| 少妇精品久久久| 高清国产在线一区| 岛国精品在线| 91豆花精品一区| 成人黄视频在线观看| 亚洲美女喷白浆| 日韩一级片免费看| 91精品国产91久久综合桃花 | 一区二区免费看| 婷婷综合在线视频| 成人国产一区二区三区精品| 成人日韩在线视频| 免费在线观看成人av| 免费成人深夜夜行网站视频| av资源久久| 欧美日韩一区二区视频在线观看| 色播一区二区| 国产精品网站大全| 久热在线观看视频| 欧美乱大交做爰xxxⅹ性3| 福利片在线观看| 亚洲精品黄网在线观看| 国产精品天天操| 欧美日韩国产经典色站一区二区三区 | 欧美熟乱15p| 欧美精品中文字幕一区二区| 国产精品成人自拍| 91在线精品播放| 91在线成人| 国产成人精品日本亚洲| 日韩理论视频| 欧美国产第一页| 欧美24videosex性欧美| 久久亚洲综合国产精品99麻豆精品福利| 国产视频福利在线| 亚洲一区av在线播放| 国产精品99999| 国产小视频国产精品| 色吊丝在线永久观看最新版本| 亚洲二区在线播放视频| 亚洲第一成人av| 日韩精品中文字幕在线一区| av网站在线免费看| 欧美一区二区在线看| 一区二区视频网站| 欧美一区二区女人| 国产激情久久久久久熟女老人av| 91精品久久久久久久91蜜桃| 中文字幕你懂的| 在线电影院国产精品| 国产裸体无遮挡| 欧美一区二区精品| 亚洲成人777777| 亚洲精品综合久久中文字幕| 免费在线毛片| 中文字幕国产精品| 国产调教视频在线观看| 九九精品在线视频| 成人免费一区二区三区牛牛| 97国产成人精品视频| a日韩av网址| 国产日韩av在线| 国产成人精品一区二区三区免费| 91精品在线一区| 成人爽a毛片免费啪啪红桃视频| 国产亚洲第一区| 理论片一区二区在线| 亚洲一区二区精品在线| 欧美在线资源| 久草资源站在线观看| 九九视频精品免费| 中文字幕99页| 久久久精品综合| 国产大屁股喷水视频在线观看| 一区二区三区欧美在线观看| 免费日韩一级片| 欧美日韩成人高清| 亚洲经典一区二区三区| 亚洲人成在线观| 草莓福利社区在线| 91精品国产91久久久久久久久 | 亚洲美女区一区| 日韩熟女精品一区二区三区| 欧美视频在线观看一区| www.日日夜夜| 亚洲欧洲黄色网| 二区在线播放| 国产精品成av人在线视午夜片| 精品成人18| 欧美另类网站| 911精品美国片911久久久 | 草草影院在线| 国产精品一区二区3区| 国产福利资源一区| 日本午夜精品电影| 在线日韩av| 天天综合天天添夜夜添狠狠添| www.色精品| 麻豆91精品91久久久| 在线视频国内一区二区| 亚洲精品久久久久久无码色欲四季 | 日本77777| 国产人伦精品一区二区| 国产稀缺真实呦乱在线| 欧美精品日日鲁夜夜添| 日韩电影免费| 97精品在线视频| 精品国产乱码一区二区三区| 日本一区网站| 欧美日韩国产色综合一二三四| 亚洲涩涩在线观看| 久久伊人蜜桃av一区二区| 久久久久久久久艹| 欧美欧美午夜aⅴ在线观看| 亚洲人成色777777精品音频| 欧美日韩国产二区| 色婷婷成人网| 亚洲永久激情精品| 视频一区中文字幕| 波多野结衣影院| 一区二区成人在线观看| 国产黄色片免费观看| 欧美日韩福利视频| 国产精品久久久久久久久久辛辛 | 182午夜视频| 国产精品网站在线| 成人黄色免费网| 亚洲人成绝费网站色www| 国产福利电影在线播放| 国产98在线|日韩| 欧美日韩18| 尤物网站在线观看| 亚洲成va人在线观看| 精品人妻一区二区三区四区不卡| 欧美成人免费网| 欧美h版在线观看| 青青草视频国产| 国产精品一区二区无线| 青草草在线视频| 精品国产一区二区亚洲人成毛片| 在线午夜影院| 国产欧美日韩在线播放| 亚洲国产1区| 好男人香蕉影院| 欧美性极品少妇精品网站| 日韩在线免费看| 日韩免费观看视频| 欧洲乱码伦视频免费| 日本特黄a级片| 国产精品乱码妇女bbbb| 国产乡下妇女三片| 久久久国产精品一区| 疯狂欧洲av久久成人av电影 | 黄页视频在线播放| 91精品久久久久久久久久久久久 | 欧美大黑帍在线播放| 国产精品18久久久| 日本最新中文字幕| 精品一区二区三区四区| 成人av色网站| 欧美日韩视频免费| 久久亚洲精华国产精华液 | 欧美在线|欧美| a视频在线播放| 国产日韩欧美一区二区| 香蕉久久国产| 日韩高清dvd碟片| 亚洲变态欧美另类捆绑| 色偷偷色偷偷色偷偷在线视频| 日韩欧美视频一区二区| 激情综合一区二区三区| 九九热国产在线| 国产亚洲欧美另类中文| 国产精品一区二区三区av | 亚洲自拍另类| 糖心vlog免费在线观看|