为Kubernetes Traefik Ingress配置每个服务的不同路径重写

时间:2018-08-13 12:35:14

标签: nginx kubernetes traefik kubernetes-ingress traefik-ingress

我正在将我们的应用程序从单实例Docker-compose配置迁移到Kubernetes。目前,我有以下示例NGINX配置,作为我的应用程序的反向代理运行:

column - y axis

}

我对反向代理部分的最初计划是使用NGINX入口控制器实现一个入口,但是我看到我的配置只能使用NGINX Plus创建为入口。这就是为什么我决定尝试使用Traefik的原因,但是我不确定是否仍然可以对每个服务的路径进行不同的重写。

我尝试了以下Ingress配置,但似乎不起作用:

server {
  server_name             example.com;
  ssl_certificate         /etc/nginx/certs/${CERT_NAME};
  ssl_certificate_key     /etc/nginx/certs/${KEY_NAME};

  listen                  443 ssl;
  keepalive_timeout       70;

  access_log              /var/log/nginx/access.log mtail;

  ssl_protocols           xxxxxx
  ssl_ciphers             xxxxxx
  ssl_session_cache       shared:SSL:10m;
  ssl_session_timeout     10m;

  rewrite_log             on;
  resolver                127.0.0.11 ipv6=off;

  location /push/ {
        auth_basic                    "Restricted";
        auth_basic_user_file          /etc/nginx/htpasswd;
        rewrite /push/(.*)        /index.php/$1 break;
        proxy_pass                    pushinterface:3080;
  }

  location /flights/ {
        rewrite /flights/(.*)         /$1 break;
        proxy_pass                    flightstats:3090;
  }

  location /api/ {
        proxy_pass                    $api;
  }

  location /grafana/ {
        access_log                    off;
        log_not_found                 off;
        proxy_pass                    http://grafana:3000;
        rewrite ^/grafana/(.*)        /$1 break;
  }

感谢您为解决该任务提供的帮助

2 个答案:

答案 0 :(得分:1)

在示例中使用ReplacePathRegex规则类型不能保证传入的请求将被转发到目标后端,如Traefik Documentation中所述。

为了将请求路由到端点,请使用Matcher而不是Modifiers规则,因为它们是为此目的而设计的。

分别针对类似问题here进行讨论。

答案 1 :(得分:1)

经过数小时未能成功解决问题的尝试,我使用Nginx入口控制器完成了该任务,效果很好!这是入口配置:

apiVersion: extensions/v1beta1
kind: Ingress
metadata:
  annotations:
    nginx.ingress.kubernetes.io/configuration-snippet: |
      rewrite /push/(.*) /index/$1 break;
      rewrite /flights/(.*) /$1 break;
      rewrite /grafana/(.*) /$1 break;

spec:
  rules:
  - host: example.com
    http:
      paths:
      - backend:
          serviceName: pushinterface
          servicePort: 80
        path: /push
      - backend:
          serviceName: flights
          servicePort: 80
        path: /flights
       - backend:
          serviceName: api
          servicePort: 80
        path: /api
      - backend:
          serviceName: grafana
          servicePort: 80
        path: /grafana

感谢大家的回答! :)