gpt4 book ai didi

kubernetes - Kubernetes 中的默认负载平衡

转载 作者:行者123 更新时间:2023-12-02 11:37:21 25 4
gpt4 key购买 nike

我最近开始使用 Kubernetes 集群。我们集群中给定 Kubernetes 服务的网络调用流程类似于以下内容:

外部非 K8S 负载均衡器 -> Ingress Controller -> Ingress Resource -> Service -> Pod

对于给定的服务,有两个副本。通过查看副本中容器的日志,我可以看到调用被路由到不同的 pod。据我所知,我们还没有在任何地方为 Kubernetes 中的服务明确设置任何负载平衡策略。

我有几个问题:

1) K8S 有默认的负载均衡策略吗?我已经阅读了 kube-proxy 和随机路由。它绝对不是循环的。
2) 有没有明显的方法可以在 Ingress 资源本身中指定负载均衡规则?以每项服务为基础?

查看我们的 Ingress 资源之一,我可以看到“loadBalancer”属性为空:

---
apiVersion: extensions/v1beta1
kind: Ingress
metadata:
annotations:
ingress.kubernetes.io/rewrite-target: /
kubectl.kubernetes.io/last-applied-configuration: |
{"apiVersion":"extensions/v1beta1","kind":"Ingress","metadata":{"annotations":{"ingress.kubernetes.io/rewrite-target":"/","nginx.ingress.kubernetes.io/rewrite-target":"/"},"name":"example-service-ingress","namespace":"member"},"spec":{"rules":[{"host":"example-service.x.x.x.example.com","http":{"paths":[{"backend":{"serviceName":"example-service-service","servicePort":8080},"path":""}]}}]}}
nginx.ingress.kubernetes.io/rewrite-target: /
creationTimestamp: "2019-02-13T17:49:29Z"
generation: 1
name: example-service-ingress
namespace: x
resourceVersion: "59178"
selfLink: /apis/extensions/v1beta1/namespaces/x/ingresses/example-service-ingress
uid: b61decda-2fb7-11e9-935b-02e6ca1a54ae
spec:
rules:
- host: example-service.x.x.x.example.com
http:
paths:
- backend:
serviceName: example-service-service
servicePort: 8080
status:
loadBalancer:
ingress:
- {}

我应该指定 - 我们使用的是本地 Kubernetes 集群,而不是在云上。

干杯!

最佳答案

服务的 Pod 之间的“内部负载平衡”已经在 this question from a few days ago 中介绍过。 .

Ingress 并没有真正做任何特别的事情(除非你在它使用的 NGINX 配置中进行了黑客攻击)——它将使用与链接问题相同的服务规则。

如果您想要或需要对 Pod 如何在服务内路由的细粒度控制,可以扩展 Kubernetes 的功能 - 我建议您查看 Istio 的流量管理功能,因为它的功能之一是能够动态控制服务中不同 pod 接收的流量。

关于kubernetes - Kubernetes 中的默认负载平衡,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54736107/

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