ngnix+proxy+mongrel => real host
Julien Biard
julien.biard at citycampus.com
Fri Apr 27 12:02:43 MSD 2007
Hi,
I want to use ngnix + mongrel in proxy with different URLs, e.g
site1.com, site2.fr... and I need to get the real host in my application
(with request.host) and not the host used in upstream declaration.
Any idea ?
In this case, I have mongrel as host instead of site1.com or site2.fr :/
Best regards,
Julien
%<%<%<%<%<%<%<%<%<%<%<%<%<%<%<%<%<%<%<%<%<%<%<%<%<%<%<%<%<%<%<%<%<%<%<%<%<%<%<
/etc/nginx/ngnix.conf
user nginx nginx;
worker_processes 2;
error_log /var/log/nginx/error_log info;
events {
worker_connections 1024;
use epoll;
}
http {
include /etc/nginx/mime.types;
default_type application/octet-stream;
log_format main
'$remote_addr - $remote_user [$time_local] '
'"$request" $status $bytes_sent '
'"$http_referer" "$http_user_agent" '
'"$gzip_ratio"';
client_header_timeout 10m;
client_body_timeout 10m;
send_timeout 10m;
connection_pool_size 256;
client_header_buffer_size 1k;
large_client_header_buffers 4 2k;
request_pool_size 4k;
output_buffers 1 32k;
postpone_output 1460;
sendfile on;
tcp_nopush on;
tcp_nodelay on;
keepalive_timeout 75 20;
ignore_invalid_headers on;
index index.html;
gzip on;
gzip_min_length 1100;
gzip_buffers 4 8k;
gzip_types text/plain;
client_max_body_size 11000k;
upstream mongrel {
server 127.0.0.1:8000;
server 127.0.0.1:8001;
server 127.0.0.1:8002;
server 127.0.0.1:8003;
}
# ruby/mongrel
server {
listen 80;
server_name site1.com;
error_log /var/log/nginx/site1.com_error.log;
include /etc/nginx/include;
}
server {
listen 80;
server_name site2.fr;
error_log /var/log/nginx/site2.fr_error.log;
include /etc/nginx/include;
}
}
%<%<%<%<%<%<%<%<%<%<%<%<%<%<%<%<%<%<%<%<%<%<%<%<%<%<%<%<%<%<%<%<%<%<%<%<%<%<%<
/etc/nginx/include :
listen 80;
root /home/www/app/current/public;
access_log off;
rewrite_log on;
# / -> first search for local index.html then go to mongrel
location ~ ^/$ {
if (-f /index.html){
rewrite (.*) /index.html last;
}
proxy_pass http://mongrel;
}
# rail caching: searching first for $action.html local pages
location / {
if (!-f $request_filename.html) {
proxy_pass http://mongrel;
}
rewrite (.*) $1.html last;
}
# serve static files directly
location ~ .html {
root /home/www/app/current/public;
}
location ~*
^.+\.(jpg|jpeg|gif|png|ico|css|zip|tgz|gz|rar|bz2|doc|xls|exe|pdf|ppt|txt|tar|mid|midi|wav|bmp|rtf|js|mov)$
{
root /home/www/app/current/public;
}
# resend everything else to mongrel
location / {
proxy_pass http://mongrel;
proxy_redirect off;
proxy_set_header Host $http_host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
}
%<%<%<%<%<%<%<%<%<%<%<%<%<%<%<%<%<%<%<%<%<%<%<%<%<%<%<%<%<%<%<%<%<%<%<%<%<%<%<
More information about the nginx
mailing list