Я устанавливаю nginx ingress на кластере k8s, возникла неразрешимая проблема на входном маршруте.
В кластере k8s есть 3 серверных службы: 2 службы nginx и 1 служба neo4j.
Мой вход описывает информацию следующим образом:
[root@es3 cafe_ingress]# kubectl describe ingress cafe-ingress
Name: cafe-ingress
Namespace: default
Address: 192.168.59.155
Default backend: default-http-backend:80 (<error: endpoints "default-http-backend" not found>)
TLS:
cafe-secret terminates cafe.example.com
Rules:
Host Path Backends
---- ---- --------
cafe.example.com
/tea tea-svc:80 (10.244.0.25:80,10.244.1.11:80,10.244.2.15:80)
/coffee coffee-svc:80 (10.244.0.24:80,10.244.2.14:80)
/neo4j neo4j-v1-service:7474 (10.244.0.29:7474)
Annotations: Events:
Type Reason Age From Message
---- ------ ---- ---- -------
Normal CREATE 22m nginx-ingress-controller Ingress default/cafe-ingress
Normal UPDATE 5s (x3 over 22m) nginx-ingress-controller Ingress default/cafe-ingress
И, я обращаюсь к сервису tea
или coffee
, этот вход по маршруту coffee
или tea
работает правильно, я могу получить ответ от сервиса tea
или coffee
в браузере:
Однако, где доступ к neo4j
, я не могу получить ответ:
Из выходных сообщений модуля nginx-ingress-controller
получен код 404, следуйте:
2020-12-17T07:28:10.861510393Z 10.244.0.0 - - [17/Dec/2020:07:28:10 +0000] "GET /neo4j HTTP/1.1" 404 0 "-" "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/86.0.4240.75 Safari/537.36" 480 0.004 [default-neo4j-v1-service-7474] [] 10.244.0.29:7474 0 0.005 404 17a02ccd8a65d5ff396c78e819f3c4cc
Однако, когда я обращаюсь к neo4j service
, выполняю командную строку curl 10.244.0.29:7474
(URL-адрес модуля) или curl 10.0.0.100:7474
(URL-адрес службы), я могу получить ответ:
[root@es3 cafe_ingress]# curl 10.244.0.29:7474
{
"bolt_routing" : "neo4j://10.244.0.29:7687",
"transaction" : "http://10.244.0.29:7474/db/{databaseName}/tx",
"bolt_direct" : "bolt://10.244.0.29:7687",
"neo4j_version" : "4.2.1",
"neo4j_edition" : "community"
}[root@es3 cafe_ingress]# curl 10.0.0.100:7474
{
"bolt_routing" : "neo4j://10.0.0.100:7687",
"transaction" : "http://10.0.0.100:7474/db/{databaseName}/tx",
"bolt_direct" : "bolt://10.0.0.100:7687",
"neo4j_version" : "4.2.1",
"neo4j_edition" : "community"
}
Как я могу решить эту проблему? Надеемся на вашу помощь, спасибо!
да, бэкэнд-модуль neo4j без ресурса /neo4j
, поэтому запрос получает 404
код. Спасибо ! Я исправляю эту проблему, изменяя конфигурацию моего входа. Смотрите следующий ответ.
Проблема устранена.
Причиной проблемы является внутренняя служба neo4j
отсутствующего ресурса на пути /neo4j
.
Есть проблемная конфигурация моего входа:
apiVersion: extensions/v1beta1
kind: Ingress
metadata:
name: cafe-ingress
spec:
rules:
- host: cafe.example.com
http:
paths:
- path: /tea
backend:
serviceName: tea-svc
servicePort: 80
- path: /coffee
backend:
serviceName: coffee-svc
servicePort: 80
- path: /neo4j
backend:
serviceName: neo4j-v1-service
servicePort: 7474
А затем перенастройте его, сделайте так, чтобы у него был домен владельца, укажите /
на сервис neo4j
, он работает правильно.
Новая конфигурация входа выглядит следующим образом:
apiVersion: extensions/v1beta1
kind: Ingress
metadata:
name: cafe-ingress
spec:
# tls:
# - hosts:
# - cafe.example.com
# secretName: cafe-secret
rules:
- host: cafe.example.com
http:
paths:
- path: /tea
backend:
serviceName: tea-svc
servicePort: 80
- path: /coffee
backend:
serviceName: coffee-svc
servicePort: 80
- host: neo4j.xxx.com
http:
paths:
- path: /
backend:
serviceName: neo4j-v1-service
servicePort: 7474
Вы уверены, что ваш сервер
Pod
обслуживает контент на/neo4j
, а не на/
? Не могли бы вы поделиться своим определением входящего ресурса?