AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / server / 问题 / 747100
Accepted
Samul
Samul
Asked: 2016-01-07 05:12:49 +0800 CST2016-01-07 05:12:49 +0800 CST 2016-01-07 05:12:49 +0800 CST

带 -m 和 -p 参数的 iptables

  • 772

我的 iptables 中有这个规则:

iptables -A INPUT -p tcp -m tcp --dport 9191 -j DROP

我真的需要“-m tcp”吗?我已经在使用“-p tcp”,所以我应该使用“-m tcp”更安全吗?

centos
  • 1 1 个回答
  • 3392 Views

1 个回答

  • Voted
  1. Best Answer
    Diamond
    2016-01-07T05:29:20+08:002016-01-07T05:29:20+08:00

    使用该-p tcp选项,tcp 模块已经加载,因此它有点多余,不是必须使用该-m tcp选项,我看不出有任何理由使用该选项会使规则更安全。

    请参阅iptables 手册页以获得更好的理解和比较:

    -p, --protocol [!] 协议

    要检查的规则或数据包的协议。指定的协议可以是 tcp、udp、icmp 或 all 之一,也可以是一个数值,表示这些协议之一或不同的协议。/etc/protocols 中的协议名称也是允许的。一个 ”!” 协议反转测试之前的参数。数字零等于所有。Protocol all 将与所有协议匹配,当省略此选项时将被视为默认值。

    ...

    匹配扩展

    iptables 可以使用扩展的数据包匹配模块。它们以两种方式加载:隐式地,当指定 -p 或 --protocol 时,或使用 -m 或 --match 选项,后跟匹配的模块名称;在这些之后,各种额外的命令行选项变得可用,具体取决于特定模块。您可以在一行中指定多个扩展匹配模块,并且可以在指定模块后使用 -h 或 --help 选项来接收特定于该模块的帮助。

    有关可用选项的列表,-p tcp请参见此处:

    http://ipset.netfilter.org/iptables-extensions.man.html#lbCF

    如上所述,使用-m选项可以添加扩展模块,然后可以使用更多匹配的选项。例如cpu 模块:

    中央处理器

    [!] --cpu 数量

    匹配处理此数据包的 CPU。cpus 编号从 0 到 NR_CPUS-1 可以与 RPS(远程数据包引导)或多队列 NIC 结合使用,以将网络流量分散到不同的队列上。

    例子:

    iptables -t nat -A PREROUTING -p tcp --dport 80 -m cpu --cpu 0 -j REDIRECT --to-port 8080

    iptables -t nat -A PREROUTING -p tcp --dport 80 -m cpu --cpu 1 -j REDIRECT --to-port 8081

    自 Linux 2.6.36 起可用。

    iptables 扩展的完整列表。


    来自 OP 的附加问题:我不明白 -m 匹配什么。什么字符串?-m tcp 匹配什么?它试图在哪里找到“tcp”这个词?

    答:-m用于匹配模块名称而不是字符串。通过使用特定模块,您可以获得某些匹配选项。请参阅上面的 cpu 模块示例。随着-m tcp模块 tcp 的加载。tcp 模块允许某些选项:--dport, --sport, --tcp-flags, --syn, --tcp-option在 iptables 规则中使用。但是 using-p tcp已经启用了 tcp 模块,这就是为什么即使不使用-m tcp. 希望它能消除你所有的困惑。

    • 9

相关问题

  • 如何在 Linux 机器上找到有关硬件的详细信息?

  • 使用 crontab 和 /etc/cron.hourly,daily,weekly 的区别

  • 持续监控许多服务器运行状况的简单方法?

  • Hudson 无法在 tomcat5 中启动

  • CentOS 的依赖挑战

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    新安装后 postgres 的默认超级用户用户名/密码是什么?

    • 5 个回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    Noah Goodrich 什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent 如何确定bash变量是否为空? 2009-05-13 09:54:48 +0800 CST
  • Martin Hope
    cletus 您如何找到在 Windows 中打开文件的进程? 2009-05-01 16:47:16 +0800 CST

热门标签

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve