spring-boot - 每个 HTTPS 入口请求的 404 NOT FOUND 响应
问题描述
我在 GKE 上部署了多个 Spring Boot 应用程序。每个 Spring Boot 都启用且不受限制的执行器端点。我创建了一个 HTTPS 入口,但只收到 404 Not Found 响应。
入口 YAML:
apiVersion: extensions/v1beta1
kind: Ingress
metadata:
annotations:
ingress.gcp.kubernetes.io/pre-shared-cert: mcrt-0c6bff90-d2fa-4a14-84b5-779c812a4c0b
ingress.kubernetes.io/backends: '{"k8s-be-30206--3e15e15e4f605a79":"HEALTHY","k8s-be-31081--3e15e15e4f605a79":"HEALTHY","k8s-be-31129--3e15e15e4f605a79":"HEALTHY","k8s-be-31673--3e15e15e4f605a79":"HEALTHY","k8s-be-32006--3e15e15e4f605a79":"HEALTHY"}'
ingress.kubernetes.io/https-forwarding-rule: k8s-fws-default-skitter-ingress--3e15e15e4f605a79
ingress.kubernetes.io/https-target-proxy: k8s-tps-default-skitter-ingress--3e15e15e4f605a79
ingress.kubernetes.io/ssl-cert: mcrt-0c6bff90-d2fa-4a14-84b5-779c812a4c0b
ingress.kubernetes.io/url-map: k8s-um-default-skitter-ingress--3e15e15e4f605a79
kubectl.kubernetes.io/last-applied-configuration: |
{"apiVersion":"extensions/v1beta1","kind":"Ingress","metadata":{"annotations":{"kubernetes.io/ingress.allow-http":"false","kubernetes.io/ingress.global-static-ip-name":"skitter-ip","networking.gke.io/managed-certificates":"skitterapp.com"},"name":"skitter-ingress","namespace":"default"},"spec":{"rules":[{"host":"skitterapp.com","http":{"paths":[{"backend":{"serviceName":"business-owner-service","servicePort":80},"path":"/business-owner-service/*"},{"backend":{"serviceName":"customer-service","servicePort":80},"path":"/customer-service/*"},{"backend":{"serviceName":"staff-service","servicePort":80},"path":"/staff-service/*"},{"backend":{"serviceName":"sms-service","servicePort":80},"path":"/sms-service/*"}]}}]}}
kubernetes.io/ingress.allow-http: "false"
kubernetes.io/ingress.global-static-ip-name: skitter-ip
networking.gke.io/managed-certificates: skitterapp.com
creationTimestamp: "2020-09-20T12:10:35Z"
finalizers:
- networking.gke.io/ingress-finalizer
generation: 3
name: skitter-ingress
namespace: default
resourceVersion: "11344191"
selfLink: /apis/extensions/v1beta1/namespaces/default/ingresses/skitter-ingress
uid: 6b92ff0d-01a2-449f-9cd7-afdd1452e73b
spec:
rules:
- host: skitterapp.com
http:
paths:
- backend:
serviceName: business-owner-service
servicePort: 80
path: /business-owner-service/*
- backend:
serviceName: customer-service
servicePort: 80
path: /customer-service/*
- backend:
serviceName: staff-service
servicePort: 80
path: /staff-service/*
- backend:
serviceName: sms-service
servicePort: 80
path: /sms-service/*
status:
loadBalancer:
ingress:
- ip: 35.241.60.223
负载均衡器详细信息(突出显示证书处于活动状态并且一切正常):
测试请求:https ://skitterapp.com/business-owner-service/actuator/health ; https://skitterapp.com/customer-service/actuator/health
我究竟做错了什么?我希望当我发送请求skitterapp.com/customer-service/actuator/health 时,入口识别/customer-service/**,并将GET 请求/actuator/health 传递给客户服务。但我没有看到这种行为,从我在日志中看到的内容来看,客户服务没有收到健康请求
解决方案
您必须在入口中添加此注释,
nginx.ingress.kubernetes.io/rewrite-target:/
可能这可以解决问题
推荐阅读
- java - Java未将数据分配给子类构造函数中的成员
- ios - iOS 构建错误:缺少文件 Icon102.png
- jsp - 给一个品种的特定汽车自己的指示 Netlogo
- java - 如何从数组中仅获取偶数行或奇数行?
- php - 子文件夹中的附加 .htaccess | 查询参数的 mod_rewrite
- php - 有没有办法在 Amazon S3 上压缩目录并在应用程序中动态下载它
- svelte - 在 Svelte 中禁用环绕链接
- linux - 如何在不同服务器上的另一个 shell 脚本中运行 shell 脚本?
- python - 在 docker 容器中安装 yfinance python 包
- tomcat - 使用 openssl 为 tomcat 生成 ssl 证书会创建 firefox 不喜欢的“DSA”