NAME
       Net::Tomcat - A Perl API for monitoring Apache Tomcat.

VERSION
       Version 0.01

SYNOPSIS
       Net::Tomcat is a Perl API for monitoring Apache Tomcat instances.

               use Net::Tomcat;

               # Create a new Net::Tomcat object
               my $tc = Net::Tomcat->new(
                                       username => 'admin',
                                       password => 'password',
                                       hostname => 'web-server-01.company.com'
                                     )
                       or die "Unable to create new Net::Tomcat object: $!\n";

               # Print the Tomcat server version and JVM version information
               print "Tomcat version: " . $tc->server->version . "\n"
                   . "JVM version: " . $tc->server->jvm_version . "\n";

               # Get all connectors as an array of Net::Tomcat::Connector objects
               my @connectors = $tc->connectors;

               # Print the connector names, and request and error counts
               foreach my $connector ( @connectors ) {
                       print "Name: " . $connector->name . "\n"
                           . "Request Count: ".$connector->request_count . "\n"
                           . "Error Count: ".$connector->error_count . "\n\n"
               }

               # Directly access a connector by name
               print "http-8080 error count: "
                       . $tc->connector('http-8080')->stats->error_count . "\n";

               # Retrieve a Net::Tomcat::Connector::Scoreboard object
               # representing the request scoreboard of the connector.
               my $scoreboard = $tc->connector('http-8080')->scoreboard;

               # Get all threads in a servicing state as
               # Net::Tomcat::Connector::Scoreboard::Entry objects.
               my @threads = $scoreboard->threads_service;

METHODS
   new ( %ARGS )
       Constructor - creates a new Net::Tomcat object.  This method takes three mandatory parameters and accepts six optional
       parameters.

       username
          A valid username of a user account with access to the Tomcat management pages.

       password
          The password for the user account given for the username parameter above.

       hostname
          The resolvable hostname or IP address of the target Tomcat server.

       port
          The target port on the target Tomcat server on which to connect.

          If this parameter is not specified then it defaults to port 8080.

       proto
          The protocol to use when connecting to the target Tomcat server.

          If this parameter is not specified then it defaults to HTTP.

       app_status_url
          The relative URL of the Tomcat Web Application Manager web page.

          This parameter is optional and if not provided will default to a value of '/manager/html/list'.

          If this parameter is provided then it should be a relative URL in respect to the hostname parameter.

       server_status_url
          The relative URL of the Tomcat Web Server Status web page.

          This parameter is optional and if not provided will default to a value of '/manager/status/all'.

          If this parameter is provided then it should be a relative URL in respect to the hostname parameter.

       refresh_interval
          The interval in seconds after which any retrieved results should be regarded as invalid and discarded.  After this period has
          elapsed, subsequent requests for cached values will be issued to the Tomcat instance and the results will be cached for the
          duration of the refresh_interval period.

          Note that the refresh interval applies to all objects individually - that is; a Net::Tomcat::Connector object may have a
          different refresh interval than a Net::Tomcat::Connector::Scoreboard object.

          This parameter is optional and defaults to 3600s.  Caution shoudl be exercised when setting this parameter to avoid potential
          inconsistency in sequential calls to assumed immutable objects.

   connector ( $CONNECTOR )
               # Print connector error count.
               my $connector = $tc->connector( 'http-8080' );
               print "Connecter http-8080 error count: "
                       . $connector->stats->error_count . "\n";

               # Or
               printf( "Connector %s error count: %s\n",
                       $tc->connector('http-8080')->name,
                       $tc->connector('http-8080')->stats->error_count
               );

       Returns a Net::Tomcat::Connector object where the connector name is identified by the named $CONNECTOR parameter.

   connectors
       Returns an array of Net::Tomcat::Connector objects representing all connector instances on the server.

   server
       Returns a Net::Tomcat::Server object for the current instance.

   jvm
       Returns a Net::Tomcat::JVM object for the current instance.

AUTHOR
       Luke Poskitt, "<ltp at cpan.org>"

REPOSITORY
       <https://github.com/ltp/Net-Tomcat>

SEE ALSO
       Net::Tomcat::Server Net::Tomcat::Connector Net::Tomcat::Scoreboard

BUGS
       Please report any bugs or feature requests to "bug-net-tomcat at rt.cpan.org", or through the web interface at
       <http://rt.cpan.org/NoAuth/ReportBug.html?Queue=Net-Tomcat>.  I will be notified, and then you'll automatically be notified of
       progress on your bug as I make changes.

SUPPORT
       You can find documentation for this module with the perldoc command.

           perldoc Net::Tomcat

       You can also look for information at:

       ·   RT: CPAN's request tracker (report bugs here)

           <http://rt.cpan.org/NoAuth/Bugs.html?Dist=Net-Tomcat>

       ·   AnnoCPAN: Annotated CPAN documentation

           <http://annocpan.org/dist/Net-Tomcat>

       ·   CPAN Ratings

           <http://cpanratings.perl.org/d/Net-Tomcat>

       ·   Search CPAN

           <http://search.cpan.org/dist/Net-Tomcat/>

ACKNOWLEDGEMENTS
LICENSE AND COPYRIGHT
       Copyright 2015 Luke Poskitt.

       This program is free software; you can redistribute it and/or modify it under the terms of the the Artistic License (2.0). You
       may obtain a copy of the full license at:

       <http://www.perlfoundation.org/artistic_license_2_0>

       Any use, modification, and distribution of the Standard or Modified Versions is governed by this Artistic License. By using,
       modifying or distributing the Package, you accept this license. Do not use, modify, or distribute the Package, if you do not
       accept this license.

       If your Modified Version has been derived from a Modified Version made by someone other than you, you are nevertheless required
       to ensure that your Modified Version complies with the requirements of this license.

       This license does not grant you the right to use any trademark, service mark, tradename, or logo of the Copyright Holder.

       This license includes the non-exclusive, worldwide, free-of-charge patent license to make, have made, use, offer to sell, sell,
       import and otherwise transfer the Package with respect to any patent claims licensable by the Copyright Holder that are
       necessarily infringed by the Package. If you institute patent litigation (including a cross-claim or counterclaim) against any
       party alleging that the Package constitutes direct or contributory patent infringement, then this Artistic License to you shall
       terminate on the date that such litigation is filed.

       Disclaimer of Warranty: THE PACKAGE IS PROVIDED BY THE COPYRIGHT HOLDER AND CONTRIBUTORS "AS IS' AND WITHOUT ANY EXPRESS OR
       IMPLIED WARRANTIES.  THE IMPLIED WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, OR NON-INFRINGEMENT ARE
       DISCLAIMED TO THE EXTENT PERMITTED BY YOUR LOCAL LAW. UNLESS REQUIRED BY LAW, NO COPYRIGHT HOLDER OR CONTRIBUTOR WILL BE LIABLE
       FOR ANY DIRECT, INDIRECT, INCIDENTAL, OR CONSEQUENTIAL DAMAGES ARISING IN ANY WAY OUT OF THE USE OF THE PACKAGE, EVEN IF ADVISED
       OF THE POSSIBILITY OF SUCH DAMAGE.