Pastie now auto-senses if line-wrap is a bad or good idea. Feedback?
## mark a section (Learn more)
## Based on ## http://brainspl.at/nginx.conf.txt ## Thanks to Ezra and Err for this file and the config generator ## Modifed by Hendrik <solaris@sundevil.de> to suit his needs #user and group to run as user <%= config['user'] || "nginx" %> <%= config['group'] || "nginx" %>; # number of nginx workers worker_processes 2; # pid of nginx master process pid <%= config['pid_path'] || 'logs/' %>nginx.pid; # Number of worker connections. 1024 is a good default events { worker_connections 1024; } # start the http module where we config http access. http { # pull in mime-types. You can break out your config # into as many include's as you want to make it cleaner include <%= config['config_path'] || 'conf/' %>mime.types; # set a default type for the rare situation that # nothing matches from the mimie-type include default_type application/octet-stream; # configure log format log_format main '$remote_addr - $remote_user [$time_local] $status ' '"$request" $body_bytes_sent "$http_referer" ' '"$http_user_agent" "http_x_forwarded_for"'; # main access log access_log <%= config['log_path'] || 'logs/' %>access.log main; # main error log error_log <%= config['log_path'] || 'logs/' %>error.log debug; #error_log logs/error.log debug_http; # no sendfile on OSX sendfile on; # These are good default values. tcp_nopush on; tcp_nodelay off; # output compression saves bandwidth gzip on; gzip_http_version 1.0; gzip_comp_level 2; gzip_proxied any; gzip_types text/plain text/html text/css application/x-javascript text/xml application/xml application/xml+rss text/javascript; # this is where you define your mongrel clusters. # you need one of these blocks for each cluster # and each one needs its own name to refer to it later. <% config['sites'].each do |name, site| %> <% next unless site['upstream'] %> upstream <%= name %> { <% Array(site['upstream'] || site['upstreams']).each do |server| %> server <%= server %>; <% end %> } <% end %> <% config['sites'].each do |name, site| %> # the server directive is nginx's virtual host directive. server { # port to listen on. Can also be set to an IP:PORT listen 80; # sets the domain[s] that this vhost server requests for server_name <%= site['server_name'] %>; # doc root root <%= (config['root'][ site['root'] || 'default' ] || site['root']) % name %>; # vhost specific access log access_log <%= config['log_path'] || 'logs/' %><%= name %>.access.log main; #Set the max size for file uploads to 50Mb client_max_body_size 50M; # this rewrites all the requests to the maintenance.html # page if it exists in the doc root. This is for capistrano's # disable web task if (-f $document_root/maintenance.html){ rewrite ^(.*)$ /maintenance.html last; break; } <% if site['no_www'] %> if ($host ~* "www") { rewrite ^(.*)$ http://<%= site['server_name'].split.first %>$1 redirect; break; } <% end %> location / { <% Array(site['rewrite'] || site['rewrites']).each do |rewrite| %> rewrite <%= rewrite %> break; <% end %> <% Array(site['feed'] || site['feeds']).each do |feed_rewrite| %> if ($http_user_agent !~ FeedBurner) { rewrite <%= feed_rewrite %> break; } <% end %> <% if site['auth_file'] %> auth_basic "<%= name %> requires credentials."; auth_basic_user_file <%= site['auth_file'] %>; <% end %> # needed to forward user's IP address to rails proxy_set_header X-Real-IP $remote_addr; # needed for HTTPS proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header Host $http_host; proxy_redirect false; proxy_max_temp_file_size 0; # check for index.html for directory index # if its there on the filesystem then rewite # the url to add /index.html to the end of it # and then break to send it to the next config rules. if (-f $request_filename/index.html) { rewrite (.*) $1/index.html break; } # this is the meat of the rails page caching config # it adds .html to the end of the url and then checks # the filesystem for that file. If it exists, then we # rewite the url to have explicit .html on the end # and then send it on its way to the next config rule. # if there is no file on the fs then it sets all the # necessary headers and proxies to our upstream mongrels if (-f $request_filename.html) { rewrite (.*) $1.html break; } <% if site['upstream'] %> if (!-f $request_filename) { proxy_pass http://<%= name %>; break; } <% end %> } error_page 500 502 503 504 /50x.html; location = /50x.html { root html; } } <% end %> }
This paste will be private.
From the Design Piracy series on my blog: