linux不產生core檔案的解決方法:1、檢查Core dump的目錄是否存在並設定進程對該目錄有寫入權限;2、檢查服務程式是否呼叫seteuid();3、設定夠大的Core檔案大小限制;4、修改profile等等。
本文操作環境:linux5.9.8系統、Dell G3電腦。
linux不產生core檔案怎麼辦?為什麼沒有產生core 檔?
一、要確保存放Core dump的目錄存在且進程對該目錄有寫入權限。
存放Core dump的目錄即行程的目前目錄,一般就是當初發出指令啟動該行程時所在的目錄。但如果是透過腳本啟動,則腳本可能會修改目前目錄,而這時進程真正的目前目錄就會與當初執行腳本所在目錄不同。這時可以查看"/proc/270403847381cfabb8e6cf4eab88292a/cwd"符號連結的目標來決定進程真正的目前目錄位址。透過系統服務啟動的進程也可透過此方法查看。
二、若程式呼叫了seteuid()/setegid()改變了行程的有效使用者或群組,則在預設情況下系統不會為這些行程產生Core dump。
很多服務程式都會呼叫seteuid(),如MySQL,無論你用什麼使用者執行mysqld_safe啟動MySQL,mysqld進行的有效使用者總是msyql使用者。如果你當初是以用戶A運行了某個程序,但在ps裡看到的這個程式的用戶卻是B的話,那麼這些進程就是調用了seteuid了。為了能夠讓這些行程產生Coredump,需要(echo "1" > /proc/sys/kernel/suid_dumpable)。
三、這個一般都知道,就是要設定夠大的Core檔案大小限制了。
程式崩潰時產生的Core檔案大小即為程式執行時所佔用的記憶體大小。但程式崩潰時的行為不可按平常時的行為來估計,例如緩衝區溢位等錯誤可能導致堆疊被破壞,因此經常會出現某個變數的值被修改成亂七八糟的,然後程式用這個大小去申請內存就可能導致程式比平常多佔用很多記憶體。因此無論程式正常運行時佔用的記憶體多麼少,請確保產生Core檔案還是將大小限制設為unlimited為好。
四、在/etc/profile中新增:
ulimit -c unlimited > /dev/null 2?&1
五、一般在CLI 上啟動的程序,如果設定:
ulimit -c unlimited
就可以在程式以外終止時產生core dump 檔案。但是對於 daemon 方式運行的程序,其與 CLI 啟動的程序的主要區別是進程的運行環境,其中就包括
cwd(current working directory)。如果以相對路徑方式定義core 檔案的格式,例如定義/proc/sys/kernel/core_pattern 為:
core-%e-%p-%t
則一般來說,daemon 檔案的cwd 就是/,你可以透過/proc/6f26828356b84e110c413559c6a66e46/cwd來查看,通常是連接到/目錄。而如果使用者對這個目錄沒有寫權限,那就不會產生 core dump 檔案了。
最直接的解決的方法,是修改/proc/sys/kernel/core_pattern為絕對路徑:/data/coredump/core-%e-%p-%t
##並且保證這樣就基本OK 了。 修改/proc/sys/kernel/core_pattern檔案中的 core dump 檔案格式為絕對路徑,例如:/data/coredump/core-%e-%p-%t
何時不產生core檔案?
在下列條件下不產生core檔案:( a )進程是設定-使用者-ID,且目前使用者並非程式檔案的擁有者; #( b )進程是設定-群組-ID,且目前使用者並非該程式檔案的群組擁有者;( c )使用者沒有寫目前工作目錄的許可權;( d )文件太大。 core文件的許可權(假定該文件在此之前並不存在)通常是用戶讀/寫,組讀和其他讀。 推薦學習:《linux影片教學》
以上是linux不產生core檔案怎麼辦的詳細內容。更多資訊請關注PHP中文網其他相關文章!