server_name and listen behaviour
Igor Sysoev
igor at sysoev.ru
Tue Feb 12 19:32:08 UTC 2013
On Feb 12, 2013, at 23:14 , Ruslan Ermilov wrote:
> On Tue, Feb 12, 2013 at 09:10:17PM +0400, ivan babrou wrote:
>> Hi, I have a question. It's better to describe with example
>> I point one.local and two.local to 127.0.0.1 and create following servers
>> in config for nginx:
>> server {
>> listen 80;
>> server_name one.local;
>> location / {
>> return 404;
>> }
>> }
>> server {
>> listen two.local:80;
>> server_name two.local;
>> location / {
>> return 403;
>> }
>> }
>> If I request one.local then 403 is returned. If i change listen for
>> one.local to one.local:80 then 404 correctly returned, but only after
>> restart, reload doesn't help (that's probably bug too).
>> I expect to get 404 if i request one.local even if I listen on all
>> addresses. Am I right?
>
> 127.0.0.1:80 and *:80 are two different socket addresses,
> and when you connect to 127.0.0.1:80, the first one will
> be used (two.local in your case). This is not specific
> to nginx, it's how sockets work.
>
> nginx by default optimizes such a config by creating only
> one listening socket [1], and pessimizes by using getsockaddr()
> to differentiate between multiple sockaddrs. This optimization
> can be turned off by using "bind" parameter (or some other
> parameters, see [1] for details). Nevertheless, 127.0.0.1:80
> and *:80 are still two different addresses, and 127.0.0.1:80
> is more specific than *:80.
>
> As to "reload not working", I cannot reproduce this:
>
> (in my config I always return 200 with "$server_name")
>
> $ echo 'GET http://one:8000/' | nc 127.0.0.1 8000
> two.local
>
> # here config was changed to listen on 127.0.0.1:80
> # instead of *:80 for one.local
>
> # reload (kill -HUP nginx master process)
>
> $ kill -HUP 33122
> $ echo 'GET http://one:8000/' | nc 127.0.0.1 8000
> one.local
>
> [1] http://nginx.org/r/listen
I believe on Linux you cannot use
listen *:80 bind;
listen 127.0.0.1:80 bind;
--
Igor Sysoev
http://nginx.com/support.html
More information about the nginx-devel
mailing list