1
perfectlife 2024-01-03 10:47:11 +08:00
pod 本身一般不会导致响应时间差异太大,更多的是服务调用的第三方接口,中间件导致的,上个 apm 工具监控一下
|
2
pkoukk 2024-01-03 10:49:57 +08:00 1
不是,问题不应该是为什么不一致么?
|
3
vivisidea 2024-01-03 11:05:59 +08:00
差异的原因通常是所在宿主机的硬件配置不同,或者负载不同,如果对 rt 很敏感,可以划几个 node 隔离一下,专门部署这种 rt 敏感的 pod
|
5
ixx 2024-01-03 11:11:09 +08:00
@idblife 参数不一样不就说明执行的业务逻辑不一样,这样的话哪怕是同一个 pod 也应该不一致,和 deployment 有啥关系,只有 3 楼老哥说的那种,不同节点的硬件或者网络差异不然不会有区别的
|
6
whileFalse 2024-01-03 11:56:01 +08:00 via Android 3
lz 这个需求是哪里来的?怎么感觉 lz 都没好好过过脑子呢
|
7
bwangel 2024-01-03 17:27:48 +08:00 1
https://linkerd.io/2.14/features/load-balancing/
不同 pod 之间响应时间不同才是正常的情况吧。 linkerd 专门有个负载均衡算法叫做 EWMA, 根据 pod 的响应时间,提供不同的流量值。响应时间越快的 pod, 收到的请求也越多。我们实测过,这样整体 p99 会更好。 https://github.com/mosn/mosn/pull/2274 曾有人想把这个负载均衡算法在 envoy 中也实现一遍,可惜最后没 merge 有个类似情况是 tcp 连接在多个线程之间如何分配 https://blog.envoyproxy.io/envoy-threading-model-a8d44b922310 envoy 的博客中提到了,多个线程监听了一个端口之后,连接具体分配到哪个线程完全是内核决定的。内核的策略也不是平均分配的,而是尽量塞满一个线程,再往下一个线程分配。 As discussed briefly above, all worker threads listen on all listeners without any sharding. Thus, the kernel is used to intelligently dispatch accepted sockets to worker threads. Modern kernels in general are very good at this; they employ features such as IO priority boosting to attempt to fill up a thread’s work before starting to employ other threads that are also listening on the same socket, as well as not using a single spin-lock for processing each accept. 因为请求发送到同一个线程上,能最大程度地利用内存缓存和 cpu 缓存,这样从整体来看,性能是更好的。 |
8
idblife OP @whileFalse
没有建议的话可以闭嘴 |