iptables 匹配 n 条 rule 的时间复杂度是多少?

2020 年 2 月 26 日
 feng32
简单起见, 假设都在一个 chain 中, 每个 rule 是 /32 地址, ACCEPT 或 DROP
2103 次点击
所在节点    程序员
4 条回复
zhs227
2020 年 2 月 26 日
建议使用 ipset,只知道效率很低,具体有多低不知道。基本上相当于 O(n)?
feng32
2020 年 2 月 26 日
@zhs227 我知道 ipset,只是有点好奇 iptables 原始规则是不是真的那么低效
ipwx
2020 年 2 月 26 日
iptables 应该是 O(n),不然管不住它这么复杂的规则。

用上 ipset 应该可以 O(logN)。
ipwx
2020 年 2 月 26 日
@feng32 iptables 非常强大,规则之间有先后匹配顺序。现在有两条路,第一是让运维人员用 ipset 优化规则集,第二是算法自动优化。考虑到人工都优化不了的规则集,算法肯定优化不了,所以我觉得这个优化器大概率内核没写。(摊手

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://nm.100875.xyz/t/647644

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX