2016-08-02 37 views
0

Ich habe Nginx als Reverse-Proxy für einige Anwendungsserver wie so konfiguriert, aber es gibt eine Menge doppelten Code dort (mit Ausnahme der Proxy_pass-Leitung). Gibt es eine Möglichkeit, die Zeilen proxy_redirect und proxy_set_header in einen gemeinsamen Block zu verschieben und nur für jeden Standortblock zu referenzieren?Nginx config wiederverwendbare Blöcke

nginx.conf:

location ^~ /users { 
      proxy_pass http://192.168.0.1:5001; 
      proxy_redirect http://api.example.com https://api.example.com; 
      proxy_set_header Host $host; 
      proxy_set_header X-Real-IP $remote_addr; 
      proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; 
      proxy_set_header X-Forwarded-Proto https; 
} 

location ^~ /users/verify { 
      proxy_pass http://192.168.0.1:5002; 
      proxy_redirect http://api.example.com https://api.example.com; 
      proxy_set_header Host $host; 
      proxy_set_header X-Real-IP $remote_addr; 
      proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; 
      proxy_set_header X-Forwarded-Proto https; 
} 

Antwort

0

Sicher. Sie können wie so in Ihrem http Block Ihrer Config dies tun:

http { 
    include  /etc/nginx/mime.types; 
    default_type application/octet-stream; 

    log_format main '$remote_addr - $remote_user [$time_local] "$request" ' 
        '$status $body_bytes_sent "$http_referer" ' 
        '"$http_user_agent" "$http_x_forwarded_for"'; 

    #Rest of your config 

    #Proxy settings 
    proxy_redirect http://api.example.com https://api.example.com; 
    proxy_set_header Host $host; 
    proxy_set_header X-Real-IP $remote_addr; 
    proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; 
    proxy_set_header X-Forwarded-Proto https; 

    include /etc/nginx/conf.d/*.conf; 
} 

Beachten Sie, dass diese Einstellungen "global" sein würde.