亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術文章
文章詳情頁

java - 怎樣優化接口返回大體量數據?

瀏覽:91日期:2023-12-13 14:53:33

問題描述

需求描述:

外圍平臺調用接口根據手機號查詢用戶的歌單推薦信息,每個用戶會有一千條左右的推薦信息,每條推薦信息包括了,歌曲ID、歌曲名稱、版權ID、試聽地址字段。

我需要關聯多張表查詢,每次查詢時間大概4s左右,查詢出來后還需要組裝數據,然后才返回接口。

返回格式是json。這樣的話接口返回會比較慢。

想過提前將數據放redis集群,但是后來否定了,因為用戶量大概是500多萬,每個用戶的推薦信息大小大概200kb,存redis的話會耗費大量的內存,所以否定了。但是想不到其它給好的處理方法,請各位大神幫忙看看這樣一個需求有什么好的處理建議嗎?感謝!

問題解答

回答1:

瓶頸出在查詢很多張表需要4秒上,這里面的邏輯有可以優化的點嗎?如果沒有那么這4秒必須花費,其他的數據傳輸格式,網絡通信時間再優化也無法小于4秒了。要么在客戶端在某個用戶無感知的情況下發推薦請求,要么優化查詢邏輯。

回答2:

你鏈表查詢,把你的sql貼出來,另外為什么不分開查詢呢?估計你耗時在SQ

回答3:

1.一次返回一千條?一次50條會不會快點呢?多次分頁請求呢?2.覺得直接把緩存方案否了不妥,500多w的用戶,并不都是活躍用戶,估算出活躍用戶的量的redis可以接受不?3

回答4:

在【推薦信息】上添加ID屬性,保存在redis,這個量應該不會大。

每個用戶推薦的信息也存在redis上,但是只保存1000個【推薦信息】的ID。

這樣的話就不會造成每個用戶的推薦信息有200kb了。

標簽: java
相關文章:
主站蜘蛛池模板: 欧美视频在线观看一区二区 | 九九精品视频免费 | 免费一级毛片在线播放视频 | 精品国产午夜久久久久九九 | 国产福利精品视频 | 18年大片免费在线观看 | 黄色自拍 | 另类国产精品一区二区 | 国产美女福利在线 | 91在线一区二区三区 | 欧美日韩在线亚洲国产人 | 色综合合久久天天综合绕视看 | 大ji吧快给我别停受不了视频 | 久久99精品国产99久久 | 亚洲成人在线视频观看 | 午夜在线视频国产 | 免费看国产一级特黄aa大片 | 亚洲精品啪啪一区二区三区 | 国产三级黄色片 | 那个网站可以看毛片 | 欧美一区亚洲 | 高清不卡毛片免费观看 | 亚洲欧美制服丝袜一区二区三区 | 免费看一级毛片欧美 | 70岁老妇女一级毛片爽 | 国产免费色视频 | 国产免费全部免费观看 | 中文激情 | 亚洲123 | 一级片网站在线观看 | 四虎91视频 | 午夜亚洲国产 | 九九精| 欧美日韩国产最新一区二区 | 久久国产精品2020免费m3u8 | 丰满的日本护士xxx 丰满美女福利视频在线播放 | 女人182毛片a级毛片 | 可以免费观看一级毛片黄a 可以免费观看欧美一级毛片 | 午夜视频黄色 | 草草网址 | 伊人蕉久中文字幕无码专区 |