Nginx Ingress 404 в браузере

Создал Ingress для моего приложения для реагирования, размещенного в контейнере докеров nginx.

Конфигурация входа

apiVersion: networking.k8s.io/v1beta1
kind: Ingress
metadata:
  name: my-ingress
  labels:
    helm.sh/chart: home-service
    app.kubernetes.io/name: home-service
    app.kubernetes.io/instance: xrayed-vulture
    app.kubernetes.io/version: "1.0.0"
    app.kubernetes.io/managed-by: Tiller
  annotations:
    kubernetes.io/ingress.class: nginx
    nginx.ingress.kubernetes.io/rewrite-target: /
spec:
  rules:
    - host: "home-service.net"
      http:
        paths:
          - path: "/pmr"
            backend:
              serviceName: my-service
              servicePort: 8089

Услуга

apiVersion: v1
kind: Service
metadata:
  name: my-service
  labels:
    helm.sh/chart: home-service
    app.kubernetes.io/name: home-service
    app.kubernetes.io/instance: xrayed-vulture
    app.kubernetes.io/version: "1.0.0"
    app.kubernetes.io/managed-by: Tiller
spec:
  type: ClusterIP
  ports:
    - port: 8089
      targetPort: 8089
      protocol: TCP
      name: http
    - port: 443
      targetPort: https
      protocol: TCP
      name: https
  selector:
    app.kubernetes.io/name: pmr-ui-app

Конфигурация Nginx /etc/nginx/conf.d/default.conf в моем приложении-реакции, которое размещено в контейнере nginx: stable-alpine.

server {
        listen 8089;
        listen 443 default ssl;
        server_name localhost;

        root   /usr/share/nginx/html;

        ssl_certificate /etc/nginx/certs/nginx.crt;
        ssl_certificate_key /etc/nginx/certs/nginx.key;
        ssl_protocols        SSLv3 TLSv1;
        ssl_ciphers          HIGH:!aNULL:!MD5;

        location / {
            root   /usr/share/nginx/html;
            index  index.html index.htm;
            try_files $uri /index.html;
        }

        error_page 404 /404.html;

        # redirect server error pages to the static page /50x.html
        error_page   500 502 503 504  /50x.html;
        location = /50x.html {
            root   /usr/share/nginx/html;
        }

        access_log /var/log/nginx/access.log main;
        error_log   /var/log/nginx/error.log  warn;
}

Выполняя вызов curl на адрес взрыва, вход работает нормально и возвращает правильную страницу

curl -v http://home-service.net/pmr


message from my nginx controller container
10.251.128.1 - - [02/Sep/2020:16:33:30 +0000] "GET /pmr HTTP/1.1" 200 3009 "-" "curl/7.64.0" 103 0.002 [nc-my-service-8089] [] 10.x.x.26:8089 3009 0.000 200 e2407a01ffcf7607b958522574979b29

message from the react app container itself
10.x.x.27 - - [02/Sep/2020:16:33:30 +0000] "GET /pmr HTTP/1.1" 200 3009 "-" "curl/7.64.0" "10.251.128.1"

Но зайдя в браузер, я вижу 404 для загрузки некоторых файлов .js и css.

Chrome с http://home-service.net/pmr

Nginx controller logs
10.x.x.198 - - [02/Sep/2020:14:45:36 +0000] "GET /pmr HTTP/1.1" 304 0 "-" "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/83.0.4103.116 Safari/537.36" 611 0.001 [nc-my-service-8089] [] 10.x.x.26:8089 0 0.000 304 f994cdb21f962002e73ce6d967f82550

10.x.x.200 - - [02/Sep/2020:14:51:11 +0000] "GET /wf-bridge/wf-bridge/wf-bridge.esm.js HTTP/1.1" 404 21 "http://home-service.net/pmr" "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/83.0.4103.116 Safari/537.36" 495 0.001 [upstream-default-backend] [] 10.x.x.18:8080 21 0.000 404 0ba3519a8f55673cdcbb391d6102609a
10.x.x.1 - - [02/Sep/2020:14:51:11 +0000] "GET /static/js/2.ae30464f.chunk.js HTTP/1.1" 404 21 "http://home-service.net/pmr" "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/83.0.4103.116 Safari/537.36" 435 0.001 [upstream-default-backend] [] 10.x.x.18:8080 21 0.000 404 b01b7b33a961df5be413f10ec14909c1
10.x.x.198 - - [02/Sep/2020:14:51:11 +0000] "GET /static/js/main.d76be073.chunk.js HTTP/1.1" 404 21 "http://home-service.net/pmr" "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/83.0.4103.116 Safari/537.36" 438 0.000 [upstream-default-backend] [] 10.x.x.18:8080 21 0.000 404 c333c6dca261a75133944c6e308874af
10.210.x.200 - - [02/Sep/2020:14:51:11 +0000] "GET /static/css/main.9d650a52.chunk.css HTTP/1.1" 404 21 "http://home-service.net/pmr" "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/83.0.4103.116 Safari/537.36" 455 0.000 [upstream-default-backend] [] 10.x.x.18:8080 21 0.000 404 0d8a5a6aa7d549294fcb1c147dd01294
10.x.x.198 - - [02/Sep/2020:14:51:11 +0000] "GET /static/js/2.ae30464f.chunk.js HTTP/1.1" 404 21 "http://kda9dc8056pmr01.aks.azure.ubsdev.net/pmr" "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/83.0.4103.116 Safari/537.36" 435 0.000 [upstream-default-backend] [] 10.x.x.18:8080 21 0.000 404 1d8ee795cfa4e52225cf51e9fc1989d6
10.x.x.198 - - [02/Sep/2020:14:51:11 +0000] "GET /static/js/main.d76be073.chunk.js HTTP/1.1" 404 21 "http://home-service.net/pmr" "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/83.0.4103.116 Safari/537.36" 438 0.001 [upstream-default-backend] [] 10.x.x.18:8080 21 0.004 404 a0952e173bfb58f418f5d600e377f18c

React Nginx container will recieve the request with 200 like this
10.x.x.25 - - [02/Sep/2020:14:25:27 +0000] "GET / HTTP/1.1" 200 3009 "-" "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/83.0.4103.116 Safari/537.36" "10.210.62.200"

Почему все запросы не обрабатываются одним my-service, а файлы css и .js обрабатываются upstream-default-backend, что приводит к 404?

Версия контроллера входящего трафика Nginx: nginx-ingress-controller:0.26.1


person Buba Conteh    schedule 02.09.2020    source источник
comment
Файлы JS и CSS имеют абсолютный путь вместо относительного.   -  person lakshman.pasala    schedule 02.09.2020
comment
@ lakshman.pasala Я заметил это, но если я создам службу nodeport, я могу добраться до сайта, и он будет полностью отображен со всеми загруженными css и js. Это происходит только с входной конечной точкой. Эта ссылка stackoverflow.com/questions/50871970/ тоже не помогает   -  person Buba Conteh    schedule 03.09.2020


Ответы (1)


Ваши ресурсы отображаются с корневым путем /static. Это отдельный HTTP-запрос, и он получит серверную часть по умолчанию, поскольку он не удовлетворяет вашему правилу /pmr пути. Для правильной работы обратного прокси-сервера следует использовать относительные пути внутри веб-приложения. Например, удалите корневой каталог / и просто используйте static/css/main.css. Или используйте правило имени хоста вместо правил пути.

person Faheem    schedule 03.09.2020