Linux   发布时间:2022-04-01  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了linux – 使用带有NAT的iptables标记数据包大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。

概述

我必须为路由器编写bash脚本来控制给定域名上给定用户的带宽限制. 为此,我使用iptables将从受限域传入的数据包标记为专用网络中的用户IP地址.对于每对夫妇user_ip / domain_ip,我有一个密钥,我可以用它来标记数据包. 我在mangle表中添加这些规则,如下所示: $iptables -t mangle -A PRERoutING -p tcp -d $userIp -s $
我必须为路由器编写bash脚本来控制给定域名上给定用户的带宽限制.

为此,我使用iptables将从受限域传入的数据包标记为专用网络中的用户IP地址.对于每对夫妇user_ip / domain_ip,我有一个密钥,我可以用它来标记数据包.

我在mangle表中添加这些规则,如下所示:

$iptables -t mangle -A PRERoutING -p tcp -d $userIp -s $reStrictedDom -j MARK --set-mark $id 
$iptables -t mangle -A PRERoutING -p tcp -d $userIp -s $reStrictedDom -j RETURN

nat表中的NAT设置(eth0是我的互联网接口,我使用tap0作为Lan接口)是

$iptables -t nat -A POSTRoutING -o eth0 -j MASQUERADE

我的Lan用户的数据包应该与mangle表中的规则匹配,但不能捕获.

示例:( PRERoutING CHAIN中的表格manglE)
例如,这用于标记来自slashdot.org的用于Lan网络中的​​用户192.168.0.2的分组.

Chain PRERoutING (policy ACCEPT 14858 packets,7215129 bytes)
pkts      bytes target     prot opt in     out     source               desTination      
 0        0 MARK       tcp  --  *      *       216.34.181.45        192.168.0.2         MARK xset 0x9/0xffffffff 
 0        0 RETURN     tcp  --  *      *       216.34.181.45        192.168.0.2

但是,如果我尝试在路由器的互联网接口上标记来自slashdot.org的数据包,则会捕获数据包,如果Lan中的计算机也会查询slashdot.org,则同样的规则也会标记它们.

所以我认为由于NAT转换存在问题,我不确切知道何时以及以何种顺序应用规则.

第一次,我的NAT设置在iptables中是好还是不完整?
我是否错过了关于规则或iptables概念的重要事项?

提前致谢.

解决方法

我认为您应该使用POSTRoutING mangle表,因为您在NAT引擎之前标记了PRERoutING中的数据包.

看看IPTABLE链:

大佬总结

以上是大佬教程为你收集整理的linux – 使用带有NAT的iptables标记数据包全部内容,希望文章能够帮你解决linux – 使用带有NAT的iptables标记数据包所遇到的程序开发问题。

如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。