NAME

Unix::Lsof - Wrapper to the Unix lsof utility

VERSION

This document describes Unix::Lsof version 0.0.1

SYNOPSIS

  use Unix::Lsof;
  my ($output,$error) = lsof("afile.txt");
  my @pids = keys %$output;
  my @commands = map { $_->{"command name"} } values %$output;

  ($output,$error) = lsof("-p",$$);
  my @filenames;
  for my $pid (keys %$output) {
      for my $files ( @{ $o->{$k}{files} } ) {
          push @filenames,$f->{"file name"}
      }
  }

 my $lr = lsof ("-p",$$); # see Unix::Lsof::Result
 @filenames = $lrs->get_filenames();
 @inodes = $lrs->get_values("inode number");

DESCRIPTION

This module is a wrapper around the Unix lsof utility (written by Victor A.Abell, Copyright Purdue University), which lists open files as well as information about the files and processes opening them. Unix::Lsof uses the lsof binary, so you need to have that installed in order to use this module (lsof can be obtained from ftp://lsof.itap.purdue.edu/pub/tools/unix/lsof).

By default, this module exports a single function lsof, to which you can pass the same parameters you would the lsof binary. When called in list context, lsof will return two values, a hash reference containing the parsed output of the lsof binary and a string containing (unparsed) any error messages. When called in scalar context, lsof will return a Unix::Lsof::Result object (see the documentation for that module for further details).

On request, you can also export the subroutine parse_lsof_output which will do what the name says and return the parsed output.

INTERFACE

Subroutines

lsof( [PARAMETERS] )

lsof accepts parameters passed on to the lsof binary. These need to be in list form, so you need to do

$r = lsof("-p",$pid,"-a","+D","/tmp");

NOT

$r = lsof("-p $pid -a +D /tmp");

SCALAR CONTEXT

Example:

$lr = lsof("afile");

When called in scalar context, lsof will return a Unix::Lsof::Result object. Please see the documentation for that module on how to use this object. I mean it, really, take a look there, you'll almost certainly want to use the Unix::Lsof::Result interface which gives you lots of helper methods to dig out exactly the information you want.

LIST CONTEXT

Example:

($output,$error) = lsof("afile");

When called in list context, lsof will return two values, a hash reference containing the parsed output of the lsof binary, and a string containing any error messages. The output data structure looks like this (approximating Data::Dumper formatting here:)

$output = {
            '<pid>' => {
                         '<process field name>' => '<value>',
                         '<process field name>' => '<value>',
                         'files' => [
                                      {
                                        '<file field name>' => '<value>',
                                        '<file field name>' => '<value>'
                                      },
                                      {
                                        '<file field name>' => '<value>',
                                        '<file field name>' => '<value>'
                                             ...
                                      },
                                    ]
                       }
               ...
          }

Each process id (pid) is the key to a hash reference that contains as keys the names of process set fields and their corresponding field value. The special files key has an array reference as value. Each element in this array is a hash reference that contains the names of file set fields and their values. See the section OUTPUT FOR OTHER PROGRAMS in the lsof manpage if you're wondering what process and file sets are.

Process field names are:

"command name"
"login name"
"process id"
"process group id"
"parent pid"
"user id"

File field names are:

"access mode"
"structure share count"
"device character code"
"major/minor device number"
"file descriptor"
"structure address"
"flags"
"inode number"
"link count"
"lock status"
"file name"
"node identifier"
"file offset"
"protocol name"
"raw device number"
"file size"
"stream module and device names"
"file type"
"tcp/tpi info"
"user id"
"zone name"
parse_lsof_output ( <STRING> )

This function takes the raw output as obtained from the lsof binary (with the -F0 option) and parses it into the data structure explained above. It does not understand the lsof STDERR output.

DIAGNOSTICS

Cannot find lsof program

Couldn't find the lsof binary which is required to use this module. Either install lsof or (if it's installed) be sure that it is in your shells path.

Can't parse line

Encountered a line of lsof output which could not be properly parsed. If you get this from calling lsof() it is almost certainly a bug, please let me know so I can fix it. If you encountered it from running parse_lsof_output, please make sure that the output was obtained from running lsof with the -F0 option.

CONFIGURATION AND ENVIRONMENT

Unix::Lsof requires no configuration files. It searches for the lsof binary in the directories listed in your $PATH environment variable.

DEPENDENCIES

Unix::Lsof requires the following modules:

  • version

  • IPC::Run3

INCOMPATIBILITIES

None reported.

BUGS AND LIMITATIONS

Please report any bugs or feature requests to bug-unix-lsof@rt.cpan.org, or through the web interface at http://rt.cpan.org/NoAuth/ReportBug.html?Queue=Unix-Lsof.

No bugs have been reported so far. There are a number of improvements that could be made to this module, particularly in the handling of parameters. Further development is almost certainly strictly "develop by bugreport", so if you want a feature added, please open a wishlist item in the RT web interface and let me know. I'm more than happy to do more work on this module, but want to see what concrete improvements people would like to have. As always, patches are more than welcome.

ACKNOWLEDGEMENTS

A very heartfelt thanks to Vic Abel for writing lsof, it has been invaluable to me over the years. Many thanks as always to http://www.perlmonks.org, the monks continue to amaze and enlighten me. A very special thanks to Damian Conway, who (amongst other things) recommends writing module documentation at the same time as code (in his excellent book "Perl Best Practices"). I didn't follow that advice and as a result writing these docs was more painful and error-prone than it should have been. Please Mr. Conway, for the next edition could you put more emphasis on that recommendation so that dolts like me get it the first time?

AUTHOR

Marc Beyer <japh@tirwhan.org>

LICENCE AND COPYRIGHT

Copyright (c) 2008, Marc Beyer <japh@tirwhan.org>. All rights reserved.

This module is free software; you can redistribute it and/or modify it under the same terms as Perl itself. See perlartistic.

DISCLAIMER OF WARRANTY

BECAUSE THIS SOFTWARE IS LICENSED FREE OF CHARGE, THERE IS NO WARRANTY FOR THE SOFTWARE, TO THE EXTENT PERMITTED BY APPLICABLE LAW. EXCEPT WHEN OTHERWISE STATED IN WRITING THE COPYRIGHT HOLDERS AND/OR OTHER PARTIES PROVIDE THE SOFTWARE "AS IS" WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE SOFTWARE IS WITH YOU. SHOULD THE SOFTWARE PROVE DEFECTIVE, YOU ASSUME THE COST OF ALL NECESSARY SERVICING, REPAIR, OR CORRECTION.

IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MAY MODIFY AND/OR REDISTRIBUTE THE SOFTWARE AS PERMITTED BY THE ABOVE LICENCE, BE LIABLE TO YOU FOR DAMAGES, INCLUDING ANY GENERAL, SPECIAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES ARISING OUT OF THE USE OR INABILITY TO USE THE SOFTWARE (INCLUDING BUT NOT LIMITED TO LOSS OF DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY YOU OR THIRD PARTIES OR A FAILURE OF THE SOFTWARE TO OPERATE WITH ANY OTHER SOFTWARE), EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES.