Редактирование входа Kubernetes: HTTP 400 Неправильный запрос - Простой HTTP-запрос был отправлен HTTPS
Может ли быть какая-либо причина, почему веб-приложение, которое прекрасно загружается, дает *HTTP 400 Bad request - The plain HTTP request was sent to HTTPS*
порт после того, как вход веб-приложения был отредактирован вручную или отредактирован с помощью автоматизированного задания, которое обновляет вход, изменяя IP-адреса из белого списка
По-видимому, эта проблема исправлена, когда мы повторно развернули веб-приложение после очистки развертывания веб-приложения...
Любые указатели на это были бы хороши, так как это происходит в нашей среде PROD и не воспроизводятся ни в каких более низких средах. На что следует обратить внимание:- - Настройка контроллера Nginx Ingress одинакова в нижних и расширенных средах.
apiVersion: extensions/v1beta1
kind: Ingress
metadata:
annotations:
ingress.kubernetes.io/force-ssl-redirect: "true"
ingress.kubernetes.io/ingress.allow-http: "false"
ingress.kubernetes.io/proxy-body-size: 20M
ingress.kubernetes.io/secure-backends: "true"
ingress.kubernetes.io/whitelist-source-range: xxx.yy.zz.pp/32, yyy.ss.dd.kkl/32
ingress.kubernetes.io/whitelist-source-range-status: unlocked
creationTimestamp: 2018-11-29T15:34:05Z
generation: 5
labels:
app: xyz-abc-pqr
name: xxxx-webapp-yyyy-zzzz
namespace: nspsace-name
resourceVersion: "158237270"
selfLink: /apis/extensions/v1beta1/namespaces/nspsace-name/ingresses/xxxx-webapp-yyyy-zzzz
uid: 348f892e-f3ec-11e8-aa6f-0a0340041348
spec:
rules:
- host: ssssssss.wwwwweewwerwerw.co.uk
http:
paths:
- backend:
serviceName: xxxx-webapp-yyyy-zzzz
servicePort: 443
path: /
- host: xxxx-webapp-yyyy-zzzz.bbbbv.lasdfkla.ajksdfh.ioohhsaf.pp
http:
paths:
- backend:
serviceName: xxxx-webapp-yyyy-zzzz
servicePort: 443
path: /
tls:
- hosts:
- ssssssss.wwwwweewwerwerw.co.uk
- xxxx-webapp-yyyy-zzzz.bbbbv.lasdfkla.ajksdfh.ioohhsaf.pp
secretName: xxxx-webapp-yyyy-zzzz-server-tls
status:
loadBalancer:
ingress:
- {}
1 ответ
Возможно, что-то не так с входным контроллером и тем, как он обновляет свою конфигурацию. Я предполагаю, что вы используете входной контроллер nginx, чтобы вы могли проверить конфиги до и после:
$ kubectl cp <nginx-ingress-controller-pod>:nginx.conf nginx.conf.before
$ kubectl edit ingress <your-ingress>
$ kubectl cp <nginx-ingress-controller-pod>:nginx.conf nginx.conf.after
$ diff nginx.conf.before nginx.conf.after
Вы можете увидеть, что это может произойти с nginx из-за чего-то подобного: Работа с nginx 400 "Ошибка простого HTTP-запроса на порт HTTPS".