Служба ранчо:
$ kubectl get svc
NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE
rancher ClusterIP 10.10.17.245 <none> 80/TCP,443/TCP 1h
Служба входного контроллера:
NAMESPACE NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE
nginx-ingress nginx-ingress LoadBalancer 10.10.15.181 <ext-IP> 80:30324/TCP,443:31022/TCP 3h
Роль входа:
apiVersion: extensions/v1beta1
kind: Ingress
metadata:
name: rancher-ing
annotations:
kubernetes.io/ingress.class: "rancher"
spec:
rules:
- host: api.sample.com
http:
paths:
- path: /
backend:
serviceName: rancher
servicePort: 443
Вход:
$ kubectl get ingress
NAME HOSTS ADDRESS PORTS AGE
rancher api.sample.com 80 19s
Когда я пытаюсь связаться с администратором ранчо по внешнему IP-адресу входящего контроллера:
$ curl http://api.sample.com
В качестве ответа у меня есть не закодированная строка.Если я сделаю это через веб-браузер, эта строка будет загружена, и у меня получится 404.
Аналогичная роль для некоторой случайной службы через http (без https) работает нормально, так что это не проблема неправильной конфигурации входного контроллера.