SERVER_NAME and fastcgi
Igor Sysoev
igor at sysoev.ru
Thu Sep 16 11:58:30 MSD 2010
On Wed, Sep 15, 2010 at 09:34:56PM -0400, KyleChristensen wrote:
> Forgive me if this has been covered before, but I didn't see anything
> while searching.
>
> I have a server setup similar to:
>
> server {
> listen 80;
> server_name domain.com someotherdomain.com somethirddomain.com;
> rewrite "^(.*)$" http://www.domain.com$1 permanent;
> }
>
> server {
> listen 80;
> server_name www.domain.com *.domain.com;
> server_name_in_redirect off;
>
>
> }
>
> I had some issues with nginx redirecting to *.domain.com when people
> would omit a trailing / on physical directories in requests, the only
> fix I was able to ascertain was setting it up as I have mentioned.
>
> At any rate, if a client makes a request that bypasses our loadbalancer
> directly via wwwX.domain.com, it gets caught by the second server block
> as intended. The problem however is that $server_name gets set to the
> first match in the server_name directive (as mentioned in the
> documentation). My fastcgi_param for SERVER_NAME is set to $server_name
> (the default).
>
> The problem is that I need the ability to discern that someone is
> hitting a server directly via $_SERVER['SERVER_NAME'], and under this
> default configuration I am unable to do so since even direct requests to
> webservers end up having $server_name set to www.domain.com, rather than
> what the Host: was set to (wwwX.domain.com).
>
> I understand that there is also the $host variable, but I was not sure
> what the best practice is as far as reliably duplicating the SERVER_NAME
> functionality of Apache.
$server_name value is the first name in a server_name directive,
$http_host value is a value of a "Host" header line,
$host value is a value of a "Host" header line OR, if there is not
the header line, is a value of the $server_name.
--
Igor Sysoev
http://sysoev.ru/en/
More information about the nginx
mailing list