常见的原因是规则设置不正确,需要检查规则是否正确匹配了目标服务。以下是一个示例:
apiVersion: apps/v1
kind: Deployment
metadata:
name: myapp
labels:
app: myapp
spec:
selector:
matchLabels:
app: myapp
replicas: 2
template:
metadata:
labels:
app: myapp
spec:
containers:
- name: myapp-ctr
image: myapp:v1
ports:
- containerPort: 8080
---
apiVersion: v1
kind: Service
metadata:
name: myapp-svc
spec:
selector:
app: myapp
ports:
- name: http
port: 80
targetPort: 8080
---
apiVersion: networking.k8s.io/v1
kind: Ingress
metadata:
name: myapp-ing
spec:
rules:
- http:
paths:
- path: /myapp
pathType: Prefix
backend:
service:
name: myapp-svc
port:
name: http
检查规则是否正确匹配了目标服务,例如,在这个示例中,Ingress 路径规则“/myapp”应该匹配 Deployment 名称为“myapp”的 Pod。
如果规则的路径部分设置为“/”,则应该将 Ingress 路径部分设置为“/”,而不是“/*”。例如,以下规则将匹配所有以“/”开头的路径:
apiVersion: networking.k8s.io/v1
kind: Ingress
metadata:
name: myapp-ing
spec:
rules:
- http:
paths:
- path: /
backend:
service:
name: myapp-svc
port:
name: http
apiVersion: networking.k8s.io/v1
kind: Ingress
metadata:
name: myapp-ing
annotations:
nginx.ingress.kubernetes.io/default-backend: default-backend
spec:
rules:
- http:
paths:
- path: /
backend:
service:
name: myapp-svc
port:
name: http
kubectl describe ingress myapp-ing