溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

如何解決File size limit exceeded錯(cuò)誤問(wèn)題

發(fā)布時(shí)間:2021-10-08 14:37:57 來(lái)源:億速云 閱讀:494 作者:小新 欄目:開(kāi)發(fā)技術(shù)

這篇文章將為大家詳細(xì)講解有關(guān)如何解決File size limit exceeded錯(cuò)誤問(wèn)題,小編覺(jué)得挺實(shí)用的,因此分享給大家做個(gè)參考,希望大家閱讀完這篇文章后可以有所收獲。

遇到一個(gè)問(wèn)題,使用Yii框架編寫(xiě)php腳本,將db中100多萬(wàn)的數(shù)據(jù)導(dǎo)出,運(yùn)行,成功。

但是在 運(yùn)行到第 49萬(wàn)條時(shí),腳本終止,提示錯(cuò)誤“File size limit exceeded”,遂google之,原來(lái)是某個(gè)文件大小超過(guò)系統(tǒng)限制。筆者第一反應(yīng),日志文件寫(xiě)滿了???趕忙查看 log,居然只有幾十K !!! 那么這個(gè) “大文件”在哪里呢?

開(kāi)始分析,不可能是Yii框架的問(wèn)題,此乃linux操作系統(tǒng)異常問(wèn)題與框架無(wú)光,也不是 日志文件大小,仔細(xì)查看了所有設(shè)置的log路徑下的文件,均小的可以忽略,即使是將Yii的debug關(guān)掉,也出現(xiàn)了相同的問(wèn)題。

那么換個(gè)思路,重新運(yùn)行腳本,再次運(yùn)行腳本,發(fā)現(xiàn) dead的時(shí)間很有規(guī)律,均是在45萬(wàn)條記錄時(shí)掛掉,一條不多一條不少,開(kāi)始懷疑與進(jìn)程有關(guān)。決定查看腳本進(jìn)程所影響到的io。

1、先獲取腳本進(jìn)程的 <pid>;

2、使用lsof命令查看此pid的io情況 : lsof -p <pid>

發(fā)現(xiàn)一個(gè)疑似文件 data0/xdebug/cachegrind.out.<pid>,隨著腳本的執(zhí)行,這個(gè)xdebug文件的大小也隨之增大,最后,如愿,掛掉!此時(shí)文件大小為:2147483647??!

哈哈,好熟悉的數(shù)字,2^31 -1 !!

看來(lái)問(wèn)題找到了,在腳本執(zhí)行時(shí),xdebug也隨之對(duì)這個(gè)腳本進(jìn)程進(jìn)行寫(xiě)記錄日志,當(dāng)此文件大小超出 系統(tǒng)所能支持的文件大小時(shí),如期掛掉。

ok, 將xdebug關(guān)掉,重跑腳本,一百多萬(wàn)的記錄順利跑完,搞定。

ps: 筆者所使用的服務(wù)器為32位系統(tǒng),而在32位操作系統(tǒng)中,由于是二進(jìn)制,其能最大存儲(chǔ)的數(shù)據(jù)是1111111111111111111111111111111。

正因?yàn)榇耍w現(xiàn)在其他可視系統(tǒng)中的十進(jìn)制就為2147483647。

關(guān)于“如何解決File size limit exceeded錯(cuò)誤問(wèn)題”這篇文章就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,使各位可以學(xué)到更多知識(shí),如果覺(jué)得文章不錯(cuò),請(qǐng)把它分享出去讓更多的人看到。

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI