nginx and rails configuration question
Cathal
coriordan at tssg.org
Thu Apr 3 12:45:33 MSD 2008
Francisco Valladolid <ficovh at ...> writes:
>
>
> Can you post the complete nginx.conf file ?Regards.
> On Thu, Apr 3, 2008 at 4:08 AM, Cathal
<coriordan at tssg.org> wrote:
> Hi Francisco,
> Thanks for replying.
> I've defined the cluster instances elsewhere in my conf file.
> I just didn't include them in the sample I posted.
> The issue is that $request_filename includes the matched location '/app2'
> in its path.
> So the following directive:
>
> if (-f $request_filename)
> {
> break;
> }
> looks for '/app2/styesheets/style.css' in the root directory.
> This doesn't exist.
> Is there someway to take into account that '/app2' is a virtual path when
> attempting a match?
> regards,C.
>
>
> -- Francisco Valladolid H. -- http://bsdguy.net - Jesus Christ follower.
>
Hi Francisco,
Here is the nginx.conf file I'm using.
regards,
C.
--- begin nginx.conf ---
# user and group to run as
user user users;
# number of nginx workers
worker_processes 6;
# pid of nginx master process
pid /var/run/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 {
ignore_invalid_headers off;
# pull in mime-types. You can break out your config
# into as many include's as you want to make it cleaner
include /usr/local/nginx/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] '
'"$request" $status $body_bytes_sent "$http_referer" '
'"$http_user_agent" "$http_x_forwarded_for"';
# main access log
access_log /var/log/nginx_access.log main;
# main error log
error_log /var/log/nginx_error.log debug;
# 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.
upstream mongrel_app1 {
server localhost:7000;
server localhost:7001;
server localhost:7002;
server localhost:7003;
}
upstream mongrel_app2 {
server localhost:10000;
server localhost:10001;
server localhost:10002;
server localhost:10003;
}
# the server directive is nginx's virtual host directive.
server {
# port to listen on. Can also be set to an IP:PORT
listen 80;
# Set the max size for file uploads to 50Mb
client_max_body_size 50M;
# sets the domain[s] that this vhost server requests for
# server_name www.[engineyard].com [engineyard].com;
# doc root
root /u/apps/app1/current/public;
# vhost specific access log
access_log /var/log/nginx.vhost.access.log main;
# 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/system/maintenance.html) {
rewrite ^(.*)$ /system/maintenance.html last;
break;
}
# SNMP MRTG location
location /admin/mrtg/ {
satisfy_any on;
deny all;
auth_basic "closed site";
auth_basic_user_file /var/passwords;
alias /var/www/mrtg/;
index index.html index.htm;
}
# app1
location / {
# 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;
# If the file exists as a static file serve it directly without
# running all the other rewite tests on it
if (-f $request_filename) {
break;
}
# 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 (!-f $request_filename) {
proxy_pass http://mongrel_app1;
break;
}
}
# app2
location /app2 {
root /u/apps/app2/current/public;
# 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;
# If the file exists as a static file serve it directly without
# running all the other rewite tests on it
if (-f $request_filename) {
break;
}
# 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 (!-f $request_filename) {
proxy_pass http://mongrel_app2;
break;
}
}
error_page 500 502 503 504 /500.html;
location = /500.html {
root /u/apps/app1/current/public;
}
}
}
--- end nginx.conf ---
More information about the nginx
mailing list