NAME

plackbench - Benchmarking/Debugging tool for Plack web requests

SYNOPSIS

# Make a request 5 times, and print some stats
$ plackbench -n 5 /path/to/app.psgi '/search?q=stuff'

# Debug the same request
$ PERL5OPT=-d plackbench -n 5 /path/to/app.psgi '/search?q=stuff'

# Profile the same request
$ PERL5OPT=-d:NYTProf plackbench -n 5 /path/to/app.psgi '/search?q=stuff'
$ nytprofhtml -m

DESCRIPTION

This script benchmarks a web request. It hits the Plack app directly without going through a web server.

This is somewhat useful on it's own for getting an idea of the time spent in Perl-land for a web request. But it's mostly a harness for a debugger or profiler.

USAGE

plackbench /path/to/app.psgi URI

The first positional argument is the path to a .psgi file. The second is the URL to request.

The URI is relative to the application root.

OPTIONS

-n

Number of times to execute the request. Defaults to 1.

--warm

Make an initial request that won't be included in the stats.

--post=<file>

Make a POST request instead of a GET. Pass the path to a file with the raw URL-encoded POST data. If the file contains multiple lines, each will be used a separate POST request.

If the file is a '-', the POST body will be read from STDIN.

-e <code>

Pre-process the request using the Perl code passed. $_ will be set to a HTTP::Request object.

For example, to set the User-Agent:

plackbench -e '$_->header("User-Agent" => "Mozilla")' /path/to/app.psgi /
-f <file>

Like -e, however the code is read from a file. Should return a code reference, which will be passed a HTTP::Request object.

A simple example:

sub {
    my $request = shift;
    $request->header( Cookie => 'session=mysid' );
    return;
}

The file can contain any valid Perl code, but the last statement in the file must be a subroutine reference.

Using with Devel::NYTProf

Just invoking the script through NYTProf is all that's necessary:

PERL5OPT=-d:NYTProf plackbench /path/to/app.psgi '/search?q=stuff'

In some applications, startup costs can overshadow the actual request in the report. If this happens prevent NYTProf from starting by default:

NYTPROF=start=no PERL5OPT=-d:NYTPRof plackbench /path/to/app.psgi '/search?q=stuff'

The script will call DB::enable_profile() to start NYTProf before executing any requests. Which removes the startup code from the final report.

If the --warm flag is used, DB::enable_profile() will be called after the initial request.

See Devel::NYTProf for more information.