2011-02-07 07:48:44 +01:00
|
|
|
# Lightttpd
|
|
|
|
|
|
|
|
1. Lighttpd works fine so long as you provide a custom config. Add the following to lighttpd.conf **BEFORE** installing
|
|
|
|
Silverstripe. Replace "yoursite.com" and "/home/yoursite/public_html/" below.
|
|
|
|
|
|
|
|
|
|
|
|
$HTTP["host"] == "yoursite.com" {
|
|
|
|
server.document-root = "/home/yoursite/public_html/"
|
|
|
|
|
|
|
|
# Disable directory listings
|
|
|
|
dir-listing.activate = "disable"
|
|
|
|
|
|
|
|
# Deny access to template files
|
|
|
|
url.access-deny += ( ".ss" )
|
|
|
|
static-file.exclude-extensions += ( ".ss" )
|
|
|
|
|
2012-03-24 22:16:59 +01:00
|
|
|
# Deny access to SilverStripe command-line interface
|
|
|
|
$HTTP["url"] =~ "^/framework/cli-script.php" {
|
2011-02-07 07:48:44 +01:00
|
|
|
url.access-deny = ( "" )
|
|
|
|
}
|
|
|
|
|
|
|
|
# Disable FastCGI in assets directory (so that PHP files are not executed)
|
|
|
|
$HTTP["url"] =~ "^/assets/" {
|
|
|
|
fastcgi.server = ()
|
|
|
|
}
|
|
|
|
|
|
|
|
# Rewrite URLs so they are nicer
|
|
|
|
url.rewrite-once = (
|
|
|
|
"^/.*\.[A-Za-z0-9]+.*?$" => "$0",
|
2012-03-24 22:16:59 +01:00
|
|
|
"^/(.*?)(\?|$)(.*)" => "/framework/main.php?url=$1&$3"
|
2011-02-07 07:48:44 +01:00
|
|
|
)
|
|
|
|
|
|
|
|
# Show SilverStripe error page
|
2012-03-24 22:16:59 +01:00
|
|
|
server.error-handler-404 = "/framework/main.php"
|
2011-02-07 07:48:44 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
Rewrite rules do not check for file existence as they do on Apache. There is a ticket about it for Lighttpd:
|
|
|
|
[http://redmine.lighttpd.net/issues/985](http://redmine.lighttpd.net/issues/985).
|
|
|
|
|
|
|
|
2. Extract the SilverStripe software to your lighttpd installation, and run http://yoursite.com/install.php and the
|
|
|
|
installation should proceed normally.
|
|
|
|
|
|
|
|
## Multiple installations of SilverStripe on the same host (www.yourhost.com)
|
|
|
|
|
|
|
|
Running multiple installations of Silverstripe on the same host is a bit more tricky, but not impossible. I would
|
|
|
|
recommend using subdomains instead if you can, for exampe: site1.yourdomain.com and site2.yourdomain.com, it makes
|
|
|
|
things a lot simpler, as you just use two of the above host example blocks. But if you really must run multiple copies
|
|
|
|
of Silverstripe on the same host, you can use something like this (be warned, it's quite nasty):
|
|
|
|
|
|
|
|
|
|
|
|
$HTTP["host"] == "yoursite.com" {
|
|
|
|
url.rewrite-once = (
|
|
|
|
"(?i)(/copy1/.*\.([A-Za-z0-9]+))(.*?)$" => "$0",
|
|
|
|
"(?i)(/copy2/.*\.([A-Za-z0-9]+))(.*?)$" => "$0",
|
2012-03-24 22:16:59 +01:00
|
|
|
"^/copy1/(.*?)(\?|$)(.*)" => "/copy1/framework/main.php?url=$1&$3",
|
|
|
|
"^/copy2/(.*?)(\?|$)(.*)" => "/copy2/framework/main.php?url=$1&$3"
|
2011-02-07 07:48:44 +01:00
|
|
|
)
|
|
|
|
$HTTP["url"] =~ "^/copy1/" {
|
2012-03-24 22:16:59 +01:00
|
|
|
server.error-handler-404 = "/copy1/framework/main.php"
|
2011-02-07 07:48:44 +01:00
|
|
|
}
|
|
|
|
$HTTP["url"] =~ "^/copy2/" {
|
2012-03-24 22:16:59 +01:00
|
|
|
server.error-handler-404 = "/copy2/framework/main.php"
|
2011-02-07 07:48:44 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
Note: It doesn't work properly if the directory name copy1 or copy2 on your server has a dot in it, and you then open
|
|
|
|
the image editor inside admin, I found that out the hard way when using a directory name of silverstripe-v2.2.2 after
|
|
|
|
directly unzipping the Silverstripe tarball leaving the name as is. I haven't found a solution for that yet, but for now
|
|
|
|
this method still works properly if you just don't use dots in the directory names.
|
|
|
|
|
|
|
|
## Installing lighttpd on Debian
|
|
|
|
|
|
|
|
* aptitude install lighttpd *(and php5-cgi, mysql-server, etc, as necessary.)*
|
|
|
|
* if apache is already running, lighttpd can still be safely installed. It will complain it cannot start because
|
|
|
|
port 80 is in use. After installing lighttpd, edit /etc/lighttpd/lighttpd.conf and set: "server.port = 81" for example,
|
|
|
|
and run /etc/init.d/lighttpd restart
|
|
|
|
* edit /etc/lighttpd/conf-available/10-fastcgi.conf and set socket to: /var/run/lighttpd/php.socket
|
|
|
|
* enable fastcgi module with /usr/sbin/lighty-enable-mod
|
|
|
|
* /etc/init.d/lighttpd restart
|
|
|
|
* You should now be able to view PHP files in your now-working lighttpd server.
|
|
|
|
* Follow the top instructions on adding the rewrite rules, and then install SilverStripe.
|
|
|
|
|
|
|
|
## More about lighttpd
|
|
|
|
|
|
|
|
Learn more about the lighttpd webserver at http://www.lighttpd.net/
|