Linux系統(tǒng)被入侵后使用lsof命令恢復(fù)被刪除日志的方法

Linux系統(tǒng)是服務(wù)器最常見(jiàn)的操作系統(tǒng),當(dāng)然也面臨著非常多的安全事件,相較Windows操作系統(tǒng),Linux采用了明確的訪問(wèn)權(quán)限控制和全面的管理工具,具有非常高的安全性和穩(wěn)定性。Linux系統(tǒng)被入侵后,攻擊者為了掩蓋蹤跡,經(jīng)常會(huì)清除系統(tǒng)中的各種日志,包括Web的access和error日志、last日志、message日志、secure日志等,給我們后期應(yīng)急響應(yīng)和取證分析帶來(lái)了非常大的阻力。所以,恢復(fù)被清除的日志是非常重要的取證和分析環(huán)節(jié),一下是使用lsof命令恢復(fù)日志文件的案例,適用于常見(jiàn)的日志恢復(fù)工作。
一、前提條件
不能關(guān)閉服務(wù)器,不能關(guān)閉相關(guān)服務(wù)或進(jìn)程,如恢復(fù)apache的訪問(wèn)日志 /var/log/httpd/access_log ,不能關(guān)閉或者重啟服務(wù)器系統(tǒng),也不能重啟httpd服務(wù)。
二、實(shí)施過(guò)程
1. 找到相關(guān)進(jìn)程pid
[root@localhost ~]# lsof | grep access_log
httpd 1392 root 7w REG 253,0 0 263802 /var/log/httpd/access_log
httpd 7330 apache 7w REG 253,0 0 263802 /var/log/httpd/access_log
httpd 7331 apache 7w REG 253,0 0 263802 /var/log/httpd/access_log
httpd 7332 apache 7w REG 253,0 0 263802 /var/log/httpd/access_log
httpd 7333 apache 7w REG 253,0 0 263802 /var/log/httpd/access_log
httpd 7334 apache 7w REG 253,0 0 263802 /var/log/httpd/access_log
httpd 7335 apache 7w REG 253,0 0 263802 /var/log/httpd/access_log
httpd 7336 apache 7w REG 253,0 0 263802 /var/log/httpd/access_log
httpd 7337 apache 7w REG 253,0 0 263802 /var/log/httpd/access_log
這里我們重點(diǎn)關(guān)注一下第一、第二、第三、第四列,分別表示進(jìn)程名、pid、用戶、文件描述符,我們看到這里的文件描述符是7w,所以我們?cè)谙乱徊讲僮鬟^(guò)程要記住這個(gè)7.
2. 找回日志
[root@localhost ~]# wc -l /proc/1392/fd/7
55 /proc/1392/fd/7
[root@localhost ~]# cat /proc/1392/fd/7 > /var/log/httpd/access_log
我們先通過(guò)wc或者tail命令查看日志信息,然后再將日志重寫(xiě)到access_log中即可。
三、總結(jié)
在Linux系統(tǒng)的/proc 分區(qū)下保存著進(jìn)程的目錄和名字,包含fd(文件描述符)和其下的子目錄(進(jìn)程打開(kāi)文件的鏈接),那么如果刪除了一個(gè)文件,還存在一個(gè) inode的引用:/proc/進(jìn)程號(hào)/fd/文件描述符。我們只要知道當(dāng)前打開(kāi)文件的進(jìn)程pid和文件描述符fd就能利用lsof工具列出進(jìn)程打開(kāi)的文件。通過(guò)lsof我們就可以進(jìn)行簡(jiǎn)單的文件恢復(fù)工作,當(dāng)然這里不局限于日志文件,只要是存在引用的文件。
相關(guān)文章
Fedora Linux 42 穩(wěn)定版發(fā)布: 帶來(lái)大量新功能和軟件更新
Fedora 42昨日發(fā)布,這是 Red Hat 贊助開(kāi)發(fā)的杰出前沿 Linux 發(fā)行版的最新版,包含大量新功能和軟件更新,使其成為 2025 年上半年發(fā)布的一款出色的 Linux 操作系統(tǒng)之一,內(nèi)2025-04-16如何在Linux查看硬盤(pán)信息? 查看Linux硬盤(pán)大小類型和硬件信息的5種方法
使用Linux系統(tǒng)的過(guò)程中,查看和了解硬盤(pán)信息是非常重要的工作,尤其是對(duì)于系統(tǒng)管理員而言,那么在Linux系統(tǒng)中如何查看硬盤(pán)信息?以下是具體內(nèi)容介紹2025-03-12如何在 Linux 中查看 CPU 詳細(xì)信息? 3招輕松查看CPU型號(hào)、核心數(shù)和溫度
在日常運(yùn)維工作中,獲取 CPU 信息是系統(tǒng)運(yùn)維管理員常見(jiàn)的工作內(nèi)容,無(wú)論是為了性能調(diào)優(yōu)、硬件升級(jí)還是僅僅滿足好奇心2025-03-11什么是 Arch Linux? 獨(dú)樹(shù)一幟的Arch Linux發(fā)行版分析
Arch Linux是為簡(jiǎn)化,優(yōu)化,現(xiàn)代化,實(shí)用主義,用戶中心和多功能性而創(chuàng)建Linux發(fā)行版,究竟是什么讓 Arch 與眾不同?下面我們就來(lái)簡(jiǎn)要解讀2025-02-19如何在Linux環(huán)境下制作 Win11裝機(jī)U盤(pán)?
一直用的linux辦公,想要將筆記本電腦從 Linux 系統(tǒng)切換回 Windows 11,我們可以制作一個(gè)win11裝機(jī)u盤(pán),詳細(xì)如下2025-02-17Rsnapshot怎么用? 基于Rsync的強(qiáng)大Linux備份工具使用指南
Rsnapshot 不僅可以備份本地文件,還能通過(guò) SSH 備份遠(yuǎn)程文件,接下來(lái)詳細(xì)介紹如何安裝、配置和使用 Rsnapshot,包括創(chuàng)建每小時(shí)、每天、每周和每月的本地備份,以及如何進(jìn)2025-02-06Linux Kernel 6.13發(fā)布:附更新內(nèi)容及新特性解讀
Linux 內(nèi)核 6.13 正式發(fā)布,新版本引入了惰性搶占支持,簡(jiǎn)化內(nèi)核搶占邏輯,通過(guò)減少與調(diào)度器相關(guān)的調(diào)用次數(shù),讓內(nèi)核在運(yùn)行時(shí)表現(xiàn)更優(yōu),從而提高效率2025-01-23五大特性引領(lǐng)創(chuàng)新! 深度操作系統(tǒng) deepin 25 Preview預(yù)覽版發(fā)布
今日,深度操作系統(tǒng)正式推出deepin 25 Preview版本,該版本集成了五大核心特性:磐石系統(tǒng)、全新DDE、Treeland窗口合成器、AI For OS以及Distrobox子系統(tǒng)2025-01-18Linux Mint Xia 22.1重磅發(fā)布: 重要更新一覽
Beta 版 Linux Mint“Xia” 22.1 發(fā)布,新版本基于 Ubuntu 24.04,內(nèi)核版本為 Linux 6.8,這次更新帶來(lái)了諸多優(yōu)化和改進(jìn),進(jìn)一步鞏固了 Mint 在 Linux 桌面操作系統(tǒng)領(lǐng)域的2025-01-16LinuxMint怎么安裝? Linux Mint22下載安裝圖文教程
Linux Mint22發(fā)布以后,有很多新功能,很多朋友想要下載并安裝,該怎么操作呢?下面我們就來(lái)看看詳細(xì)安裝指南2025-01-16