[英]Allow Azure Application Gateway to route all sub paths in AKS
我將 AKS 配置為 Azure 應用程序網關作為我的入口。
我正在嘗試將 .net 核心 Angular 應用程序部署到集群中的路徑。 我想訪問http://<cluster ip>/app1
上的應用程序。
我的 kube.netes 部署(包括入口設置)如下:
apiVersion: v1
kind: Pod
metadata:
name: web-app-1
labels:
app: web-app-1
spec:
containers:
- image: "xxx.azurecr.io/web-app-1:latest"
name: web-app-1
imagePullPolicy: Always
ports:
- containerPort: 80
protocol: TCP
---
apiVersion: v1
kind: Service
metadata:
name: web-app-1
spec:
selector:
app: web-app-1
ports:
- protocol: TCP
port: 80
targetPort: 80
---
apiVersion: extensions/v1beta1
kind: Ingress
metadata:
name: web-app-1
annotations:
kubernetes.io/ingress.class: azure/application-gateway
spec:
rules:
- http:
paths:
- path: /app1
backend:
serviceName: web-app-1
servicePort: 80
在 Angular 應用本身中,我將<base href="/" />
留在了index.html
中。 但是,我已將構建修改為ng build --base-href /app1/"
部署后,我瀏覽到http://<cluster ip>/app1
,然后它會加載 index.html 文件。 但是,它會為所有其他腳本返回 404,例如 404 on http://<cluster ip>/app1/main-es2015.9ae13a2658e759db61f5.js
問題可能出在我如何配置 Angular,但瀏覽到http://<cluster ip>/app1/index.html
返回 404 當我知道它可以僅使用/app1/
訪問時。
我認為問題在於應用程序網關沒有為/app1/
之后的任何內容正確路由請求。 我怎樣才能讓它允許子路由通過(即腳本)?
謝謝
現在開始工作了。 如果我查看 404 響應標頭,它說它來自 kestrel,因此正在訪問 dotnet 核心 api,因此需要在那里進行配置。 我所做的所有更改是:
客戶:
/
egStartup.cs
Configure
中,添加app.UsePathBase("/app1");
我在env.IsDevelopment()
的else
中這樣做。應用網關:
- path: /app1*
。 我沒有星號,所以沒有路由所有后續路線。你也可以這樣做
apiVersion: networking.k8s.io/v1
kind: Ingress
metadata:
name: appgw-ingress
annotations:
kubernetes.io/ingress.class: azure/application-gateway
appgw.ingress.kubernetes.io/backend-path-prefix: "/"
spec:
rules:
- http:
paths:
- path: /api/*
....
將路由前綴形式“/”更新為“/api/*”的位置。 特別是這個注釋
appgw.ingress.kubernetes.io/backend-path-prefix: "/"
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.