猿问

如何知道可以从 Kubernetes API Server 分配哪个节点端口?

我想弄清楚当创建一个节点端口类型的新服务时,kubernetes 如何知道可以分配哪个节点端口,如下所示:


apiVersion: v1

kind: Service

metadata:

  name: my-service

spec:

  type: NodePort

  selector:

    app: MyApp

  ports:

    - port: 80

      targetPort: 80

我搜索了谷歌并找到了这些 kubernetes 源代码,但我不明白它是如何工作的。 https://github.com/kubernetes/kubernetes/blob/master/pkg/registry/core/service/portallocator/allocator.go


白衣非少年
浏览 149回答 1
1回答

犯罪嫌疑人X

Nodeport 在 30000-32767 之间随机选择。您可以在服务定义中进行设置。apiVersion: v1kind: Servicemetadata:  name: my-servicespec:  type: NodePort  selector:    app: MyApp  ports:      # By default and for convenience, the `targetPort` is set to the same value as the `port` field.    - port: 80      targetPort: 80      # Optional field      # By default and for convenience, the Kubernetes control plane will allocate a port from a range (default: 30000-32767)      nodePort: 30007来自文档:https ://kubernetes.io/docs/concepts/services-networking/service/#nodeport更新放置在包kubernetes/pkg/registry/core/service/portallocator中的类负责为服务分配节点端口。此测试记录了行为:https ://github.com/kubernetes/kubernetes/blob/master/pkg/registry/core/service/portallocator/operation_test.goKubernetes 只占用一个随机端口,如果该端口不是免费的,它会占用下一个端口。如果您可以阅读该包中的其他类,则可以很好地了解该行为。
随时随地看视频慕课网APP

相关分类

Go
我要回答