欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

java分類樹,我從2s優(yōu)化到0.1s

 更新時間:2023年05月15日 08:48:52   作者:蘇三說技術(shù)  
這篇文章主要介紹了java分類樹,我從2s優(yōu)化到0.1s的相關(guān)資料,需要的朋友可以參考下

分類樹查詢功能,在各個業(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或其他模板引擎,如Velocity\FreeMarker等。

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

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

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

第1次優(yōu)化

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

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

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

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

流程圖如下:

于是暫時這樣優(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)和自測順利完成了。

第2次優(yōu)化

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

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

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

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

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

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

增加了一個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獲取分類樹導(dǎo)致的網(wǎng)站首頁的性能瓶頸。

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

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

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

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

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

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

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

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

改造后的流程圖如下:

  • 用戶訪問接口時改成先從本地緩存分類數(shù)查詢數(shù)據(jù)。
  • 如果本地緩存有,則直接返回。
  • 如果本地緩存沒有,則從Redis中查詢數(shù)據(jù)。
  • 如果Redis中有數(shù)據(jù),則將數(shù)據(jù)更新到本地緩存中,然后返回數(shù)據(jù)。
  • 如果Redis中也沒有數(shù)據(jù)(說明Redis掛了),則從數(shù)據(jù)庫中查詢數(shù)據(jù),更新到Redis中(萬一Redis恢復(fù)了呢),然后更新到本地緩存中,返回返回數(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),運營同學(xué)在系統(tǒng)后臺增加了很多分類。

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

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

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

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

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

讓數(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
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;
}

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

由此,可以在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問題被解決了。

到此這篇關(guān)于java分類樹,我從2s優(yōu)化到0.1s的文章就介紹到這了,更多相關(guān)java分類樹優(yōu)化內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • springcloud項目改名的操作方法

    springcloud項目改名的操作方法

    這篇文章主要介紹了springcloud項目改名的操作方法,本文通過圖文并茂的形式給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-11-11
  • springboot websocket簡單入門示例

    springboot websocket簡單入門示例

    這篇文章主要介紹了springboot websocket簡單入門示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-08-08
  • Java9中接口的私有方法詳解

    Java9中接口的私有方法詳解

    印象中Java?接口就沒有論述私有方法這回事。既然?Java?9?添加了這項特性,那么,應(yīng)該就有它的用途,我們一起來看看?Java?9?中的接口的私有方法是什么樣的吧
    2023-04-04
  • 基于JAVA的短信驗證碼api調(diào)用代碼實例

    基于JAVA的短信驗證碼api調(diào)用代碼實例

    這篇文章主要為大家詳細介紹了基于JAVA的短信驗證碼api調(diào)用代碼實例,感興趣的小伙伴們可以參考一下
    2016-05-05
  • java 注解實現(xiàn)一個可配置線程池的方法示例

    java 注解實現(xiàn)一個可配置線程池的方法示例

    這篇文章主要介紹了java 注解實現(xiàn)一個可配置線程池的方法示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2019-01-01
  • 帶你盤點Java的五種運算符

    帶你盤點Java的五種運算符

    這篇文章主要介紹了Java基本數(shù)據(jù)類型和運算符,結(jié)合實例形式詳細分析了java基本數(shù)據(jù)類型、數(shù)據(jù)類型轉(zhuǎn)換、算術(shù)運算符、邏輯運算符等相關(guān)原理與操作技巧,需要的朋友可以參考下
    2021-07-07
  • 常見的排序算法,一篇就夠了

    常見的排序算法,一篇就夠了

    這篇文章主要介紹了一些常用排序算法整理,插入排序算法、直接插入排序、希爾排序、選擇排序、冒泡排序等排序,需要的朋友可以參考下
    2021-07-07
  • HttpClient 在Java項目中的使用詳解

    HttpClient 在Java項目中的使用詳解

    HttpClient作為訪問Http服務(wù)的客戶端訪問程序已經(jīng)被廣泛使用,提高了開發(fā)效率,也提高了代碼的健壯性。因此熟練掌握HttpClient是必需的,關(guān)于httpclient感興趣的朋友可以參考本篇文章
    2015-10-10
  • Spring?cache源碼深度解析

    Spring?cache源碼深度解析

    緩存用于提升系統(tǒng)的性能,特別適用于一些對資源需求比較高的操作,下面這篇文章主要給大家介紹了關(guān)于Spring?cache源碼的相關(guān)資料,文中通過示例代碼介紹的非常詳細,需要的朋友可以參考下
    2022-03-03
  • java實現(xiàn)app簽到功能

    java實現(xiàn)app簽到功能

    這篇文章主要為大家詳細介紹了java實現(xiàn)app簽到功能,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-11-11

最新評論