=pod

=head1 SUMMARY

IPC::Locker provides a server for locks and a Perl package for clients to
access that server.  The result is that clients can access named locks on a
Internet wide basis, solving critical section problems without the mess of
NFS or other file locking techniques.

The latest version is available from CPAN and from
L<https://www.veripool.org/ipc-locker>.

=head1 EXAMPLE

  use IPC::Locker;
  # ...
  my $lock = IPC::Locker->lock(host=>'example.std.com');
  # ... Critical section ...
  $lock->unlock;

=head1 INSTALLATION

=head2 Build and Install the Package

=head3 Install from CPAN:

  cpan install IPC::Locker

=head3 Or, build from sources:

  # Obtain distribution kit
  git clone [email protected]:veripool/IPC-Locker.git
  # Build
  cd IPC-Locker
  git pull
  perl Makefile.PL
  make
  make test
  make install

=head2 Install the Daemons

You may wish to install C<lockerd> and C<pidstatd> in a init.rc file so
that it is run at system startup.  Depending on your distribution, you may
be able to just:

  cp init.d/lockerd   /etc/init.d/lockerd  # On one server only
  cp init.d/pidstatd  /etc/init.d/pidstatd  # On all machines

Edit paths in above to point to /usr/bin instead of /usr/local/bin, if needed.

  service lockerd start  # On one server only
  service pidstatd start  # On all machines
  chkconfig lockerd on  # On one server only
  chkconfig pidstatd on  # On all machines

If you get "This account is currently not available."  you need to change
the daemon account from a shell of /sbin/nologin to /sbin/bash.

=head2 Nagios

If you are using Nagios http://www.nagios.org, sample scripts to check the
daemons are included in the nagios subdirectory.

=head1 DOCUMENTATION

IPC::Locker provides the following programs/packages:

=head2 lockerd

C<lockerd> is the daemon that supports IPC::Locker. See C<man
lockerd> after installation.

=head2 IPC::PidStat

C<IPC::PidStat> is a Perl package which answers the question, "is pid X
running on host Y?".  See C<man IPC::PidStat> after installation.

=head2 pidstat

C<pidstat> is a program which answers the question, "is pid X running on
host Y?".  See C<man pidstat> after installation.

=head2 pidstatd

C<pidstat> is the daemon that supports C<IPC::PidStat> and C<pidstat>. See
C<man pidstatd> after installation.

=head2 pidwatch

C<pidwatch> is a program which starts other programs, and kill that program
when another job exists.  See C<man pidwatch> after installation.

=head2 uriexec

C<uriexec> is a simple wrapper which allows executing a command which is
quoted using URI escapes.  This prevents layered shells from interpreting
special characters.  See C<man uriexec> after installation.

=head2 check_lockerd and check_pidstatd

C<check_lockerd> and C<check_pidstatd> are Nagios plugins to check
C<lockerd> and C<pidstatd>.  See the Nagios documentation at
https://www.nagios.org for information on installing plugins.

=head1 LICENSE

This package is Copyright 1999-2019 by Wilson Snyder <[email protected]>.

This program is free software; you can redistribute it and/or modify it
under the terms of either the GNU Lesser General Public License Version 3
or the Perl Artistic License Version 2.0.  This code is provided with no
warranty of any kind, and is used entirely at your own risk.