亚洲 国产精品 日韩-亚洲 激情-亚洲 欧美 91-亚洲 欧美 成人日韩-青青青草视频在线观看-青青青草影院

千鋒教育-做有情懷、有良心、有品質的職業教育機構

手機站
千鋒教育

千鋒學習站 | 隨時隨地免費學

千鋒教育

掃一掃進入千鋒手機站

領取全套視頻
千鋒教育

關注千鋒學習站小程序
隨時隨地免費學習課程

當前位置:首頁  >  技術干貨  > 記一次OOM問題的解決連載一 【流式查詢】

記一次OOM問題的解決連載一 【流式查詢】

來源:千鋒教育
發布人:qyf
時間: 2023-03-02 20:44:00 1677761040

  一. 問題概述

  老師的一個學生入職了杭州中通全球創研中心,最近他給老師分享一個他們公司解決OOM問題的案例,老師覺得十分有趣,特意把這個案例記錄下來,日后我會做成教學案例分享給學生。這個問題發生的背景如下:

  【在物流領域,針對各個下級網點而言,每月1日~9日是進行財務月結的重要時間節點。在這個關鍵節點上,各個網點需要使用導出功能輸出寄派件、費用客戶信息等多種信息進行匯總結算】。也就是說,在月初的時候,每個網點都要統計一個月的各種流水(寄件,收件等),最后再以excel表格的形式下載給客戶。

  那么在這個業務中為什么很容易發生OOM異常呢?這是因為平均1個網點1個月的流水數據大約在30w行左右,根據計算得出大約500行數據就會占用1M內存,而1個站點把30萬行一股腦地讀到內存中,就會占用600M內存。試想一下,如果全國的網點都在月初集中下載報表的話,JVM是很容出現內存溢出的問題的!

  二. 解決方案

  那么這樣一個棘手的問題,如果我們只用一個單一的解決方案是不夠的,老師根據學生的描述,建議該學生主要采取以下幾種解決方案。

  2.1 用硬盤空間置換內存空間

  如果我們在接到統計數據請求的時候,一次性把30w條數據從數據庫讀取到一個List集合中,這顯然是不合理的,因為這樣一個List集合就會占用600M內存。所以我們可以進行分頁查詢,每次查詢1000條數據,然后往硬盤里寫,多讀取幾次,一點一點的把所有的數據都讀出來,再一點一點的往硬盤中寫。這樣在這個過程中,占用的內存就會少很多,主要變成了對硬盤空間的占用。而我們操作excel的技術,可以選擇阿里巴巴的easyexcel。

  2.2 使用Mybatis的流式查詢

  我們可以使用Mybatis的【流式查詢】查詢技術,在查詢成功后返回的是一個迭代器而不是一個集合,應用每次都從迭代器中獲取一條查詢結果,能夠降低內存的使用。試想一下,如果我們不使用流式查詢,而想要一次性從數據庫中讀取30萬條數據,內存是根本不夠用的!這時我們只能選擇分頁查詢,而分頁查詢的性能又取決于表設計以及索引的設計,大量數據分頁查詢的性能是很低的。老師對比了使用流式查詢和分頁查詢的兩種方案,得到的結論是取30萬條數據時,流式查詢的速度大約是分頁查詢的4~5倍左右。

  2.3 使用redission信號量限流

  生成一個月的流水報表是一個非常耗時的操作,用戶也不可能馬上就要結果,所以我這個學生的公司對同時生成報表的請求數量做了限制,同時只能處理10個報表的生成。在這期間如果再有生成報表的請求,我們將會讓這些請求排隊,等到前面的報表生成完畢后,再處理后面的請求。報表生成成功后,再通知客戶主動去下載,老師建議這里使用redisson分布式鎖的信號量來限制同時創建報表的線程數量。

  2.4 MQ解耦+微服務拆分

  本次業務中,讀數據庫,編寫excel文件,上傳到文件服務器這三個操作都非常耗時,學生的公司使用了MQ解耦,并把這次請求拆分成3個微服務,這樣讀、寫、上傳就不會相互影響了。

  三. 流式查詢

  在這篇文章中,老師只給大家分享一下Mybatis流式查詢的實現方法,其他的解決方案以后會在其他的文章中給大家呈現。

  3.1 概念

  流式查詢就是查詢成功后返回的是一個迭代器而不是一個集合,應用每次都從迭代器中獲取一條查詢結果,這樣能夠降低內存的使用。

  3.2 Mybatis實現流式查詢

  接下來就是實現流失查詢的具體過程。

  在mapper映射文件中,編寫流式查詢的邏輯。

<!--
1: fetchSize: 官方文檔建議設置成Integer.MIN_VALUE
2: resultSetType="FORWARD_ONLY" 返回一個只向前的游標
3:注意我把表一次性查出,并沒有使用分頁邏輯,依靠流式查詢一行一行得到結果
-->
<select id="selectFetchSize" fetchSize="-2147483648" resultSetType="FORWARD_ONLY" resultType="com.qf.shop.cms.entity.TContent">
select * from t_content
</select>

  在mapper接口文件中添加selectFetchSize方法。

  // 參數 ResultHandler 是一個回調接口,也就是從游標中獲得一條數據就會回調接口中的方法

  void selectFetchSize(ResultHandlerhandler);

  自己編寫一個類實現ResultHandler接口,在該接口中定義從游標獲得一條數據后的回調邏輯。

  /**

  * 通過流式查詢每獲得一條數據的回調類

  */

  public class TContentResultHandler implements ResultHandler{

  /**

  * 這里每集滿1000條數據 往硬盤的excel文件中追加一次數據

  */

  private final static int BATCH_SIZE = 1000;

  /**

  * 計數器

  */

  private int size=0;

  /**

  * 存儲每批數據的臨時容器

  */

  private ListtContents = new ArrayList<>();

  /**

  * 每從流式查詢中獲得一行結果,就會調用一次這個方法

  * @param resultContext

  */

  @Override

  public void handleResult(ResultContext resultContext){

  // 這里獲取流式查詢每次返回的單條結果

  TContent resultObject = resultContext.getResultObject();

  // 你可以看自己的項目需要分批進行處理或者單個處理,這里以分批處理為例

  tContents.add(resultObject);

  size++;

  if (size == BATCH_SIZE) {

  // 如果集滿1000條就往文件中寫一次

  handle();

  }

  }

  /**

  * 集滿1000條 執行一次的邏輯

  */

  private void handle() {

  try {

  // 在這里可以對你獲取到的批量結果數據進行需要的業務處理

  // 這里的業務是 往文件中寫一次

  } finally {

  // 處理完每批數據后后將臨時清空

  size = 0;

  tContents.clear();

  }

  }

  /**

  * 這個方法給外面調用,用來完成最后一批數據處理

  */

  public void end(){

  handle();// 處理最后一批不到BATCH_SIZE的數據

  }

  }

  在業務邏輯(service)層調用流式查詢方法。

  @Autowired

  private TContentMapper contentMapper;

  public void streamQuery(){

  // 生成流式查詢的回調對象

  TContentResultHandler tContentResultHandler = new TContentResultHandler();

  // 調用流式查詢

  contentMapper.selectFetchSize(tContentResultHandler);

  // 執行完最后一批數據的邏輯

  tContentResultHandler.end();

  }

  四. 后話

  老師前面已經說到,為了解決本次產生的OOM問題,老師給大家列舉了非常多的解決方案,但本篇文章介紹的流式查詢只是其中的方案之一。至于其他的解決方案,老師將在后續的文章中為大家一一揭曉,敬請各位繼續關注本公眾號,如有問題,可以在評論區給我們留言哦。

tags:
聲明:本站稿件版權均屬千鋒教育所有,未經許可不得擅自轉載。
10年以上業內強師集結,手把手帶你蛻變精英
請您保持通訊暢通,專屬學習老師24小時內將與您1V1溝通
免費領取
今日已有369人領取成功
劉同學 138****2860 剛剛成功領取
王同學 131****2015 剛剛成功領取
張同學 133****4652 剛剛成功領取
李同學 135****8607 剛剛成功領取
楊同學 132****5667 剛剛成功領取
岳同學 134****6652 剛剛成功領取
梁同學 157****2950 剛剛成功領取
劉同學 189****1015 剛剛成功領取
張同學 155****4678 剛剛成功領取
鄒同學 139****2907 剛剛成功領取
董同學 138****2867 剛剛成功領取
周同學 136****3602 剛剛成功領取
相關推薦HOT
精品精品国产高清A毛片| 国模GOGO无码人体啪啪| 国产又粗又黄又爽的大片| 久久成人国产精品免费软件| 奶头被几个流浪汉吃肿了| 人妻有码中文字幕在线| 无码日韩人妻AV一区免费| 亚洲色大情网站WWW| 99麻豆久久久国产精品免费| 国产超碰人人爽人人做| 黑人巨鞭大战丰满少妇| 民工把我奶头掏出来了怎么办| 日本熟妇啪啪日本丰满熟妇啪啪日| 五十路熟妇无码AV在线| 在公交车上弄到高C了怎么办| 宝贝腿抬高点让我爽一点麻豆 | 老师你的兔子好软水好多小时| 人喾交性专区免费看| 亚欧成人无码AV在线播放| 在镜子面前看我是怎么爱你的| 挡粉嫩小泬久久久久久久| 精品人妻人人做人人爽夜夜爽| 欧美国产成人久久精品| 先锋中文字幕在线资源| 中文字幕久久精品无码| 国产成人精欧美精品视频| 久久精品香蕉绿巨人登场| 日本熟妇JAPANESE丰满| 亚洲美女高潮久久久久| 边做奶水边喷H高H共妻| 精品国产一区二区三区麻豆| 人妻少妇精品无码系列| 亚洲国产精品尤物YW在线观看 | 妺妺窝人销魂体色www| 无码人妻AⅤ一区二区三区水密桃 无码人妻AⅤ一区二区三区蜜桃 | 亚洲AV性色精品国产小电影| 99久久免费国产精品四虎99久久精品免费看国产一区二区 | 国产成人午夜无码电影在线观看| 久久久久久亚洲综合影院| 肉欲扒灰合集100篇| 亚洲愉拍自拍欧美精品APP| 赤裸人妻撅起肥白大屁股| 久久久久久A亚洲欧洲AⅤ| 熟妇高潮一区二区在线播放| 在线精品国产一区二区三区| 国产成人亚洲精品无码高潮| 免费女同毛片在线播放| 亚洲AV乱码一区二区三区在线观看| 99久久亚洲精品无码毛片| 黑人av巨大粗吊| 日韩午夜福利无码专区A| 一区二区三区无码免费看| 国产JIZZJIZZ全部免费看| 免费全部高H视频无码| 亚洲AV无码成人精品区毛片| 成人免费午夜无码视频| 老妇高潮潮喷到猛进猛出| 铜铜铜铜铜铜铜铜铜好大好深色| 91人妻一区二区三区蜜桃精品| 好爽…又高潮了毛片喷水| 色欲AV自慰一区二区三区| 2019NV天堂香蕉在线观看| 精品成人一区二区三区四区| 天美传媒蜜桃传媒精东豆| AⅤ日本亚洲欧洲免费| 久久精晶国产99久久6| 无码中文亚洲AV影音先锋无码 | 国产山东熟女48嗷嗷叫| 日本真人边吃奶边做爽动态图| 又大又黄又粗又爽的免费视频| 国产欧美在线观看不卡| 日本三级香港三级人妇99| 中文乱码在线中文字幕中文乱码| 国语做受对白XXXXX在线| 少妇被粗大猛进进出Va| 9612黄桃网站进入页面直播| 久久se精品一区二区| 小鲜肉洗澡时自慰网站XNXX| 成人AV天堂一二三在线观看| 免费女人18毛片A毛片视频| 亚洲无线码高清在线观看| 国产亚洲精品自在久久蜜TV| 色欲AV永久无码精品无码蜜桃| CHINESE玩弄老年熟女| 老汉吸奶水捏奶头小说| 亚洲欧美日韩愉拍自拍| 国产在线精品99一区不卡| 天天躁日日躁AAAAXXXX| 厨房里的激战2类型| 欧美性爱小说网站| 中文字幕无码乱人伦| 久久久精品无码中文天美| 亚洲成AV人片在线播放无码| 国产精品亚洲欧美大片在线观看| 色8激情欧美成人久久综合电影| BBW下身丰满18XXXX| 蜜臀AV无码人妻精品| 伊人精品久久久久7777| 久久WWW免费人成一看片| 亚洲成AV人片在线观看无下载| 国产精品泄火熟女| 玩弄肥美高大的熟妇| 国产AⅤ无码一区二区三区| 日本一卡二卡三卡四卡2021| ZLJZLJZLJZLJ亚洲| 欧美性XXXX极品少妇| AV无码天堂一区二区三区| 免费无码又爽又刺激高潮软件 | 尤物爆乳AV导航| 久久青青草原精品国产APP| 亚洲性日韩精品一区二区三区| 护士高潮喷水白浆| 亚洲国产成人综合精品| 记忆女神的女儿们| 亚洲国产精品久久久久秋霞影院| 国内精品久久久久久不卡影院 | 国产在线精品一区二区三区 | YY8090理论三级在线观看| 强插女教师AV在线| 八戒电影电影网电影网| 日本动漫爆乳H动漫无遮挡| 被滋润的少妇疯狂呻吟| 日本适合18岁以上的护肤品| 成人欧美激情亚洲日韩蜜臀 | 欧美激情视频一区二区三区免费| 中文字幕AV无码不卡免费| 内射射满骚B含着小说| Chinese老熟女老女人HD| 人妻无码一区二区三区久| 成人无码H免费动漫在线观看| 三级无码在钱AV无码在钱| 国产成人精品日本亚洲专区不卡 | 久久久精品国产SM调教网站| 野花视频最新免费完整版在线观看 | 欧美VA久久久噜噜噜久久| JAVA强行VIDEOS| 日韩人妻无码免费视频一区二区三| 二虎进入温如玉160章小说| 头埋入双腿之间被吸到高潮| 国产三级农村妇女在线| 亚洲国产欧美在线成人| 久久婷婷五月国产色综合| 18禁黄网站禁片免费观看香港| 欧美日韩一区二区综合| 厨房里的激战2类型| 无人高清影视在线观看| 精品高朝久久久久9999| 在办公室被C到呻吟的动态图| 欧美成人少妇人妻精品视频| 成年免费手机毛片免费看无码 | 国产AV无码日韩AV无码网站| 西方37大但人文艺术A管77| 精品久久人人妻人人做精品| 一区二区不卡AV免费观看| 欧美精品亚洲精品日韩专区VA | 7777色情ⅩXXX欧美色妇| 日本熟妇乱人伦XXXX| 国产毛片一区二区精品| 亚洲色偷偷综合亚洲AV伊人| 农里粗汉的共妻嗯啊高H| 大象成品W灬源码1| 亚洲AV成人一区二区三区在线观| 久久久久99精品成人片直播| AV无码中出一区二区三区| 私人IMAX情侣影院家庭影院| 黑人异族XXXⅩ吊大| 综合无码一区二区三区| 色欲香天天天综合网站小说| 好男人在线视频神马影视WWW| 中国极品少妇XXXXX1314| 日产2021免费一二三四区| 国产又粗又猛又爽又黄的视频在线 | 中国高清WINDOWS视频软件| 日本无码视频精品一二三区| 国产午夜无码福利在线看网站| 野花影视免费观看高清| 日本毛多水多做受视频| 国内精品视频在线观看九九| 中文字幕熟妇人妻在线视频| 色一情一乱一伦一区二区三区| 狠狠色丁香久久婷婷综合五月| 在公车上拨开内裤进入毛片| 色噜噜噜亚洲男人的天堂| 精品国色天香一卡2卡3卡| CHⅠNESE性旺盛老熟女| 无码精品人妻一区二区三区网站 | CHINESE老太性视频BBW| 无人区码一码二码三码| 美女把尿口扒开让男人桶| 国产VA免费精品观看精品| 一本一本大道香蕉久在线精品| 日韩人妻中文字幕| 久久精品国产久精国产果冻传媒| WWW一区二区WWW免费| 亚洲成AV人片在线观看无线| 欧美最猛性XXX| 经典精品毛片免费观看| ZOZ○ZO女人和另类ZOZ0| 亚洲AV之男人的天堂| 人妻少妇精品久久久久久|