smart-socket v1.5.13 发布,插件全家桶迎来新成员
smart-socket v1.5.13 版本除了一些细节优化,最大的亮点莫过于插件全家桶迎来了一位重磅级新成员:RateLimiterPlugin(流控插件)。 流控,在很多场景下是一项刚性需求。目前市面上所见的绝大多数流控方案都是 QPS 维度的,即限制单位时间内的请求/响应次数。而 smart-socket 本次发布的流控插件却比较与众不同,我们提供的是针对字节码的流量控制能力,实现了网络上下行流量的限速。 产生出研发流控插件的想法缘于一次线上故障,当时某个业务的网络 IO 流量剧增,消耗了过多资源以致其他请求出现严重超时。由此使我意识到基于 QPS 限流策略的局限性,不仅仅是高并发会冲击系统的稳定性,低并发高流量也是个不容忽视的存在。尤其在分布式环境下,单节点的故障会引发一系列连锁反应。而要防止个别网络通道无节制的消耗 IO 资源,则需要将流量限速在安全范围内。 流控功能的实现原理是通过代理技术拦截了 Java 通信对象 AsynchronousSocketChannel 的 read/write 方法,识别出超负荷的 IO 任务并延迟至一下个窗口期执行(具体实现参见仓库源码)...





