当前位置: 首页 > 知识库问答 >
问题:

后端 - externalTrafficPolicy为local的时候,访问k8s集群的外部流量 一定会落在 有被访问服务pod的Node节点上吗?

安明亮
2024-04-28

关于 K8s中的external-traffic-policy是 在下面的这篇文章中 提到了 值为local的情况
https://blog.csdn.net/agonie201218/article/details/122215040

问题: 如果值为local,外部流量到达某一个Node节点, 这个Node节点本身可能并不包含被访问服务的Pod吧?此时因为设置了local,又不让转发,岂不是本地请求就失败了?

备注参考:
https://kubernetes.io/zh-cn/docs/tasks/access-application-clu...

共有1个答案

简景焕
2024-04-28

你说的并没有错,但是一般的外部负载均衡器,如阿里云的clb,当你把local类型的loadblance服务绑定到clb时,clb只会把请求路由到部署了pod的node节点上,你可以把clb想象成一个nginx,node想象成一组upstream,clb会动态管理upstream的配置。

 类似资料:
  • 我正在尝试访问库伯内特斯集群部署的Spring Boot微服务并尝试测试REST API。我在部署脚本中配置了节点端口方法。但是当我尝试使用Postman工具访问时,我只得到“无法获得任何响应”的响应。 我配置了服务。yaml脚本类似于以下结构, 我的部署。yaml如下所示:, 当我使用时,输出如下所示, 我正在尝试通过以下方式访问我部署的API, 更新 当我为我的部署运行命令时,我得到如下响应:

  • 是否可以使用serviceaccount令牌获得k8s群集访问权限? 我的脚本没有访问kubeconfig文件的权限,但是,它可以访问/var/run/secrets/kubernetes处的服务帐户令牌。io/serviceaccount/token。 以下是我尝试过的步骤,但不起作用。 kubectl配置设置凭据sa用户--令牌=$(cat/var/run/secrets/kubernetes

  • 前面几节讲到如何访问kubneretes集群,本文主要讲解访问kubenretes中的Pod和Serivce的几种方式,包括如下几种: hostNetwork hostPort NodePort LoadBalancer Ingress 说是暴露Pod其实跟暴露Service是一回事,因为Pod就是Service的backend。 hostNetwork: true 这是一种直接定义Pod网络的方

  • 我搭建了一个 minikube 环境 pod 和 service、ingress 的声明如下: 然后应用他们 查看 pod 状态正常 查看 services 状态正常 查看 ingress 状态正常 修改本地的 /etc/hosts 我的 minikube 的 ip 就是 192.168.49.2 然后从宿主机访问, 但是连接失败 然后我把 ClusterIP 改成 NodePort 却可以 然后

  • 我正在尝试在minikube(Windows-10)上部署简单的spring boot REST服务。下面是我的配置 Docker文件 docker image运行良好,我能够运行该应用程序。 部署 服务 我无法使用< code > service-IP:node port/Uri < br > http://127 . 0 . 0 . 1:30008/hello访问restendpoint ht

  • 在 Kubernetes 集群内访问 TiDB 时,使用 TiDB service 域名 ${cluster_name}-tidb.${namespace} 即可。 若需要在集群外访问,则需将 TiDB 服务端口暴露出去。在 TidbCluster CR 中,通过 spec.tidb.service 字段进行配置: spec: ... tidb: service: ty