discourse/config/nginx.sample.conf

72 lines
1.6 KiB
Plaintext
Raw Normal View History

# Additional MIME types that you'd like nginx to handle go in here
types {
text/csv csv;
}
2013-02-05 13:16:51 -06:00
upstream discourse {
server unix:/var/www/discourse/tmp/sockets/thin.0.sock;
server unix:/var/www/discourse/tmp/sockets/thin.1.sock;
server unix:/var/www/discourse/tmp/sockets/thin.2.sock;
server unix:/var/www/discourse/tmp/sockets/thin.3.sock;
2013-02-05 13:16:51 -06:00
}
server {
listen 80;
gzip on;
gzip_min_length 1000;
gzip_types application/json text/css application/x-javascript;
server_name enter.your.web.hostname.here;
2013-02-05 13:16:51 -06:00
sendfile on;
keepalive_timeout 65;
2013-07-21 02:42:07 -05:00
client_max_body_size 2m;
2013-02-05 13:16:51 -06:00
location / {
root /var/www/discourse/public;
2013-02-05 13:16:51 -06:00
## optional upload anti-hotlinking rules
#location ~ ^/uploads/ {
# valid_referers none blocked mysite.com *.mysite.com;
# if ($invalid_referer) {
# return 403;
# }
#}
2013-06-15 00:25:41 -05:00
## [LEGACY] this is deprecated, leaving it there for a small transition period
location ~ ^/t\/[0-9]+\/[0-9]+\/avatar {
expires 1d;
add_header Cache-Control public;
add_header ETag "";
}
location ~ ^/(assets|uploads)/ {
2013-02-05 13:16:51 -06:00
expires 1y;
add_header Cache-Control public;
add_header ETag "";
break;
}
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $scheme;
proxy_set_header Host $http_host;
2013-02-05 13:16:51 -06:00
# If the file exists as a static file serve it directly without
2013-07-13 23:06:59 -05:00
# running all the other rewrite tests on it
2013-02-05 13:16:51 -06:00
if (-f $request_filename) {
break;
}
if (!-f $request_filename) {
proxy_pass http://discourse;
break;
}
2013-02-05 13:16:51 -06:00
}
}