Nginx causes redirects when server root is changed

yashgt nginx-forum at nginx.us
Tue Jul 31 07:06:58 UTC 2012


My nginx version is :
root at v-enterprise15:/etc/nginx/conf.d# nginx -v
nginx: nginx version: nginx/1.0.5

My application is installed at 
/usr/share/nginx/www/magento/current

When I access
http://myserver:81/magento/current/index.php
it works fine. This is because the server root is set to
/usr/share/nginx/www;

Now I want to acces the app using http://myserver.co.in:81/index.php.
When I change the server root to /usr/share/nginx/www/magento/current
and type the above URL, it REDIRECTS with http 302 to 
http://myserver:81/magento/current. 
What might be the reason for this?

It then applies other rules from my .conf and gives a 404.

I see this in the access log:
[31/Jul/2012:11:19:23 +0530] "GET /index.php HTTP/1.1" 302 5 "-"
"Opera/9.80 (Windows NT 6.1; U; en) Presto/2.10.229 Version/11.64"

My .conf file is:
    server {
        listen 81 default;
    ## SSL directives might go here
        server_name myserver;
        #root /usr/share/nginx/www;
        root /usr/share/nginx/www/magento/current;
        error_log /var/log/nginx.error.log notice;
        access_log /var/log/nginx.access.log ;
        
        rewrite_log on;

        
        location / {
            auth_basic           "Restricted"; ## Message shown in login
window
            auth_basic_user_file htpasswd; ## See /etc/nginx/htpassword
            index index.html index.php; ## Allow a static html file to
be shown first
            try_files $uri $uri/ @magehandler; ## If missing pass the
URI to Magento's front handler
            #try_files $uri $uri/ ; ## If missing pass the URI to
Magento's front handler
            #expires 30d; ## Assume all files are cachable
        }

        
        location ^~  /. { ## Disable .htaccess and other hidden files
            return 404;
        }

        location @magehandler { ## Magento uses a common front handler
            #rewrite / /index.php;
            rewrite ^(.*) index.php$1 last;
        }

        #The more-specific regex are at the top.
        #The regex's are evaluated in the order in which they appear.
        location ~ .php$ { ## Execute PHP scripts
            #if (!-e $request_filename) { rewrite / /index.php last; }
## Catch 404s that try_files miss
                proxy_read_timeout 120;
                proxy_connect_timeout 120;
            expires        off; ## Do not cache dynamic content
            fastcgi_pass   127.0.0.1:9000;
            #fastcgi_param  HTTPS $fastcgi_https;
            fastcgi_param  SCRIPT_FILENAME 
$document_root$fastcgi_script_name;
            fastcgi_param  MAGE_RUN_CODE default; ## Store code is
defined in administration > Configuration > Manage Stores
            fastcgi_param  MAGE_RUN_TYPE store;
            include        fastcgi_params; ## See
/etc/nginx/fastcgi_params
        }
        location ~ /(media|skin|js)/ { }
        location ~
/(tag|admin|customer|wishlist|checkout|catalog|app).*$ { #store URL
                rewrite /(.*)$ /index.php/$1 last;
        }
        
        location ~ /[a-zA-Z]+$ { #store URL
                rewrite ^/([a-zA-Z]+) ?store=$1 last;
        }
        location ~ /[a-zA-Z]+/ { #store URL
                rewrite ^/([a-zA-Z]+)(.*) /$2?store=$1 last;
        }

Posted at Nginx Forum: http://forum.nginx.org/read.php?2,229127,229127#msg-229127



More information about the nginx mailing list