Como posso configurar locais nginx para compartilhar opções de configuração comuns?

37

Como posso configurar um bloco de configuração compartilhado para um conjunto de locais?

    location / {

            proxy_pass        http://127.0.0.1:9000/;
            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;

            proxy_cache cache-test;
            proxy_cache_valid 200 302 24h;
            proxy_cache_valid 404 60s;
            add_header X-Cache-Status $upstream_cache_status;

    }


    location /api/0.1/user{
            proxy_cache_key /user/$http_authorization;
    }

Agora, se eu tentar acessar /api/0.1/usuário, recebo 404 porque ele não passa a solicitação para 127.0.0.1:9000

    
por netbrain 26.03.2012 / 20:56

2 respostas

47

Crie uma configuração de proxy comum e inclua conforme necessário.

/etc/nginx/api_proxy.conf

proxy_pass        http://127.0.0.1:9000/;
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;

proxy_cache cache-test;
proxy_cache_valid 200 302 24h;
proxy_cache_valid 404 60s;
add_header X-Cache-Status $upstream_cache_status;

Seu arquivo de configuração do host

...
location /api/0.1/user {
    include /etc/nginx/api_proxy.conf;
    proxy_cache_key /user/$http_authorization;
}
...
    
por 27.03.2012 / 00:40
11

A maioria das variáveis de configuração proxy_ * também é permitida no contexto do servidor, portanto você pode movê-las para compartilhar as mesmas configurações em vários locais.

No entanto, proxy_pass deve ser usado apenas dentro da localização. Portanto, você deve ter pelo menos essa diretiva em cada local, opcionalmente substituindo valores de alguns proxy_ * vars extras.

    
por 26.03.2012 / 22:10