Linux中使用lsof命令如何恢复删除的文件?

来源:互联网 发布:新浪网络猫耳宝贝 编辑:程序博客网 时间:2024/05/23 19:15

本文和大家分享的主要是linux操作系统中使用lsof命令恢复删除的文件相关知识,一起来看看吧,希望对大家有所帮助。

  lsof命令

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

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

  语法

  lsof(选项)

  参数

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

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

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

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

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

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

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

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

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

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

  -h:显示帮助信息;

  -v:显示版本信息。

  使用

  查看

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

shell> lsof -i:22

COMMAND   PID USER   FD   TYPE DEVICE SIZE/OFF NODE NAME

sshd     1939 root    3u  IPv4  12317      0t0  TCP *:ssh (LISTEN)

sshd     1939 root    4u  IPv6  12321      0t0  TCP *:ssh (LISTEN)

sshd     2790 root    3u  IPv4  15229      0t0  TCP 192.168.178.128:ssh->192.168.178.1:64601 (ESTABLISHED)

sshd     2824 root    3u  IPv4  15528      0t0  TCP 192.168.178.128:ssh->192.168.178.1:64673 (ESTABLISHED)

sshd     2990 root    3u  IPv4  15984      0t0  TCP 192.168.178.128:ssh->192.168.178.1:64686 (ESTABLISHED)

sshd    14695 root    3u  IPv4  39558      0t0  TCP 192.168.178.128:ssh->192.168.178.1:49662 (ESTABLISHED)

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

  · COMMAND:进程的名称

  · PID:进程标识符

  · USER:进程所有者

  · FD:文件描述符,应用程序通过文件描述符识别该文件。如cwdtxt

  · TYPE:文件类型,如DIRREG

  · DEVICE:指定磁盘的名称

  · SIZE:文件的大小

  · NODE:索引节点(文件在磁盘上的标识)

  · NAME:打开文件的确切名称

  恢复文件

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

  #备份shellcp /var/log/message /var/log/message_bac

  http://embeddedlinux.org.cnshell> lsof |grep /var/log/message

  rsyslogd 1737 root 1w REG 8,2 5716123 652638 /var/log/messages

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

  shell> rm /var/log/messages

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

  shell> lsof |grep /var/log/messages

  rsyslogd 1737 root 1w REG 8,2 5716123 652638 /var/log/messages (deleted)

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

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

  shellcd /proc/1737/fd/ shellll

  total 0

lrwx------ 1 root root 64 Dec 23 13:00 0 -> socket:[11442]

l-wx------ 1 root root 64 Dec 23 13:00 1 -> /var/log/messages (deleted)

l-wx------ 1 root root 64 Dec 23 13:00 2 -> /var/log/secure

lr-x------ 1 root root 64 Dec 23 13:00 3 -> /proc/kmsg

    l-wx------ 1 root root 64 Dec 23 13:00 4 -> /var/log/maillog

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

  shell> head -5 1

  Nov 14 03:11:11 localhost kernel: imklog 5.8.10, log source = /proc/kmsg started.

  Nov 14 03:11:11 localhost rsyslogd: [origin software="rsyslogd" swVersion="5.8.10" x-pid="1241" x-info="http://www.rsyslog.com"] start

  Nov 14 03:11:11 localhost kernel: Initializing cgroup subsys cpuset

  Nov 14 03:11:11 localhost kernel: Initializing cgroup subsys cpu

  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

  对比备份文件:

  shell> head -5 /var/log/message_bac

  Nov 14 03:11:11 localhost kernel: imklog 5.8.10, log source = /proc/kmsg started.

  Nov 14 03:11:11 localhost rsyslogd: [origin software="rsyslogd" swVersion="5.8.10" x-pid="1241" x-info="http://www.rsyslog.com"] start

  Nov 14 03:11:11 localhost kernel: Initializing cgroup subsys cpuset

  Nov 14 03:11:11 localhost kernel: Initializing cgroup subsys cpu

  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

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

  shellcat 1 > /var/log/messages

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

 

来源:51CTO

0 0
原创粉丝点击