如何解决如何在 Kubernetes 服务中将 Session Affinity 设置为“客户端 IP、端口和协议”
我在 GKE 有一个 Kubernetes 服务。目前它具有会话亲和性:ClientIP。在 GCP 负载均衡器控制台中,它显示为“客户端 IP”
我应该将其设置为什么值,以便在 GCP 负载均衡器控制台中显示为“客户端 IP、端口和协议”?
我看到的所有文件都提到了 会话亲缘关系可以指定为“ClientIP”或“no”(默认情况下)。他们都没有告诉我还有第三个选项,而如果您检查 GCP 负载均衡器,它有多个会话关联性选项:无;客户端IP;客户端 IP 和协议;客户端 IP、端口和协议
这是服务文件:
---
apiVersion: v1
kind: Service
Metadata:
namespace: test
name: test
annotations:
cloud.google.com/load-balancer-type: Internal
spec:
type: LoadBalancer
ports:
- port: XXX
protocol: TCP
targetPort: XXX
name: XXX
selector:
app: XXX
sessionAffinity: ClientIP
解决方法
会话关联,有时也称为粘性会话,将来自最终用户的所有请求与单个 Pod 相关联。这意味着从客户端到 Pod 的所有流量都将被定向到同一个 Pod。
如果您想确保来自特定客户端的连接是 每次都传递给同一个Pod,可以选择会话亲和度 通过设置基于客户端的IP地址 service.spec.sessionAffinity 到“ClientIP”
来自Latest Kubernetes API ServiceSpec v1 core:
sessionAffinity
支持“ClientIP”和“None”。用于维护会话亲缘关系。 启用基于客户端 IP 的会话亲缘关系。 必须是 ClientIP 或无。 默认为无。更多信息: https://kubernetes.io/docs/concepts/services-networking/service/#virtual-ips-and-service-proxies
所以,ClientIP
或 None
- 你没有第三个选择。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。