k8s 中 service 能否通过配置使得,收到集群内某个 pod 发来的请求会优先重定向到这个 service 所关联的和请求发起 pod 同一个 node 下的 pod.

2019-06-28 11:34:34 +08:00
 salivawbc
3394 次点击
所在节点    云计算
9 条回复
leorealman
2019-06-28 11:37:20 +08:00
为什么会有很奇葩的需求?你的意思是说发起请求的 POD 和最终响应的 POD 最好是在同一台物理机上?有点像 CDN 就近访问的原则
salivawbc
2019-06-28 11:49:40 +08:00
@leorealman 恩是的,因为会有两个 service 请求比较频繁,想节约他们两者之间通讯的开支,不清楚 k8s 是不是支持这种策略,并且对于同这块网络会有优化,让请求的性能接近直接使用宿主机 lo
wfhtqp
2019-06-28 11:52:18 +08:00
使用`selector`部署到一台`node`上?
salivawbc
2019-06-28 11:58:41 +08:00
@wfhtqp 一个是主要的 service 需要的资源比较多, 还有一个是 daemonSet 需要部署在每个宿主机,现在是使用 hostPort 暴露 daemonSet 的 port,然后请求的 pod 会被传入本机的 nodeIp 的环境变量,从而使得每个 pod 会访问同一个 Node 下的 daemonSet,但是会感觉有点丑,想着 k8s 是不是有更好的方案。
monsterxx03
2019-06-28 11:59:10 +08:00
目前没直接办法,看能不能把他们放在一个 pod 里,通过 localhost 访问。有个 kep 是关于这个的 https://github.com/kubernetes/enhancements/blob/master/keps/sig-network/0033-service-topology.md
chenk008
2019-06-28 12:36:31 +08:00
这个可以修改 kube-proxy 的 iptables 或者 ipvs 来实现
vindurriel
2019-06-28 12:40:22 +08:00
可以自己做 用 k8s api 找到同 node 的 pod 的 ip 优先访问 找不到或失败再调用 service
julyclyde
2019-06-28 14:13:26 +08:00
@wfhtqp selector 感觉是“必须”的意思。原 po 的需求其实是“优先”
menyakun
2019-06-28 18:49:12 +08:00
用 ipvs 的 weighted round robin (也就是 serviceIP 到 podID 的映射)应该可以,不过这个 feature 要比较新的 k8s 才支持,如果生产环境没法升级版本的话就不能用了

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/578248

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX