TSQ 的原理
这篇技术文章深入剖析了Linux内核网络栈中一个精巧的机制:TCP Small Queue (TSQ)。作者从一个常见疑问出发——既然已经有了`tcp_wmem`限制TCP层队列,为何还需要TSQ?以此引出关键:数据包从TCP层到网卡要经过多个队列,TSQ旨在更全面地控制排队延迟。 文章的核心在于对两个内核函数的源码级解读。其一是`tcp_wfree`,作为网络套接字缓冲区的析构函数,它巧妙地在缓冲区即将被丢弃时“截胡”,检查特定标志位后将套接字重新加入TSQ队列调度。其二是`tcp_tasklet_func`,它处理队列中的套接字,并根据其是否被用户进程持有来决定立即发送或推迟至`release_sock()`。 TSQ的巧妙之处在于,它没有直接维护一个可计算长度的独立队列,而是“寄生”于内核网络路径的关键节点(如缓冲区释放和套接字关闭)来间接判断队列空间是否充裕,以此实现动态的发送限速。这种设计展现了对TCP内部运作机制的深刻洞察。