linux不產生core檔案的解決方法:1、檢查Core dump的目錄是否存在並設定進程對該目錄有寫入權限;2、檢查服務程式是否呼叫seteuid();3、設定夠大的Core檔案大小限制;4、修改profile等等。
本文操作環境:linux5.9.8系統、Dell G3電腦。
linux不產生core檔案怎麼辦?為什麼沒有產生core 檔?
一、要確保存放Core dump的目錄存在且進程對該目錄有寫入權限。
存放Core dump的目錄即行程的目前目錄,一般就是當初發出指令啟動該行程時所在的目錄。但如果是透過腳本啟動,則腳本可能會修改目前目錄,而這時進程真正的目前目錄就會與當初執行腳本所在目錄不同。這時可以查看"/proc//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//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中文網其他相關文章!

Linux系統的五大支柱是:1.內核,2.系統庫,3.Shell,4.文件系統,5.系統工具。內核管理硬件資源並提供基本服務;系統庫為應用程序提供預編譯函數;Shell是用戶與系統交互的接口;文件系統組織和存儲數據;系統工具用於系統管理和維護。

在Linux系統中,可以通過在啟動時按特定鍵或使用命令如“sudosystemctlrescue”進入維護模式。維護模式允許管理員在不受干擾的情況下進行系統維護和故障排除,如修復文件系統、重置密碼、修補安全漏洞等。

Linux初學者應掌握文件管理、用戶管理和網絡配置等基本操作。 1)文件管理:使用mkdir、touch、ls、rm、mv、cp命令。 2)用戶管理:使用useradd、passwd、userdel、usermod命令。 3)網絡配置:使用ifconfig、echo、ufw命令。這些操作是Linux系統管理的基礎,熟練掌握它們可以有效管理系統。

本文解釋瞭如何管理Linux中的Sudo特權,包括授予,撤銷和安全性最佳實踐。關鍵重點是安全和sudoers安全和限制訪問。Character數量:159

本文提供了有關使用Google Authenticator在Linux上設置兩因素身份驗證(2FA)的指南,詳細介紹了安裝,配置和故障排除步驟。它突出了2FA的安全益處,例如增強的SEC

本文討論了使用TOP,HTOP和VMSTAT監視Linux系統性能,並詳細介紹其獨特功能和自定義選項,以進行有效的系統管理。

文章討論了使用APT,YUM和DNF在Linux中管理軟件包,涵蓋安裝,更新和刪除。它比較了它們對不同分佈的功能和適用性。

本文介紹瞭如何在Linux中使用正則表達式(REGEX)進行模式匹配,文件搜索和文本操作,詳細列式,命令和工具,例如GREP,SED和AWK。


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

Atom編輯器mac版下載
最受歡迎的的開源編輯器

SAP NetWeaver Server Adapter for Eclipse
將Eclipse與SAP NetWeaver應用伺服器整合。

禪工作室 13.0.1
強大的PHP整合開發環境

VSCode Windows 64位元 下載
微軟推出的免費、功能強大的一款IDE編輯器

ZendStudio 13.5.1 Mac
強大的PHP整合開發環境