1

我在配置带有一些 url 的 nginx 反向代理时遇到了一些问题。我的配置是:

events {
      worker_connections 768;
}

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

     sendfile        on;
     keepalive_timeout  65;
     access_log /dev/stdout combined;
     error_log /dev/stdout warn;

  server {
    ssl_certificate        /opt/ssl/ca.crt;
    ssl_certificate_key    /opt/ssl/ca.key;
    listen 443 ssl;

location /api/v1/namespaces/mynamespace/services/prometheuslb/proxy/ {
          resolver 127.0.0.1 valid=30s;
          set $endpoint "http://prometheuslb.mynamespace.svc.skydns.local:9090/";
          proxy_pass $endpoint;
        }

        location /api/v1/namespaces/mynamespace/services/pushgatewaylb/proxy/ {
          resolver 127.0.0.1 valid=30s;
          set $endpoint "http://pushgatewaylb.mynamespace.svc.skydns.local:9091/";
          proxy_pass $endpoint;
        }

        location /api/v1/namespaces/mynamespace/services/cratedb/proxy/ {
          resolver 127.0.0.1 valid=30s;
          set $endpoint "http://cratedb.mynamespace.svc.skydns.local:4200/";
          proxy_pass $endpoint;
          proxy_http_version 1.1;
          proxy_set_header Connection "upgrade";
        }
}
}
  • 对于 Prometheus url,我有一个无限循环,因此页面不会加载。

  • 对于 Pushgateway,它重定向错误,因为它应该在 /api/v1/namespaces/mynamespace/services/pushgatewaylb/proxy/ 中查找样式,但它会忽略该 url 部分,例如它应该在 /api/v1/namespaces/ 中查找样式mynamespace/services/pushgatewaylb/proxy/static/jquery-2.1.4.min.js

  • 对于 cratedb,我收到此错误:资源解释为样式表,但使用 MIME 类型 text/html 传输

我可以修改现有的服务器块,但不能创建单独的服务器块。

我测试了 ping 目标并且它们工作正常,如果我不使用变量它们工作正常,但我需要使用解析器的变量,因为即使端点不可用,我们也需要 nginx 启动正常。

我该如何解决这些错误?谢谢你。

编辑1:

非常感谢@Richard Smith 的回复,我不是 nginx 专家,非常感谢您的帮助:新配置:

location ~ ^/api/v1/namespaces/mynamespace/services/prometheuslb/proxy(/.*)$ {
          resolver 127.0.0.1 valid=30s;
          set $endpoint "http://prometheuslb.mynamespace.svc.skydns.local:9090";
          proxy_pass $endpoint$1;
        }

        location ~ ^/api/v1/namespaces/mynamespace/services/pushgatewaylb/proxy(/.*)$ {
          resolver 127.0.0.1 valid=30s;
          set $endpoint "http://pushgatewaylb.mynamespace.svc.skydns.local:9091";
          proxy_pass $endpoint$1;
        }

        location ~ ^/api/v1/namespaces/mynamespace/services/cratedb/proxy(/.*)$ {
          resolver 127.0.0.1 valid=30s;
          set $endpoint "http://cratedb.mynamespace.svc.skydns.local:4200";
          proxy_pass $endpoint$1;
          proxy_http_version 1.1;
          proxy_set_header Connection "upgrade";
        }

修复 cratedb 样式错误和 Prometheus 无限循环。

现在我在普罗米修斯检查浏览器时有其他错误说 GET https://domain/api/v1/namespaces/clautagsfed/services/prometheuslb/proxy/api/v1/query?query=time()&_=1541522597396 400 (Bad要求) ,

所以似乎配置中缺少一些东西(没有变量它可以正常工作)。

关于 Pushgateway 与上面解释的问题相同,它应该在 /api/v1/namespaces/mynamespace/services/pushgatewaylb/proxy/static/jquery-2.1.4.min.js 中看起来像样式,但它在 jquery-2.1.4 中看起来.min.js

谢谢

4

1 回答 1

2

使用变量时,proxy_pass指令的行为会发生变化。基本上,如果您指定一个 URI,则需要指定完整的 URI。有关详细信息,请参阅此文档

  • /$endpoint变量中删除尾随
  • 使用rewrite...break语句翻译 URI,或者将您的位置转换为正则表达式并使用捕获

例如:

location ~ ^/api/v1/namespaces/mynamespace/services/prometheuslb/proxy(/.*)$ {
    resolver 127.0.0.1 valid=30s;
    set $endpoint "http://prometheuslb.mynamespace.svc.skydns.local:9090";
    proxy_pass $endpoint$1$is_args$args;
}
于 2018-11-06T15:15:57.310 回答