記一次由openjdk導(dǎo)致的poi錯(cuò)誤(easyexcel)

項(xiàng)目中嘗試使用了easyexcel替換了原生poi。測(cè)試時(shí)線下沒啥問題,放到服務(wù)器里導(dǎo)出的文件就被損壞。

由于這篇記錄是后補(bǔ)的,所以沒有報(bào)錯(cuò)截圖。
大致的錯(cuò)誤是:缺少字體樣式文件導(dǎo)致的null報(bào)錯(cuò),而字體樣式是jdk自帶的。

我自己檢測(cè)了代碼沒發(fā)現(xiàn)什么問題。最后和同事一起在服務(wù)器的log中發(fā)現(xiàn)了一個(gè)null報(bào)錯(cuò)。然后查看了整個(gè)項(xiàng)目的部署流程,終于發(fā)現(xiàn)問題。

因?yàn)榫€上運(yùn)維環(huán)境已換成了k8s集群部署,所有的前后端都需要打成docker鏡像,在pod里跑。我查看了api鏡像打包的dockerfile文件,然后看到了這一行:

FROM openjdk:8-jdk-alpine

臥槽,什么情況?啥時(shí)候換openjdk了?咋沒人通知?

openjdk具體是啥?
這么說吧,openjdk與jdk的區(qū)別。openjdk開源、免費(fèi)、只包含了最精簡(jiǎn)的JDK。通常由于產(chǎn)權(quán),openjdk中大多數(shù)關(guān)于SUN JDK的源碼被替換了。所以easyexcel或者說poi中使用到的JDK字體文件就會(huì)報(bào)null異常。

更詳細(xì)的請(qǐng)百度。

解決方法:

我們采用的方法是,把運(yùn)維人員拖出來打一頓,然后dockerfile里把openjdk換了:

oracle-serverjre:8

說到底還是經(jīng)驗(yàn)不足,其實(shí)早點(diǎn)在前端把導(dǎo)出的log打出來就發(fā)現(xiàn)錯(cuò)誤了。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容