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

NodePort和LoadBalancer之间的区别?

司马祖鹤
2023-03-14

我刚刚开始使用库伯内特斯,我对NodePort和LoadBalancer类型的服务之间的区别感到困惑。

我理解的区别是LoadBalancer不支持UDP,但除此之外,每当我们创建NodeportLoadbalancer服务时,我们都会获得服务IP和端口、NodePort和endpoint。

来自Kubernetes文档:

NodePort:在拥有集群内部IP的基础上,在集群的每个节点上的一个端口(每个节点上的同一端口)公开服务。您可以通过任何NodeIP:NodePort地址联系该服务。

LoadBalancer:除了拥有集群内部IP并在NodePort上公开服务外,还可以向云提供商请求一个负载平衡器,该负载平衡器将转发给每个节点作为NodeIP:NodePort公开的服务。

所以,我将始终访问NodeIP上的服务:NodePort。我的理解是,每当我们访问node:NodePort时,kubeproxy就会拦截请求并将其转发到相应的pod。

关于LoadBalancer提到的另一件事是,我们可以有一个外部LB,它将在节点之间进行LB。是什么阻止我们为创建为节点端口的服务放置LB?

我真的很困惑。大多数文档或教程都只讨论LoadBalancer服务,因此我在internet上找不到太多内容。

共有3个答案

翁烨霖
2023-03-14

请在此处查看以下各项之间的差异:

你会发现这些信息weel:

  • ClusterIP服务
  • 入口
颜君浩
2023-03-14

节点端口和负载均衡器服务之间的区别。

江奕
2023-03-14

没有什么可以阻止您将外部负载均衡器放在节点前面并使用NodePort选项。

LoadBalancer选项仅用于在后台自动向云提供商请求新的软件LB实例。

我还不知道支持哪些云提供商,但我看到它已经在计算引擎和OpenStack上运行了。

 类似资料:
  • 1-我正在阅读文档,我对措辞有点困惑。上面写着: 集群IP:在集群内部IP上公开服务。选择此值将使服务只能从集群内访问。这是默认的ServiceType NodePort:在每个节点的IP上的一个静态端口(NodePort)上公开服务。节点端口服务将路由到的集群IP服务将自动创建。您可以通过请求从集群外部联系NodePort服务。 LoadBalancer:使用云提供商的负载均衡器对外公开服务。外

  • 问题内容: 我错放了太多次了,我想我一直忘记,因为我不知道两者之间的区别,只是一个给了我我期望的价值,而另一个却没有。 为什么是这样? 问题答案: 是的简写形式(尽管请注意,该表达式只会被计算一次。) 是的,即指定一元的到。 例子:

  • 问题内容: 因此,我有一段简单的代码可以打印出整数1-10: 然后,如果仅在第3行上更改一个运算符,它将打印出无限数量的1整数(我知道为什么会这样做)。为什么在运行第二个程序时没有出现语法错误?如果赋值运算符后面跟着一个加法运算符,它不会调用语法错误吗? 问题答案: 与相同, 只是意味着。

  • 问题内容: 有人可以解释一下 和 我不知道“确切”的含义 问题答案: 在这个例子中,什么都没有。当您具有多个具有相似名称的路径时,该参数将起作用: 例如,假设我们有一个显示用户列表的组件。我们还有一个用于创建用户的组件。的网址应嵌套在下。因此,我们的设置可能如下所示: 现在,这里的问题是,当我们转到路由器时,将通过所有定义的路由,并返回它找到的第一个匹配项。因此,在这种情况下,它将首先找到路线,然

  • 问题内容: 我很好奇printStackTrace()和toString()之间的区别是什么。乍一看,他们 似乎 做的完全相同。 码: 问题答案: 不,有重要区别!使用toString,您只有异常的类型和错误消息。使用printStackTrace()可以获得异常的整个堆栈跟踪,这对于调试非常有帮助。 System.out.println(toString())的示例: printStackTra