Nginx возвращает статус 400 при использовании kubernetes ingress - PullRequest
0 голосов
/ 09 апреля 2019

Я настраиваю развертывание контейнеров с помощью внутреннего сервера и сервера сокетов. Когда я пытаюсь подключиться к моей конечной точке веб-сервера, все в порядке, но при подключении к конечной точке сервера сокетов она возвращает 400

Я следил за несколькими темами, такими как: рукопожатие WebSocket: неожиданный код ответа: 400 в kubernetes-ingress

Но добавление аннотации к WebSocket-сервисам и таймауту прокси не работает.

Когда я портирую вперед модуль развертывания, он работает нормально. Таким образом, проблема должна заключаться во входном контроллере nginx.

apiVersion: extensions/v1beta1
kind: Ingress
metadata:
  name: ingress
  namespace: {{ include "namespace" . }}
  labels:
    helm.sh/chart: {{ include "chartname" . }}
    app.kubernetes.io/managed-by: {{ .Release.Service }}
    app.kubernetes.io/stage: {{ .Values.stage }}
  annotations:
    kubernetes.io/ingress.class: "nginx"
    nginx.ingress.kubernetes.io/proxy-read-timeout: "3600"
    nginx.ingress.kubernetes.io/proxy-send-timeout: "3600"
spec:
  tls:
  - secretName: tls-certificate
    hosts:
    {{ range .Values.hosts }}
    - {{ . | quote }}
    {{ end }}
  rules:
  - host: mydomain.tk
    http:
      paths:
        - path: /
          backend:
            serviceName: web
            servicePort: http
        - path: /socket
          backend:
            serviceName: web
            servicePort: socket

А вот мой файл service.yml:

apiVersion: v1
kind: Service
metadata:
  name: web
  namespace: {{ include "namespace" . }}
  labels:
    helm.sh/chart: {{ include "chartname" . }}
    app.kubernetes.io/managed-by: {{ .Release.Service }}
    app.kubernetes.io/stage: {{ .Values.stage }}
spec:
  type: NodePort
  sessionAffinity: ClientIP
  ports:
  - port: {{ .Values.web.port }}
    targetPort: http
    protocol: TCP
    name: http
  - port: {{ .Values.web.socket }}
    targetPort: socket
    protocol: TCP
    name: socket
  selector:
    name: web

Независимо от того, что я делаю, мне всегда возвращают 400 на конечной точке / socket.

В настоящее время я использую последнюю версию nginx ingress и GKE версии 1.11.7

Выходной сигнал:

Name:             ingress
Namespace:        backend
Address:
Default backend:  default-http-backend:80 (10.48.0.9:8080)
TLS:
  tls-certificate terminates mydomain.tk
Rules:
  Host     Path  Backends
  ----     ----  --------
  mydomain.tk
           /         web:http (10.48.0.28:8080)
           /socket   web:socket (10.48.0.28:9092)
Annotations:
  kubernetes.io/ingress.class:                     nginx
  nginx.ingress.kubernetes.io/proxy-read-timeout:  3600
  nginx.ingress.kubernetes.io/proxy-send-timeout:  3600
Events:
  Type    Reason  Age   From                      Message
  ----    ------  ----  ----                      -------
  Normal  CREATE  13s   nginx-ingress-controller  Ingress backend/ingress

1 Ответ

0 голосов
/ 11 апреля 2019

Я решил проблему, добавив к своим приложениям заголовки перекрестного происхождения.

...