NAME

HTTP::Server::Simple::PreFork - Turn HSS into a a preforking webserver and enable SSL

SYNOPSIS

Are you using HTTP::Server::Simple::CGI (or are you planning to)? But you want to handle multiple connections at once and even try out this SSL thingy everyone is using these days?

Fear not, the (brilliant) HTTP::Server::Simple::CGI is easy to extend and this (only modestly well-designed) module does it for you.

HTTP::Server::Simple::CGI::PreFork should be fully IPv6 compliant.

DESCRIPTION

This module is a plugin module for the "Commands" module and handles PostgreSQL admin commands scheduled from the WebGUI.

Configuration

Obviously, you want to read the HTTP::Server::Simple documentation for the bulk of configuration options. Since we also overload the base tcp connection class with Net::Server, you might also want to read the documentation for that.

We use two Net::Server classes, depending on if we are preforking or single threaded:

Net::Server::Single for singlethreaded

Net::Server::PreFork for multithreaded

In addition to the HTTP::Server::Simple configuration, there are only two additional options (in the hash to) the run() method: usessl and prefork.

prefork

Basic usage:

$myserver->run(prefork => 1):

Per default, prefork is turned off (e.g. server runs singlethreaded). This is very usefull for debugging and backward compatibility.

Beware when forking: Keep in mind how database and filehandles behave. Normally, you should set up everything before the run method (cache files, load confiugurations,...), then close all handles and run(). Then, depending on your site setup, either open a database connection for every request and close it again, or (and this is the better performing option) open a database handle at every request you don't have an open handle yet - since we are forking, every thread get's its own unique handle while not constantly opening and closing the handles.

Optionally, you can also add all the different options of Net::Server::Prefork like "max_servers" on the call to run() to optimize your configuration.

usessl

Caution: SSL support is experimental at best. I got this to work with a lot of warnings, sometimes it might not work at all. If you use this, please send patches!

Set this option to 1 if you want to use SSL (default is off). For SSL to actually work, need to add some extra options (required for the underlying Net::Server classes, something like this usually does the trick:

$webserver->run(usessl => 1, proto => 'ssleay'); "--SSL_key_file"=> 'mysite.key', "--SSL_cert_file"=>'mysite.crt', );

run

Internal functions that overrides the HTTP::Server::Simple::CGI run function. Just as explained above.

IPv6

This module overrides also the pure IPv4 handling of HTTP::Server::Simple::CGI and turns it into an IPv4/IPv6 multimode server.

Only caveat here is, that you need the Net::Server modules in version 0.99.6.1 or higher. Version 0.99 and lower only supports IPv4.

For some backward compatibility issues, the build requirements do *not* automatically pull that Net::Server version (only "0.99 or higher"). It's up to you to check that the correct version is installed.

WARNING

This module "patches" HTTP::Server::Simple by overloading one of the functions. Updating HTTP::Server::Simple *might* break something. While this is not very likely, make sure to test updates before updating a production system!

AUTHOR

Rene Schickbauer, <rene.schickbauer@gmail.com>

This module borrows heavily from the follfowing modules:

HTTP::Server::Simple by Jesse Vincent Net::Server by Paul T. Seamons

LICENSE

This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself, either Perl version 5.10.0 or, at your option, any later version of Perl 5 you may have available.

THANKS

Special thanks to Jesse Vincent for giving me quick feedback when i needed it.

Also thanks to the countless PerlMonks helping me out when i'm stuck. This module is dedicated to you!