Skip to content

Latest commit

 

History

History

03-Service-Mesh

Folders and files

NameName
Last commit message
Last commit date

parent directory

..
 
 
 
 
title sidebar_position
Service Mesh
0

服务网格

对比详见:Service Mesh Comparison

  1. istio
  2. linkerd2
  3. consul
  • 如果选择 envoy 阵营,目前不二选择就是 istio.
  • 追求轻量化和性能,目前最佳的选择应该也只有 linkerd2.
  • 未来更有潜力的方向是基于 ebpf 的内核级Service Mesh,如 Cilium Service Mesh

性能对比

The Istio load tests mesh consists of 1000 services and 2000 sidecars with 70,000 mesh-wide requests per second. After running the tests using Istio 1.11.4, we get the following results:

  • The Envoy proxy uses 0.35 vCPU and 40 MB memory per 1000 requests per second going through the proxy.
  • Istiod uses 1 vCPU and 1.5 GB of memory.
  • The Envoy proxy adds 2.65 ms to the 90th percentile latency.

linkerd2-proxy 相比 envoy,只用了 1/9 的内存与 1/8 的 CPU,同时 P99 延迟只有 envoy 的 1/3 不到.

现状分析

envoy虽然轻量且性能好,但过于简陋:

  • slow_start 还没支持,对缓存有依赖的服务扩容不太平滑
  • 不支持限流限并发,这个感觉在网格内还是有需要的,如果有微服务发疯,能起到隔离的作用...
  • 不处理南北向的网关流量,认证授权、rewrite,这些都建议在 Gateway 上搞

关于sidercar:

  • Sidecar 模式的性能损耗和资源占用叫道,所以现在也有一些 Node 模式部署的尝试,traefik mesh 就是 Node 模式,dapr 也支持 node 模式。
  • linkerd2 走的路则是做轻量的 sidecar,并且使用 rust 这类高效语言来实现。
  • Cilium 则将目标聚焦在「eBPF」上,实现内核级别的服务网格,并通过 Envoy 支持 Node 模式的 Proxy 以支持 mTLS 等更高级的能力。 不过我们现在也看到了 dapr 这样更通用的 multi-runtime 产品,以及 Proxyless Service Mesh.

对于java:

:::info sentinel和istio中的服务限流是什么关系? 都可以实现限流和熔断,区别是:
sentinel和hytrix 代码有侵入性可以控制到具体的方法。
istio则是为服务创建sidecar,主动劫持服务的入和出口流量;不侵入代码,但是粒度比较粗:只能针对整个java服务配置连接池和实例驱逐策略。 :::

其他资料