Browse Source

updated docs on FastCGI deployment with Lighty

Signed-off-by: Armin Ronacher <armin.ronacher@active-4.com>
pull/167/head
fmw 14 years ago committed by Armin Ronacher
parent
commit
94f90bc4eb
  1. 35
      docs/deploying/fastcgi.rst

35
docs/deploying/fastcgi.rst

@ -26,11 +26,12 @@ First you need to create the FastCGI server file. Let's call it
from flup.server.fcgi import WSGIServer from flup.server.fcgi import WSGIServer
from yourapplication import app from yourapplication import app
if __name__ == '__main__':
WSGIServer(app).run() WSGIServer(app).run()
This is enough for Apache to work, however lighttpd and nginx need a This is enough for Apache to work, however nginx and older versions of
socket to communicate with the FastCGI server. For that to work you lighttpd need a socket to be explicitly passed to communicate with the FastCGI
need to pass the path to the socket to the server. For that to work you need to pass the path to the socket to the
:class:`~flup.server.fcgi.WSGIServer`:: :class:`~flup.server.fcgi.WSGIServer`::
WSGIServer(application, bindAddress='/path/to/fcgi.sock').run() WSGIServer(application, bindAddress='/path/to/fcgi.sock').run()
@ -54,21 +55,33 @@ Configuring lighttpd
A basic FastCGI configuration for lighttpd looks like that:: A basic FastCGI configuration for lighttpd looks like that::
fastcgi.server = ("/yourapplication" => fastcgi.server = ("/yourapplication.fcgi" =>
"yourapplication" => ( ((
"socket" => "/tmp/yourapplication-fcgi.sock", "socket" => "/tmp/yourapplication-fcgi.sock",
"bin-path" => "/var/www/yourapplication/yourapplication.fcgi", "bin-path" => "/var/www/yourapplication/yourapplication.fcgi",
"check-local" => "disable" "check-local" => "disable",
"max-procs" -> 1
))
) )
alias.url = (
"/static/" => "/path/to/your/static"
) )
This configuration binds the application to `/yourapplication`. If you url.rewrite-once = (
want the application to work in the URL root you have to work around a "^(/static.*)$" => "$1",
lighttpd bug with the :class:`~werkzeug.contrib.fixers.LighttpdCGIRootFix` "^(/.*)$" => "/yourapplication.fcgi$1"
middleware.
Remember to enable the FastCGI, alias and rewrite modules. This configuration
binds the application to `/yourapplication`. If you want the application to
work in the URL root you have to work around a lighttpd bug with the
:class:`~werkzeug.contrib.fixers.LighttpdCGIRootFix` middleware.
Make sure to apply it only if you are mounting the application the URL Make sure to apply it only if you are mounting the application the URL
root. root. Also, see the Lighty docs for more information on `FastCGI and Python
<http://redmine.lighttpd.net/wiki/lighttpd/Docs:ModFastCGI>`_ (note that
explicitly passing a socket to run() is no longer necessary).
Configuring nginx Configuring nginx
----------------- -----------------

Loading…
Cancel
Save