Linux流控框架:TC和Netfilter

Linux内核内置了一个Traffic Control框架,可以实现流量限速,流量整形,策略应用(丢弃,NAT等)。从这个框架你能想到别的什么吗?或许现在不能,但是我会先简单说一下,和TC框架比较相似的是Netfilter框架,但是二者却又有很大的不同。

在精通了Netfilter框架之后,再来体会TC框架会简单得多,特别是,当你觉得Netfilter具有这样那样的局限时,带着这些问题去体会TC框架的设计,你可能会发现,TC在某些方面弥补了Netfilter的不足。在具体深入到细节前,我先来介绍一下二者的相同点以及因其初衷不同而导致设计的大相径庭。

先说Netfilter,无疑这个框架被设计用来在网络协议栈的内核路径上过滤数据包,就像在一条路上的关卡一样,Netfilter在协议栈处理网络数据包的路径上的5个位置设置了这样的关卡,一个数据包在被处理的路径上经过这些关卡被检查,结果就是若干个动作:接受,丢弃,排队,导入其它路径等,框架只需针对一个数据包得出一个结果即可,关卡内部提供什么服务在Netfilter框架中并没有任何规定

现在我们看TC,它旨在对数据包或者数据流提供一种服务,比如限速,整形等,而这并不是一个类似Netfilter的结果可以表达的,提供这些服务需要执行一系列的动作,因此如何来“规划和组织这些动作的执行”是TC框架设计的关键!也就是说,TC框架关注的是如何执行而不是仅仅想要得到一个要执行的动作。换句话说,Netfilter框架关注做什么,而TC框架关注怎么做

有关限速,流量整形方面的理论已经很多了,比较常见的比如使用令牌桶,但是本文关注的是Linux对TC框架的实现而不是令牌桶算法相关的内容,然而在一篇短文中又不可能详细描述从流量控制理论到各种操作系统版本实现的历史,但是我们知道,使用队列是大多数实现中实际的选择,那么现在问题来了,Linux的TC框架是如何组织队列的。在详细深入讨论队列组织之前,我最后一次比较一下Netfilter和TC。

如果你知道UNIX的字符设备和块设备之间的区别,那么理解Netfilter框架和TC框架之间的区别就比较容易了。Netfilter的一个HOOK点类似一个管道字符设备,而skb就是这个设备中的单向字符流,一般都是按照从一端流入,然后按照进入的顺序从另一端流出,附带一个结果,比如ACCEPT,DROP等。而TC框架比较类似一个块设备,对内容进行随机存储和随机访问,即skb进入的顺序并不一定是skb出来的顺序,而这正是流量整形需要做的。也就是说,TC框架必须实现一个随机访问的数据包存储缓冲区,在这个缓冲区中进行流量控制,当然,我们已经知道,这是由队列实现的。

当然,任何事情都不是绝对的,Netfilter的一个HOOK点也可以有存储缓冲区或者执行一系列的动作,典型的就是conntrack中的分片重组以及NAT功能,对于PREROUTING这个HOOK点的分片重组,无疑对于分片而言,只是进入HOOK,暂时保存在里面,直到所有分片都来了切重组成功后才一次性流出这个HOOK点,而对于NAT而言,Netfilter的处理结果无疑是“执行了一系列的动作”而不仅仅是ACCEPT。此外,我也写过一些模块,用Netfilter来实现流量控制,反过来,TC框架也可以实现Netfilter的功能,总之,当你理解了这些框架的设计原则以及其本质后,在使用和扩展上,你就可以庖丁解牛,游刃有余了。

AI大模型学习福利

作为一名热心肠的互联网老兵,我决定把宝贵的AI知识分享给大家。 至于能学习到多少就看你的学习毅力和能力了 。我已将重要的AI大模型资料包括AI大模型入门学习思维导图、精品AI大模型学习书籍手册、视频教程、实战学习等录播视频免费分享出来。

一、全套AGI大模型学习路线

AI大模型时代的学习之旅:从基础到前沿,掌握人工智能的核心技能!

因篇幅有限,仅展示部分资料,需要点击文章最下方名片即可前往获取

二、640套AI大模型报告合集

这套包含640份报告的合集,涵盖了AI大模型的理论研究、技术实现、行业应用等多个方面。无论您是科研人员、工程师,还是对AI大模型感兴趣的爱好者,这套报告合集都将为您提供宝贵的信息和启示。

因篇幅有限,仅展示部分资料,需要点击文章最下方名片即可前往获

三、AI大模型经典PDF籍

随着人工智能技术的飞速发展,AI大模型已经成为了当今科技领域的一大热点。这些大型预训练模型,如GPT-3、BERT、XLNet等,以其强大的语言理解和生成能力,正在改变我们对人工智能的认识。 那以下这些PDF籍就是非常不错的学习资源。


因篇幅有限,仅展示部分资料,需要点击文章最下方名片即可前往获

四、AI大模型商业化落地方案

因篇幅有限,仅展示部分资料,需要点击文章最下方名片即可前往获

作为普通人,入局大模型时代需要持续学习和实践,不断提高自己的技能和认知水平,同时也需要有责任感和伦理意识,为人工智能的健康发展贡献力量

### LinuxTC 框架Netfilter 框架的比较 #### 区别 Netfilter Traffic Control (TC) 是 Linux 网络子系统的两个重要组成部分,各自负责不同的网络处理任务。 - **功能定位** - Netfilter 主要用于包过滤地址转换等功能。它允许内核模块在数据包通过网络堆栈的不同位置进行操作,支持防火墙、NAT(Network Address Translation)、IPSec 等安全特性[^1]。 - TC 则专注于量整形带宽管理,在发送方向上制数据的速度以及优先级调度策略,确保不同类型的业务能够获得合理的资源分配[^2]。 - **工作阶段** - Netfilter 处理的是进入或离开主机的数据报文,在 OSI 参考模型中的第三层(网络层)到第七层(应用层)之间运作;而 TC 更多关注于第二层之后至传输层之前的部分,即链路层以上的部分,并且主要作用是在输出路径上的队列管理速率限制等方面发挥作用。 - **配置工具** - 对应这两个框架有不同的命令行工具来进行设置:`iptables`, `nftables` 常被用来定制 netfilter 的行为模式;对于 tc,则有专门设计好的 iproute2 工具集下的 `tc` 命令来完成相应参数调整。 #### 联系 尽管两者有着明显的分工差异,但在实际部署过程中往往相辅相成: - 当需要对特定应用程序产生的量实施精确调时,可以先利用 netfilter 定义匹配条件筛选目标连接对象,再交由 tc 执行具体的 QoS (Quality of Service,服务质量)措施; - 同样地,在某些复杂环境中可能既存在对外部访问权限的安全管需求又涉及到内部服务间通信效率优化的要求——此时便可以通过组合运用这两种技术手段达到理想效果。 #### 应用场景 根据不同侧重点,两种机制适用于不同类型的应用场合: - **Netfilter 场景** - 实现企业级网络安全防护体系,如入侵检测系统IDS(Intrusion Detection System),防止恶意攻击者未经授权获取敏感资料; - 构建虚拟专用网(VPN,Virtural Private Network),使得远程工作者能安全接入公司内部网络环境; - 提供负载均衡解决方案,提高服务器集群的整体性能表现并增强可用性可靠性。 - **TC 场景** - 面向 ISP(Internet Service Provider)/运营商提供差异化服务水平协议SLA(Service Level Agreement),保障高价值客户享有更优质的互联网体验; - 支持多媒体实时交互类应用例如 VoIP/VoLTE(voice over IP/Long Term Evolution)通话质量不受拥塞影响保持清晰畅; - 协助大型数据中心有效规划计算节点间的通讯带宽配额,促进资源共享最大化的同时减少延迟现象发生概率。 ```bash # 示例:使用 iptables 设置简单的入站规则 sudo iptables -A INPUT -p tcp --dport ssh -j ACCEPT # 示例:创建 HTB 类型的 qdisc 并为其根节点指定默认 classid sudo tc qdisc add dev eth0 root handle 1: htb default 10 ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值