Recommended Services
Amazon Web Services
LeanCloud
New Relic
ClearDB
salivawbc
V2EX  ›  云计算

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

  •  
  •   salivawbc · Jun 28, 2019 · 3940 views
    This topic created in 2514 days ago, the information mentioned may be changed or developed.
    9 replies    2019-06-28 18:49:12 +08:00
    leorealman
        1
    leorealman  
       Jun 28, 2019
    为什么会有很奇葩的需求?你的意思是说发起请求的 POD 和最终响应的 POD 最好是在同一台物理机上?有点像 CDN 就近访问的原则
    salivawbc
        2
    salivawbc  
    OP
       Jun 28, 2019
    @leorealman 恩是的,因为会有两个 service 请求比较频繁,想节约他们两者之间通讯的开支,不清楚 k8s 是不是支持这种策略,并且对于同这块网络会有优化,让请求的性能接近直接使用宿主机 lo
    wfhtqp
        3
    wfhtqp  
       Jun 28, 2019
    使用`selector`部署到一台`node`上?
    salivawbc
        4
    salivawbc  
    OP
       Jun 28, 2019
    @wfhtqp 一个是主要的 service 需要的资源比较多, 还有一个是 daemonSet 需要部署在每个宿主机,现在是使用 hostPort 暴露 daemonSet 的 port,然后请求的 pod 会被传入本机的 nodeIp 的环境变量,从而使得每个 pod 会访问同一个 Node 下的 daemonSet,但是会感觉有点丑,想着 k8s 是不是有更好的方案。
    monsterxx03
        5
    monsterxx03  
       Jun 28, 2019 via iPhone
    目前没直接办法,看能不能把他们放在一个 pod 里,通过 localhost 访问。有个 kep 是关于这个的 https://github.com/kubernetes/enhancements/blob/master/keps/sig-network/0033-service-topology.md
    chenk008
        6
    chenk008  
       Jun 28, 2019
    这个可以修改 kube-proxy 的 iptables 或者 ipvs 来实现
    vindurriel
        7
    vindurriel  
       Jun 28, 2019 via iPhone
    可以自己做 用 k8s api 找到同 node 的 pod 的 ip 优先访问 找不到或失败再调用 service
    julyclyde
        8
    julyclyde  
       Jun 28, 2019
    @wfhtqp selector 感觉是“必须”的意思。原 po 的需求其实是“优先”
    menyakun
        9
    menyakun  
       Jun 28, 2019
    用 ipvs 的 weighted round robin (也就是 serviceIP 到 podID 的映射)应该可以,不过这个 feature 要比较新的 k8s 才支持,如果生产环境没法升级版本的话就不能用了
    About   ·   Help   ·   Advertise   ·   Blog   ·   API   ·   FAQ   ·   Solana   ·   907 Online   Highest 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 36ms · UTC 22:31 · PVG 06:31 · LAX 15:31 · JFK 18:31
    ♥ Do have faith in what you're doing.