Linux利用lsof命令恢复删除的文件

lsof命令

lsof命令用于查看你进程开打的文件,打开文件的进程,进程打开的端口(TCP、UDP)。找回/恢复删除的文件。是十分方便的系统监视工具,因为lsof命令需要访问核心内存和各种文件,所以需要root用户执行。

在linux环境下,任何事物都以文件的形式存在,通过文件不仅仅可以访问常规数据,还可以访问网络连接和硬件。所以如传输控制协议 (TCP) 和用户数据报协议 (UDP) 套接字等,系统在后台都为该应用程序分配了一个文件描述符,无论这个文件的本质如何,该文件描述符为应用程序与基础操作系统之间的交互提供了通用接口。因为应用程序打开文件的描述符列表提供了大量关于这个应用程序本身的信息,因此通过lsof工具能够查看这个列表对系统监测以及排错将是很有帮助的。

语法

lsof(选项)

参数

-a:列出打开文件存在的进程;

-c<进程名>:列出指定进程所打开的文件;

-g:列出GID号进程详情;

-d<文件号>:列出占用该文件号的进程;

+d<目录>:列出目录下被打开的文件;

+D<目录>:递归列出目录下被打开的文件;

-n<目录>:列出使用NFS的文件;

-i<条件>:列出符合条件的进程。(4、6、协议、:端口、 @ip )

-p<进程号>:列出指定进程号所打开的文件;

-u:列出UID号进程详情;

-h:显示帮助信息;

-v:显示版本信息。

使用

查看

lsof -i:(端口) 查看这个端口有那些进程在访问,比如22端口


  1. shell> lsof -i:22 
  2. COMMAND   PID USER   FD   TYPE DEVICE SIZE/OFF NODE NAME 
  3. sshd     1939 root    3u  IPv4  12317      0t0  TCP *:ssh (LISTEN) 
  4. sshd     1939 root    4u  IPv6  12321      0t0  TCP *:ssh (LISTEN) 
  5. sshd     2790 root    3u  IPv4  15229      0t0  TCP 192.168.178.128:ssh->192.168.178.1:64601 (ESTABLISHED) 
  6. sshd     2824 root    3u  IPv4  15528      0t0  TCP 192.168.178.128:ssh->192.168.178.1:64673 (ESTABLISHED) 
  7. sshd     2990 root    3u  IPv4  15984      0t0  TCP 192.168.178.128:ssh->192.168.178.1:64686 (ESTABLISHED) 
  8. sshd    14695 root    3u  IPv4  39558      0t0  TCP 192.168.178.128:ssh->192.168.178.1:49662 (ESTABLISHED) 

lsof输出各列信息的意义如下:

  • COMMAND:进程的名称
  • PID:进程标识符
  • USER:进程所有者
  • FD:文件描述符,应用程序通过文件描述符识别该文件。如cwd、txt等
  • TYPE:文件类型,如DIR、REG等
  • DEVICE:指定磁盘的名称
  • SIZE:文件的大小
  • NODE:索引节点(文件在磁盘上的标识)
  • NAME:打开文件的确切名称

恢复文件

利用lsof可以恢复一些系统日志,前提是这个进程必须存在。这里就拿最常用的/var/log/messages来举例说明,大家在做测试的时候最好先备份一下。


  1. #备份shell> cp /var/log/message /var/log/message_bac 
  2. http://embeddedlinux.org.cn/ 
  3. shell> lsof |grep /var/log/message 
  4. rsyslogd   1737      root    1w      REG                8,2   5716123     652638 /var/log/messages 

进程在运行中,接下来我就把/var/log/messages这个文件删掉


  1. shell> rm /var/log/messages 

删掉之后,我再来看看这个进程的变化


  1. shell> lsof |grep /var/log/messages 
  2. rsyslogd   1737      root    1w      REG                8,2   5716123     652638 /var/log/messages (deleted) 

大家看到有变化了吧, 对比两个之后发现多了(deleted)。要找到这个文件在哪还要看看这个

PID:1737 FD:1 那我们有直接进入/proc/1737/FD/1用ll查看一下


  1. shell> cd /proc/1737/fd/ 
  2. shell> ll 
  3.  
  4. total 0 
  5. lrwx------ 1 root root 64 Dec 23 13:00 0 -> socket:[11442] 
  6. l-wx------ 1 root root 64 Dec 23 13:00 1 -> /var/log/messages (deleted) 
  7. l-wx------ 1 root root 64 Dec 23 13:00 2 -> /var/log/secure 
  8. lr-x------ 1 root root 64 Dec 23 13:00 3 -> /proc/kmsg 
  9. l-wx------ 1 root root 64 Dec 23 13:00 4 -> /var/log/maillog 

看到了1对应/var/log/messages (deleted),看看文件是不是我们要的文件:


  1. shell> head -5 1 
  2. Nov 14 03:11:11 localhost kernel: imklog 5.8.10, log source = /proc/kmsg started. 
  3. Nov 14 03:11:11 localhost rsyslogd: [origin software="rsyslogd" swVersion="5.8.10" x-pid="1241" x-info="http://www.rsyslog.com"] start 
  4. Nov 14 03:11:11 localhost kernel: Initializing cgroup subsys cpuset 
  5. Nov 14 03:11:11 localhost kernel: Initializing cgroup subsys cpu 
  6. Nov 14 03:11:11 localhost kernel: Linux version 2.6.32-431.el6.x86_64 (mockbuild@c6b8.bsys.dev.CentOS.org) (gcc version 4.4.7 20120313 (Red Hat 4.4.7-4) (GCC) ) #1 SMP Fri Nov 22 03:15:09 UTC 2013 

对比备份文件:


  1. shell> head -5 /var/log/message_bac 
  2. Nov 14 03:11:11 localhost kernel: imklog 5.8.10, log source = /proc/kmsg started. 
  3. Nov 14 03:11:11 localhost rsyslogd: [origin software="rsyslogd" swVersion="5.8.10" x-pid="1241" x-info="http://www.rsyslog.com"] start 
  4. Nov 14 03:11:11 localhost kernel: Initializing cgroup subsys cpuset 
  5. Nov 14 03:11:11 localhost kernel: Initializing cgroup subsys cpu 
  6. Nov 14 03:11:11 localhost kernel: Linux version 2.6.32-431.el6.x86_64 (mockbuild@c6b8.bsys.dev.centos.org) (gcc version 4.4.7 20120313 (Red Hat 4.4.7-4) (GCC) ) #1 SMP Fri Nov 22 03:15:09 UTC 2013 

对比发现数据是一样的,恢复


  1. shell> cat 1 > /var/log/messages 

再次提醒,恢复前提是这个进程必须存在。

本文作者:佚名

来源:51CTO

时间: 2024-11-08 23:31:30

Linux利用lsof命令恢复删除的文件的相关文章

asp.net 选择excel类型文件,利用Dos命令成批复制文件_实用技巧

1.选择excel类型文件 复制代码 代码如下: OpenFileDialog fileDialog = new OpenFileDialog(); // fileDialog.InitialDirectory = "d:\\"; fileDialog.Title = "选择文件"; //fileDialog.Filter = "xml files (*.xml)|*.xml"; fileDialog.Filter = "Excel文件

Linux利用nc命令监控服务器端口的方法_Linux

最近碰到一个项目,前端用apache htttpd进行发布(80端口),通过双机负载均衡转发到后端的两个tomcat进行处理(8081和8082端口),现在需要随时监控这三个端口的情况,一旦down掉需要能够立即告警处理.批量的系统监控比较好的是用nagios软件来实现,这样小项目专门装一个nagios软件,有点繁琐了.在网上查了一些资料,总结实验了一下,可以用简单的nc命令来实现. 一.nc命令检测端口的用法# nc  -v  -w 10 %IP%   -z  %PORT%-v  显示指令执行

Linux之lsof命令

lsof命令简介: lsof(list open files)是一个列出当前系统打开文件的工具.在Linux环境下,任何事物都以文件的形式存在,通过文件不仅仅可以访问常规数据,还可以访问网络连接和硬件.所以,lsof的功能很强大.一般root用户才能执行lsof命令,普通用户可以看见/usr/sbin/lsof命令,但是普通用户执行会显示"permission denied".因此通过lsof工具能够查看这个列表对系统监测以及排错将是很有帮助的.   在终端下输入lsof即可显示系统打

linux中lsof命令的用法

Lsof是遵从Unix哲学的典范,它只做一件事情,并且做的相当完美.以列出某个进程打开的所有文件信息.打开的文件可能是普通的文件,目录,NFS文件,块文件,字符文件,共享库,常规管道,符号链接,Socket流,网络Socket,UNIX域Socket,以及其它. 在UNIX环境中,文件无处不在,这便产生了一句格言:"任何事物都是文件".通过文件不仅仅可以访问常规数据,通常还可以访问网络连接和硬件.在有些情况下,当您使用ls 请求目录清单时,将出现相应的条目.在其他情况下,如传输控制协议

linux中lsof命令详解

lsof在linux中是一个很重要的命令,这里简单记录一下. 简介 lsof(list open files)是一个列出当前系统打开文件的工具.在linux环境下,任何事物都以文件的形式存在,通过文件不仅仅可以访问常规数据,还可以访问网络连接和硬件.所以如传输控制协议 (TCP) 和用户数据报协议 (UDP) 套接字等,系统在后台都为该应用程序分配了一个文件描述符,无论这个文件的本质如何,该文件描述符为应用程序与基础操作系统之间的交互提供了通用接口.因为应用程序打开文件的描述符列表提供了大量关于

利用DIR命令批量输出文件夹名或文件名的代码_DOS/BAT

操作办法:1.新建记事本,对照"新建文件夹"手工输入:                      2.新建记事本,F2"A1",Ctrl+C,Ctrl+V:F2"A7",Ctrl+C,Ctrl+V:~~F2"A5000",Ctrl+C,Ctrl+V.一个一个地复制文件名:                      3.打开命令提示行,进入"新建文件夹"目录,输入"DIR /B >1.txt

利用xcopy命令实现本地文件复制到远程服务器的方法_DOS/BAT

A.net use \\IP地址 密码/user:****** B.xcopy 文件 \\IP地址\ 批处理文件为backup.bat,其代码如下: ========================================================================================= net use \\192.168.1.198\ipc$ Zqf198703 /user:royalpeak xcopy g:\backup\*.* \\192.168.

Linux中scp命令获取远程文件的方法_linux shell

一.scp是什么? scp是secure copy的简写,用于在Linux下进行远程拷贝文件的命令,和它类似的命令有cp,不过cp只是在本机进行拷贝不能跨服务器,而且scp传输是加密的,可能会稍微影响一下速度. 二.scp有什么用? 1.我们需要获得远程服务器上的某个文件,远程服务器既没有配置ftp服务器,没有开启web服务器,也没有做共享,无法通过常规途径获得文件时,只需要通过scp命令便可轻松的达到目的: 2.我们需要将本机上的文件上传到远程服务器上,远程服务器没有开启ftp服务器或共享,无

linux中lsof命令介绍及用法

因为应用程序打开文件的描述符列表提供了大量关于这个应用程序本身的信息,因此通过lsof工具能够查看这个列表对系统监测以及排错将是很有帮助的. Linux下一切皆文件,lsof(lists openfiles)是一个列出当前系统打开文件的工具.文件可以是: 普通文件 目录 网络文件系统的文件 字符或设备文件 (函数)共享库 管道,命名管道 符号链接 网络文件(例如:NFS file.网络socket,unix域名socket) 还有其它类型的文件,等等 lsof常见参数如下: -a 列出打开文件存