linux 抓nat包,linux – 使用带有NAT的iptables标记数据包

我必须为路由器编写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概念的重要事项?

提前致谢.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要在Linux上配置NAT网络,可以按照以下步骤进行操作: 1. 首先,确保你的Linux系统上已经安装了iptables软件。如果没有安装,可以使用以下命令进行安装: ``` sudo apt-get install iptables ``` 2. 然后,启用IP转发功能。可以通过编辑 `/etc/sysctl.conf` 文件,并将以下行取消注释来启用IP转发功能: ``` net.ipv4.ip_forward=1 ``` 或者,可以通过以下命令来立即启用IP转发功能: ``` sudo sysctl -w net.ipv4.ip_forward=1 ``` 3. 接下来,配置NAT规则。假设你的Linux系统的网卡名称为 `eth0`,而你想要将另一个网络接口 `eth1` 中的主机连接到互联网。可以使用以下命令来配置NAT规则: ``` sudo iptables -t nat -A POSTROUTING -o eth0 -j MASQUERADE sudo iptables -A FORWARD -i eth0 -o eth1 -m state --state RELATED,ESTABLISHED -j ACCEPT sudo iptables -A FORWARD -i eth1 -o eth0 -j ACCEPT ``` 这些命令将创建一个名为 `POSTROUTING` 的NAT规则,将从 `eth1` 中的主机发送的所有IP数据包转发到 `eth0` 网卡,并使这些数据包的源IP地址被NATLinux系统的公共IP地址。同时,这些命令还会配置一个名为 `FORWARD` 的防火墙规则,允许通过 `eth0` 网卡转发到 `eth1` 网卡的数据包,并且允许从 `eth1` 网卡转发到 `eth0` 网卡的数据包。 4. 最后,将以上命令保存到 `/etc/iptables.up.rules` 文件中,并使用以下命令使它们在系统启动时自动加载: ``` sudo iptables-save > /etc/iptables.up.rules sudo iptables-restore < /etc/iptables.up.rules ``` 这些命令将会将当前的iptables规则保存到文件中,并在系统启动时自动加载该文件中的规则。这样,即使系统重启,NAT规则也会被正确地加载。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值