我正在尝试创建一个入口控制器,该控制器指向我通过NodePort公开的服务。
以下是ingress控制器的yaml文件(取自https://kubernetes.io/docs/tasks/access-application-cluster/ingress-minikube/):
apiVersion: networking.k8s.io/v1beta1
kind: Ingress
metadata:
name: example-ingress
spec:
rules:
- host: hello-world.info
http:
paths:
- path: /
backend:
serviceName: appName
servicePort: 80
我可以直接连接到节点端口,并显示前端。
请注意,我这样做是因为前端应用程序无法连接到我创建的其他部署,并且我读到入口控制器可以解决这个问题。我还需要添加Nginx反向代理吗?如果是的话,我该怎么做?我曾尝试将其添加到nginx配置文件中,但没有成功。
location /middleware/ {
proxy_pass http://middleware/;
}
必须使用正确的主机名才能到达Ingress
对象中定义的路由。更新/etc/hosts
文件或使用curl -H "hello-world.info" localhost
type命令。或者,您可以删除host
映射,并将所有流量重定向到一个默认服务。
apiVersion: networking.k8s.io/v1beta1
kind: Ingress
metadata:
name: example-ingress
spec:
rules:
- http:
paths:
- path: /
backend:
serviceName: appName
servicePort: 80