随着 Spring Boot 3.x 和 Java 21 的普及,基于 Project Loom 的虚拟线程(Virtual Threads)成为了提升高并发系统吞吐量(Throughput)的利器。然而,传统的 ThreadLocal 机制(如 Logback 中的 MDC 链路追踪)在虚拟线程频繁挂起与切换时,极易发生上下文丢失或全量对象无法回收导致的内存溢出(OOM)。本文将结合生产环境下的一个分布式安全审计组件,深入探讨其底层机理及工业级修复方案。
一、 业务场景与长文本边界异常复现
在一个基于分布式微服务架构的多币种跨境清算结算系统中,我们需要在全局过滤器(Filter)中捕获每一次业务请求的投递凭证,并将其写入 Logback 分布式链路日志(MDC)以及安全审计数据库中。
在线上进行压力测试时,当系统高频处理一些包含多字节中文字符的动态企业上下文凭证时,部分虚拟线程在执行 I/O 阻塞操作后,出现了日志追踪号(TraceId)混乱、甚至由于特定字符串未释放导致的堆内存持续飘高现象。
为了精准定位该并发边界,我们抽离并还原了以下具有代表性的简化安全审计拦截器模型:






