Best practices for running Perl?

Jonathan Vanasco nginx at 2xlp.com
Fri May 1 00:49:07 MSD 2009


If you are truly committed to running Perl...

your best option would be this:

Port 80 : Nginx serves static and proxies to Perl system
Port 80xx : Perl system ; either apache+fcgi or apache+mod_perl ...  
you might be able to run things under perlbal via plugins, but i dunno.

The ideal situation would be running fcgi under nginx, but I found it  
a PITA to set up / maintain.

I caved in and ran some perl apps through apache+mod_fcgi , and its  
pretty nice.  Nginx handles most of the requests itself, so 2 apache  
children are handling a decent amount of traffic.

I have a few production projects running nginx on 80 and proxying back  
to mod_perl enabled apache.  They work great, but they're apps  
designed to utilize a bunch of MP + Apache2 features... nginx was  
brought in a few years ago to increase improvement... and it was  
miraculous: nginx does awesome queuing/handoff of the mp traffic, so  
all apache does is process mod_perl fast and instantly.  no lazy  
client issues, no wasting resources on bloated servers.

in practice.. i haven't found /that/ much difference between a fine- 
tuned Apache+ModPerl , PHP ( via apache+mod_php or fcgi ) , Python  
( django / pylons ) setup.  Sure you can have a system where php+fcgi  
is taking up 50MB of ram while Apache+ModPerl is taking up 150... but  
to tweak the performance to equal one another you'd use a PHP cache  
that takes up 135MB of ram... making everything pretty darn negligble.





More information about the nginx mailing list