Chi*_*ter 5 architecture microservices api-gateway
在微服务架构中,有一个称为API网关的通用模式。
我知道来自API网关外部的所有通信都用作单个入口点。
但是我也希望从微服务到微服务的内部通信通过API网关进行?我的意思是,它比建立点对点连接要容易得多。
那么,反对在整个内部通信中使用API网关又是什么呢?
我尝试过三种口味
您可能需要考虑第一种方法(用于内部和外部调用的 API 网关)的两个问题:
网关服务的负载将会变高。如果内部服务平均对任何其他内部服务进行一次调用,则网关服务上的负载将增加一倍。这可能会导致额外的延迟,不仅因为额外的跃点,还因为每个请求都必须经历网关服务实例上的额外负载。这将迫使您增强网关服务硬件(水平或垂直),但没有任何实际好处。
一旦负载升高并达到网关服务实例的峰值容量,这些实例可能会开始耗尽工作线程和内存等资源。一般来说,这种情况可以通过减载或限制一些新请求来处理。这可能意味着我们可能只处理一部分请求,直到负载下降。然而,在我们的例子中,不仅新请求受到影响,而且所有正在等待网关服务资源被释放用于内部调用的正在进行的旧请求也会被永远阻止,直到超时,因为这些请求航班请求正在等待原始请求(本身)完成。因此,我们最终会得到一个死锁的系统,在负载下降之前根本不会服务任何请求。如果超时没有正确实现,系统甚至可能会永久死锁,直到死锁的网关服务实例被回收。
对于内部服务可以直接与其他内部服务通信的第二种方法,我们可以使用客户端负载均衡器以及通过发现服务或 DNS 的服务发现。与第一种方法相比,这不仅性能更好,而且需要更少的硬件。
| 归档时间: |
|
| 查看次数: |
363 次 |
| 最近记录: |