2 # Load the modules that we need
17 # Basic server configuration
19 server.username = "www-data"
20 server.groupname = "www-data"
21 server.pid-file = "/var/run/lighttpd.pid"
23 server.reject-expect-100-with-417 = "disable"
28 accesslog.filename = "/var/log/lighttpd/access.log"
29 accesslog.format = "%h %V %u %t \"%r\" %>s %b \"%{Referer}i\" \"%{User-Agent}i\" \"%{Accept-Language}i\""
30 server.errorlog = "/var/log/lighttpd/error.log"
33 # Allow munin to monitor the server's status
35 $HTTP["remoteip"] == "128.40.168.98" {
36 status.config-url = "/server-config"
37 status.status-url = "/server-status"
38 status.statistics-url = "/server-statistics"
44 include_shell "lighttpd-host-blocks.sh"
47 # Block some troublesome robots
49 #$HTTP["useragent"] =~ "msnbot" { url.access-deny = ("") }
50 $HTTP["useragent"] =~ "Twiceler" { url.access-deny = ("") }
51 $HTTP["useragent"] =~ "Baiduspider" { url.access-deny = ("") }
52 $HTTP["useragent"] =~ "Sosospider+" { url.access-deny = ("") }
53 #$HTTP["useragent"] =~ "Yahoo! Slurp" { url.access-deny = ("") }
54 $HTTP["useragent"] =~ "Yeti" { url.access-deny = ("") }
55 #$HTTP["useragent"] =~ "Googlebot" { url.access-deny = ("") }
56 $HTTP["useragent"] =~ "The Hare and the Hedgeho" { url.access-deny = ("") }
61 $HTTP["useragent"] =~ "tilesAtHome" { url.access-deny = ("") }
64 # Block JOSM revisions 1722-1727 as they have a serious bug that causes
65 # lat/lon to be swapped (http://josm.openstreetmap.de/ticket/2804)
67 $HTTP["useragent"] =~ "^JOSM/[0-9]+\.[0-9]+ \(172[234567] " {
68 url.access-deny = ("")
72 # Setup MIME type mapping
76 ".gif" => "image/gif",
77 ".html" => "text/html; charset=utf-8",
78 ".jpg" => "image/jpeg",
79 ".js" => "application/x-javascript",
80 ".png" => "image/png",
81 ".swf" => "application/x-shockwave-flash",
82 ".txt" => "text/plain",
87 # Force special MIME type for crossdomain.xml files
89 $HTTP["url"] =~ "/crossdomain\.xml$" {
90 mimetype.assign = ( ".xml" => "text/x-cross-domain-policy" )
94 # Enable compression of appropriate static content
97 "application/x-javascript",
98 "application/x-shockwave-flash",
105 # Set expiry for static content
108 "/export/embed.html" => "access 7 days",
109 "/images/" => "access 10 years",
110 "/javascripts/" => "access 10 years",
111 "/openlayers/" => "access 7 days",
112 "/stylesheets/" => "access 10 years"
116 # Cache compressed content
118 compress.cache-dir = "/var/cache/lighttpd"
121 # Redirect trac and wiki requests to the right places
124 "^/trac/(.*)$" => "http://trac.openstreetmap.org/$1",
125 "^/wiki/(.*)$" => "http://wiki.openstreetmap.org/$1"
129 # Redirect everything except www.openstreetmap.org and
130 # api.openstreetmap.org to www.openstreetmap.org
132 $HTTP["host"] =~ "^api\." {
133 $HTTP["host"] != "api.openstreetmap.org" {
134 url.redirect = ( "^(.*)$" => "http://api.openstreetmap.org$1" )
137 else $HTTP["host"] != "www.openstreetmap.org" {
138 url.redirect = ( "^(.*)$" => "http://www.openstreetmap.org$1" )
142 # Run anything with a .pl iextension as a CGI script
144 cgi.assign = ( ".pl" => "/usr/bin/perl" )
147 # Serve static content from the rails public area ourselves
149 server.document-root = "/home/rails/public"
152 # Send everything else to the appropriate FastCGI server
154 $HTTP["url"] =~ "^/trace/[0-9]+/data$" {
155 server.error-handler-404 = "/dispatch.bulkapi"
157 else $HTTP["url"] =~ "^/api/0\.6/map$" {
158 server.error-handler-404 = "/dispatch.map"
160 else $HTTP["url"] =~ "^/api/0\.6/(trackpoints|amf|amf/read|swf/trackpoints|changeset/[0-9]+/(upload|download))$" {
161 server.error-handler-404 = "/dispatch.bulkapi"
163 else $HTTP["url"] =~ "^/api/0\.6/.*/(full|history|search|ways)$" {
164 server.error-handler-404 = "/dispatch.bulkapi"
166 else $HTTP["url"] =~ "^/api/0\.6/" {
167 server.error-handler-404 = "/dispatch.api"
169 else $HTTP["url"] =~ "^/api/0\.[0-9]+/" {
170 url.access-deny = ("")
172 else $HTTP["url"] =~ "^/geocoder/(search|description)_geonames$" {
173 server.error-handler-404 = "/dispatch.geonames"
175 else $HTTP["url"] =~ "^/" {
176 server.error-handler-404 = "/dispatch.web"
180 # Configure the FastCGI servers
184 ( "host" => "127.0.0.1", "port" => 8000, "check-local" => "disable" ),
185 ( "host" => "127.0.0.1", "port" => 8001, "check-local" => "disable" ),
186 ( "host" => "127.0.0.1", "port" => 8002, "check-local" => "disable" ),
187 ( "host" => "127.0.0.1", "port" => 8003, "check-local" => "disable" ),
188 ( "host" => "127.0.0.1", "port" => 8004, "check-local" => "disable" ),
189 ( "host" => "127.0.0.1", "port" => 8005, "check-local" => "disable" ),
190 ( "host" => "127.0.0.1", "port" => 8006, "check-local" => "disable" ),
191 ( "host" => "127.0.0.1", "port" => 8007, "check-local" => "disable" ),
192 ( "host" => "127.0.0.1", "port" => 8008, "check-local" => "disable" ),
193 ( "host" => "127.0.0.1", "port" => 8009, "check-local" => "disable" ),
194 ( "host" => "127.0.0.1", "port" => 8010, "check-local" => "disable" ),
195 ( "host" => "127.0.0.1", "port" => 8011, "check-local" => "disable" ),
196 ( "host" => "127.0.0.1", "port" => 8012, "check-local" => "disable" ),
197 ( "host" => "127.0.0.1", "port" => 8013, "check-local" => "disable" ),
198 ( "host" => "127.0.0.1", "port" => 8014, "check-local" => "disable" ),
199 ( "host" => "127.0.0.1", "port" => 8015, "check-local" => "disable" ),
200 ( "host" => "127.0.0.1", "port" => 8016, "check-local" => "disable" ),
201 ( "host" => "127.0.0.1", "port" => 8017, "check-local" => "disable" ),
202 ( "host" => "127.0.0.1", "port" => 8018, "check-local" => "disable" ),
203 ( "host" => "127.0.0.1", "port" => 8019, "check-local" => "disable" ),
204 ( "host" => "127.0.0.1", "port" => 8020, "check-local" => "disable" ),
205 ( "host" => "127.0.0.1", "port" => 8021, "check-local" => "disable" ),
206 ( "host" => "127.0.0.1", "port" => 8022, "check-local" => "disable" ),
207 ( "host" => "127.0.0.1", "port" => 8023, "check-local" => "disable" ),
208 ( "host" => "127.0.0.1", "port" => 8024, "check-local" => "disable" ),
209 ( "host" => "127.0.0.1", "port" => 8025, "check-local" => "disable" ),
210 ( "host" => "127.0.0.1", "port" => 8026, "check-local" => "disable" ),
211 ( "host" => "127.0.0.1", "port" => 8027, "check-local" => "disable" ),
212 ( "host" => "127.0.0.1", "port" => 8028, "check-local" => "disable" ),
213 ( "host" => "127.0.0.1", "port" => 8029, "check-local" => "disable" )
216 ( "host" => "127.0.0.1", "port" => 8030, "check-local" => "disable" ),
217 ( "host" => "127.0.0.1", "port" => 8031, "check-local" => "disable" ),
218 ( "host" => "127.0.0.1", "port" => 8032, "check-local" => "disable" ),
219 ( "host" => "127.0.0.1", "port" => 8033, "check-local" => "disable" )
222 ( "host" => "127.0.0.1", "port" => 8034, "check-local" => "disable" ),
223 ( "host" => "127.0.0.1", "port" => 8035, "check-local" => "disable" ),
224 ( "host" => "127.0.0.1", "port" => 8036, "check-local" => "disable" ),
225 ( "host" => "127.0.0.1", "port" => 8037, "check-local" => "disable" ),
226 ( "host" => "127.0.0.1", "port" => 8038, "check-local" => "disable" ),
227 ( "host" => "127.0.0.1", "port" => 8039, "check-local" => "disable" ),
228 ( "host" => "127.0.0.1", "port" => 8040, "check-local" => "disable" ),
229 ( "host" => "127.0.0.1", "port" => 8041, "check-local" => "disable" ),
230 ( "host" => "127.0.0.1", "port" => 8042, "check-local" => "disable" ),
231 ( "host" => "127.0.0.1", "port" => 8043, "check-local" => "disable" ),
232 ( "host" => "127.0.0.1", "port" => 8044, "check-local" => "disable" ),
233 ( "host" => "127.0.0.1", "port" => 8045, "check-local" => "disable" ),
234 ( "host" => "127.0.0.1", "port" => 8046, "check-local" => "disable" ),
235 ( "host" => "127.0.0.1", "port" => 8047, "check-local" => "disable" ),
236 ( "host" => "127.0.0.1", "port" => 8048, "check-local" => "disable" )
239 ( "host" => "10.0.0.10", "port" => 8000, "check-local" => "disable" ),
240 ( "host" => "10.0.0.11", "port" => 8000, "check-local" => "disable" ),
241 ( "host" => "10.0.0.12", "port" => 8000, "check-local" => "disable" ),
242 ( "host" => "10.0.0.10", "port" => 8001, "check-local" => "disable" ),
243 ( "host" => "10.0.0.11", "port" => 8001, "check-local" => "disable" ),
244 ( "host" => "10.0.0.12", "port" => 8001, "check-local" => "disable" ),
245 ( "host" => "10.0.0.10", "port" => 8002, "check-local" => "disable" ),
246 ( "host" => "10.0.0.11", "port" => 8002, "check-local" => "disable" ),
247 ( "host" => "10.0.0.12", "port" => 8002, "check-local" => "disable" ),
248 ( "host" => "10.0.0.10", "port" => 8003, "check-local" => "disable" ),
249 ( "host" => "10.0.0.11", "port" => 8003, "check-local" => "disable" ),
250 ( "host" => "10.0.0.12", "port" => 8003, "check-local" => "disable" ),
251 ( "host" => "10.0.0.10", "port" => 8004, "check-local" => "disable" ),
252 ( "host" => "10.0.0.11", "port" => 8004, "check-local" => "disable" ),
253 ( "host" => "10.0.0.12", "port" => 8004, "check-local" => "disable" ),
254 ( "host" => "10.0.0.10", "port" => 8005, "check-local" => "disable" ),
255 ( "host" => "10.0.0.11", "port" => 8005, "check-local" => "disable" ),
256 ( "host" => "10.0.0.12", "port" => 8005, "check-local" => "disable" ),
257 ( "host" => "10.0.0.10", "port" => 8006, "check-local" => "disable" ),
258 ( "host" => "10.0.0.11", "port" => 8006, "check-local" => "disable" ),
259 ( "host" => "10.0.0.12", "port" => 8006, "check-local" => "disable" ),
260 ( "host" => "10.0.0.10", "port" => 8007, "check-local" => "disable" ),
261 ( "host" => "10.0.0.11", "port" => 8007, "check-local" => "disable" ),
262 ( "host" => "10.0.0.12", "port" => 8007, "check-local" => "disable" ),
263 ( "host" => "10.0.0.10", "port" => 8008, "check-local" => "disable" ),
264 ( "host" => "10.0.0.11", "port" => 8008, "check-local" => "disable" ),
265 ( "host" => "10.0.0.12", "port" => 8008, "check-local" => "disable" ),
266 ( "host" => "10.0.0.10", "port" => 8009, "check-local" => "disable" ),
267 ( "host" => "10.0.0.11", "port" => 8009, "check-local" => "disable" ),
268 ( "host" => "10.0.0.12", "port" => 8009, "check-local" => "disable" ),
269 ( "host" => "10.0.0.10", "port" => 8010, "check-local" => "disable" ),
270 ( "host" => "10.0.0.11", "port" => 8010, "check-local" => "disable" ),
271 ( "host" => "10.0.0.12", "port" => 8010, "check-local" => "disable" ),
272 ( "host" => "10.0.0.10", "port" => 8011, "check-local" => "disable" ),
273 ( "host" => "10.0.0.11", "port" => 8011, "check-local" => "disable" ),
274 ( "host" => "10.0.0.12", "port" => 8011, "check-local" => "disable" )
277 ( "host" => "10.0.0.10", "port" => 9000, "check-local" => "disable" ),
278 ( "host" => "10.0.0.11", "port" => 9000, "check-local" => "disable" ),
279 ( "host" => "10.0.0.12", "port" => 9000, "check-local" => "disable" )