Project

General

Profile

Actions

MigratingFromApache » History » Revision 24

« Previous | Revision 24/51 (diff) | Next »
Anonymous, 2006-08-05 13:24
added entry in reference to ForceType migration


= Migrating from Apache to lighty =

PageOutline

Configuration Basics

Lighttpd is a great option as a replacement from apache. If you are seriously considering migrating read the documentation for the configuration file [wiki:Docs:Configuration]. The configuration syntax is initially the biggest learning curve, but you will learn of its flexibility once you become familiar with it. One of the most powerful features of the lighty configuration are '''conditionals'''. Lighty allows you to setup configuration options based on requests' conditions. Conditionals can be nested, so in term you can create complex but very effective configuration options. Conditionals are the key many solutions that people encounter when migrating. Here are some examples:

'''Problem''': I want to disable directory listing for directory /download:
Entry in Configuration file:

{{{
  1. Enable dir listing for all directories
    dir-listing.activate = "enable"
  1. If the URL is like /download/ then disable dir-listing
    $HTTP["url"] =~ "
    /download/" {
    dir-listing.activate = "disable"
    }
    }}}

You must familiarize yourself with regular expressions to truly become familiar with conditionals. You will use conditionals in your configuration file for multitude of things. Authentication, URL Rewriting, Virtual Hosting, and many more. All the variables you can use in conditionals are listed here along with further explanation about the match operators [wiki:Docs:Configuration].

'''
Problem''': You want the status page to be available just for users from the local network:
Entry in configuration file:

{{{
$HTTP["remoteip"] == "10.0.0.0/8" {
status.status-url = "/server-status"
}
}}}

And here is a nested example.

'''Problem''': If the host is www.example.org and the directory is /download enable directory listing:

{{{
$HTTP["host"] == "www2.example.org" {
server.document-root = "/var/www/servers/www2.example.org/pages/"
$HTTP["url"] =~ "^/download/" {
dir-listing.activate = "enable"
}
}}}

}

For more conditional examples read: * [wiki:HowToRedirectHttpToHttps] * [wiki:HowToRedirectWww] * [wiki:HowToAuthenticationFromMultipleFiles]


Basic Options

{{{
Options +FollowSymLinks
}}}

becomes

{{{
server.follow-symlink = "enable"
}}}

Accesslog

Accesslogs are written by mod_accesslog and support the same options in

{{{
accesslog.format = ...
}}}

as Apache.

If you need logfile rotation use one of two ways:

=== logrotate ===

If you don't use the debian package copy ./debian/lighttpd.logrotate to /etc/logrotate.d/

logrotate will send lighttpd a SIGHUP when it is time to rotate the logs and lighttpd will reopen the logs accordingly.

=== cronolog ===

With cronolog you pipe the accesslog to a pipe and let a external program handle the logfile writing:

{{{
accesslog.filename = "|/usr/sbin/cronolog /web/logs/%Y/%m/%d/access.log"
}}}

mod_rewrite

[http://www.lighttpd.net/documentation/rewrite.html mod_rewrite] is more trickier as the idea how it is handled is completely different.

First of all we always match on the full relative request-uri that is submitted by the user. That means we are always using the [QSA] (query string append) flag from [http://httpd.apache.org/docs/mod/mod_rewrite.html mod_rewrite in Apache].

This example is based on a problem from http://dir.onlinesearch.ws/ sent in by dbird@freenode.

{{{
RewriteEngine On
RewriteBase /instadir/
RewriteCond %{REQUEST_FILENAME} -d
  1. Fix trailing slash problem
    RewriteRule (.+[/])$ $1/ [R,L]
  2. Do not try to treat the following resources as parameters to index.php
    RewriteRule ^index.php.*$ - [L]
    RewriteRule ^dmoz.css$ - [L]
    RewriteRule ^admin[/]?.*$ - [L]
    RewriteRule ^img[/]?.*$ - [L]
    RewriteRule ^[/]{0,}(.*)$ index.php?area=browse&cat=$1 [QSA,L]
    }}}

These rewrites want to rewrite everything that is not the index.php, dmoz.css, admin-interface or something from the image-directory to a parameter of the index.php page. The base directory for this match is ''/instadir/''.

{{{
  1. for all URLs in /instadir/ that are not index.php, dmoz.css, admin or img, do ...
    url.rewrite-once = ( "^/instadir/(?!index.php|dmoz.css|admin|img).*" => "$0",
    "^/instadir/([^?]*)(?:\?(.*))?" => "/instadir/index.php?area=browse&cat=$1&$2")
    }}}
    The conditional is using regex-magic called [http://perlpod.com/5.9.1/pod/perlre.html#Extended%20Patterns zero-width negative look-ahead assertion] and is something from the advanced chapters of your [http://www.oreilly.com/catalog/regex/ regex book].
mod_fastcgi

If you have 2 extensions assigned to the fastcgi handler in Apache like

{{{
AddType fastcgi-php .php .phtml
}}}

then you need two entries in the fastcgi.server config:

{{{
fastcgi.server = ( ".php" => (( "bin-path" => "/my/fastcgi-php",
"socket" => "/path/to/php.socket" )),
".phtml" => (( "socket" => "/path/to/php.socket-0" ))
)
}}}

The first entry will create the php-fcgi process and the second will reuse the same socket.

If you need to use PHP and Python in the same setup, just add two extensions:

{{{
fastcgi.server = ( ".php" => (( "bin-path" => "/my/fastcgi-php",
"socket" => "/path/to/php.socket" )),
".py" => (( "host" => "127.0.0.1", "port" => 3200 ))
)
}}}

For this setup python was spawned externally and is a waiting for requests at port 3200, localhost.

Directory !ForceType Migration

There are several PHP packages and tutorials that use the apache !ForceType directive instead of mod_rewrite. They use it as a ''Search Engine'' friendly way to pass arguments as fake directories.

Let say you have this setup: * Your script is called ''news'' (note no php extension) * Your URLs look like /news/100/ (/news/''id of the news'') * Your script grabs $_GET!['PHP_SELF'] to determine the news id

and apache is configured with a Location or !LocationMatch entry like this:

{{{
<Location /news>
ForceType application/x-httpd-php
</Location>
}}}

The easiest way to migrate this is: * First setup PHP with lightty and make sure .php extension is working * Rename filename ''news'' to ''news.php'' * Use a lighttpd rewrite to replace the Forcetype entry

In lighttpd configuration file:

{{{
url.rewrite-once = ("^/news/.*" => "/news.php")
}}}

If your script is still not working, try to replace
$_GET!["PHP_SELF"] with $_GET!["REQUEST_URI"] You can find it usually at the top of the script.
PHP does not register PHP_SELF correctly when running in FastCGI.

Updated by Anonymous over 18 years ago · 51 revisions