中间件限流

中间件限流

提高服务器CPU占用率,从而提高整个系统的QPS(吞吐量)。

但吞吐量提高的同时,用户体验是有可能变差的。

从用户角度比较敏感的除可用性之外,还有延时。

虽然系统吞吐量高,但半天刷不出页面,想必会造成大量的用户流失。

所以中间件还要保证服务质量(QOS)。

中间件需要限流管制,要让在线的服务器保持CPU有一定的富余。向用户提供较好的服务质量。

中间件流量限制手段

1)漏桶

中间件每隔固定的时间向外提供一个令牌,只有接到这个令牌的客户端,才能向中间件申请服务,没有令牌的客户端,必须等待。

2)令牌桶

中间件服务请求时需要从桶中获取令牌,如果桶中没有令牌,可以选择等待,或者放弃。

例如:同时有100个用户请求,只要令牌桶中有100个令牌,那么这100个请求就全都会放过去。

令牌桶中没有令牌的情况下会退化为漏桶。

每秒钟向桶里放入N个令牌,超过桶容量的令牌会被直接丢弃。

桶初始是满的。

 

posted @   delphi中间件  阅读(511)  评论(0编辑  收藏  举报
编辑推荐:
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 三行代码完成国际化适配,妙~啊~
· .NET Core 中如何实现缓存的预热?
历史上的今天:
2013-02-27 TMemoryStream、String与OleVariant互转
点击右上角即可分享
微信分享提示