]> git.openstreetmap.org Git - chef.git/blobdiff - cookbooks/tilecache/templates/default/nginx_tile.conf.erb
tilecache: fallback to other caches if local cache unresponsive
[chef.git] / cookbooks / tilecache / templates / default / nginx_tile.conf.erb
index 95d7b8b8c062f559c22d3de12534da4740e90094..c8cace7a849590d58e57e608af1b906e6dafa1c7 100644 (file)
@@ -3,7 +3,18 @@
 upstream tile_cache_backend {
     server 127.0.0.1;
 
-    keepalive 32;
+    # Add the other caches to relieve pressure if local squid failing
+    # Balancer: round-robin
+<% @caches.each do |cache| -%>
+<% if cache[:hostname] != node[:hostname] -%>
+    # Server <%= cache[:hostname] %>
+<% cache.ipaddresses(:family => :inet, :role => :external).sort.each do |address| -%>
+    server <%= address %> backup;
+<% end -%>
+<% end -%>
+<% end -%>
+
+    keepalive 256;
 }
 
 # Rates table based on current cookie value
@@ -51,7 +62,7 @@ server {
       proxy_http_version 1.1;
       proxy_set_header Connection '';
 
-      proxy_connect_timeout 5s;
+      proxy_connect_timeout 10s;
 
       # Preserve host header.
       proxy_set_header Host $host;
@@ -79,7 +90,7 @@ server {
 
       # Allow Higher Traffic Rate from Approved User-Agents which do not support cookies (uses nginx Map)
       if ($approved_scraper) {
-        set $limit_rate 32768;
+        set $limit_rate 65536;
       }
 
       # Strip any ?query parameters from urls