在項目中使用 JavaMail 作為郵件核心庫,但是一直遇到一個比較頭疼的問題,當郵件中存在附件時,此封郵件加載速度很慢,最高時之后 80k/s.
通過 log 打印看出,當獲取附件時,獲取一段之后等待一段時間在獲取另一端.導致 io 開銷過大,等待網絡讀取時間過長.
相關日志如下:
O24 FETCH 276 (BODY[1.2]<229376.16384>)
276 FETCH (BODY[1.2]<229376> {16384}
O24 OK Fetch completed
O25 FETCH 276 (BODY[1.2]<245760.16384>)
276 FETCH (BODY[1.2]<245760> {16384}
O25 OK Fetch completed
根據此現象大概能夠判斷到問題就是分段下載導致的.經過一番苦苦查找.功夫不負有心人,在JavaMail API 的文檔的 imap 下面中找到這么一個配置
mail.imap.partialfetch boolean Controls whether the IMAP partial-fetch capability should be used. Defaults to true.
說是否開啟 IMAP 的分段加載功能,并且默認是開啟的.
在 Properties 中設置此配置為 false.
在進行打開此封郵件的 24M 附件,加載速度控制在了 30s 左右,對比之前的接近 30 分鐘,算是幾乎解決了這個問題.
這個配置只有在超大附件時效果及其明顯,附件在 100k,以下是效果幾乎不明顯.