gpt4 book ai didi

kubernetes gce 入口路径通配符不是代理正确的 uri(在容器内工作)

转载 作者:行者123 更新时间:2023-12-03 01:15:58 26 4
gpt4 key购买 nike

无法通过某些 slugs curl /使用 REST API 的原因是什么,即 example.com/application/v2/xxxx。我使用的 docker 镜像是来自的应用程序 http://vespa.ai/ https://github.com/vespa-engine/docker-image/blob/master/Dockerfile

我已经正确设置了节点端口和入口

我尝试了各种方法,例如主机上的默认后端:

- host: example.com
http:
paths:
- backend:
serviceName: myservice
servicePort: 19071

或显式使用通配符路由:

 - host: example.com
http:
paths:
- path: /*
backend:
serviceName: myservice
servicePort: 19071

奇怪的是,在外部(集群外)执行curl: curl -s --头http://example.com/ApplicationStatus是否返回 statusCode 200 OK

正在做 curl -s --头http://example.com/application/v2/tenant/从应用程序返回 BAD_REQUEST。

“错误代码”:“BAD_REQUEST”,“消息”:“http://example.com/application/v2/tenant/

exec 进入容器并执行 curl -s --头http://localhost:19071/application/v2/tenant/作品..

因此,要么应用程序以某种方式与来自入口的主机名不正确匹配,要么存在完整 uri 未被代理的其他问题。

该应用程序的源代码太大,目前对我来说无法理解,但可以查看源代码 https://github.com/vespa-engine/vespa/blob/f76406b88df47f6bdbf9d24feda4c9ff55c63e06/orchestrator/src/main/java/com/yahoo/vespa/orchestrator/resources/HostSuspensionResource.java它可以解释为什么它返回错误消息。

其他一切似乎都正常,配置服务器和应用程序。

这里的问题可能是应用程序本身还是 kubernetes 造成的?

最佳答案

我认为这里不应该涉及HostSuspensionResource。 restapi 入口点是您正在进行的调用的 ApplicationHandler 类。

当您使用默认端口(即不是“内部”19071 端口) curl 到容器内时会发生什么?

关于kubernetes gce 入口路径通配符不是代理正确的 uri(在容器内工作),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47956738/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com