稳定性思考-强弱依赖2
这篇文章从一个实际问题切入:在微服务架构中,如何为弱依赖(如Cache)设置合理的“并发请求数阈值”?作者的分析思路很清晰,核心目标是实现高QPS下的资源消耗最小化,即“高QPS,少线程”。 作者通过一个Cache访问案例,结合公式 QPS=1000/RT * threadNum,做了生动的故障推演。正常时1个线程就能支撑400QPS;一旦Cache故障、RT飙升至3000ms,理论上就需要1200个线程,这会导致调用方线程池耗尽、频繁FullGC,陷入恶性循环。 为此,文章提出的核心方案是:限制访问弱依赖的线程数。例如,将阈值设为10。这样在上述故障中,调用方只会阻塞10个线程,整体服务保持正常,实现优雅降级。结合超时设置,能形成更有效的流控策略。 那么阈值设多少?文章给出了计算方法:根据可接受的RT(如100ms)和目标QPS(400)反推,得到 threadNum = 400 * 100 / 1000 = 40。作者也分享了经验数据:平均50ms的APP,阈值一般不超过60。文章最后点明,响应时间变长往往源于排队,而系统的最高QPS由瓶颈资源决定,盲目增加线程未必有用。