博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
iptable filter nat MASQUERADE snat dat
阅读量:6354 次
发布时间:2019-06-22

本文共 2703 字,大约阅读时间需要 9 分钟。

 

在这里,系统会根据IP数据包中的destination ip address中的IP地址对数据包进行分发。如果destination ip adress是本机地址,数据将会被转交给INPUT链。如果不是本机地址,则交给FORWARD链检测。

这也就是说,我们要做的DNAT要在进入这个菱形转发区域之前,也就是在PREROUTING链中做,

比如我们要把访问202.103.96.112的访问转发到192.168.0.112上:

iptables -t nat -A PREROUTING -d 202.103.96.112 -j DNAT --to-destination 192.168.0.112

这个转换过程当中,其实就是将已经达到这台Linux网关(防火墙)上的数据包上的destination ip address从202.103.96.112修改为192.168.0.112然后交给系统路由进行转发。

SNAT自然是要在数据包流出这台机器之前的最后一个链也就是POSTROUTING链来进行操作

iptables -t nat -A POSTROUTING -s 192.168.0.0/24 -j SNAT --to-source 58.20.51.66

这个语句就是告诉系统把即将要流出本机的数据的source ip address修改成为58.20.51.66。这样,数据包在达到目的机器以后,目的机器会将包返回到58.20.51.66也就是本机。如果不做这个操作,那么你的数据包在传递的过程中,reply的包肯定会丢失。

总结

PREROUTING: 位于 nat 表,用于修改目的地址(DNAT)(上一节说的是数据包作路由选择前应用此链中的规则 记住!所有的数据包进来的时侯都先由这个链处理)

POSTROUTING:位于 nat 表,用于修改源地址 (SNAT)(上一节说的是对数据包作路由选择后应用此链中的规则,所有的数据包出来的时侯都先由这个链处理.

 

 

因为某些原因需要把访问10.0.3.49上的httpd服务重定向到10.0.3.26上.所以研究了一下用iptables的NAT实现IP与端口的重定向,其实很简单,只需要两步。

 

1,首先需要确保linux服务器10.0.3.49开启了数据转发功能:

 

echo 1 > /proc/sys/net/ipv4/ip_forward

 

2.10.0.3.49做NAT的ip和端口80的重定向

iptables -t nat -A PREROUTING -p tcp --dport 80 -d 10.0.3.49 -j DNAT --to 10.0.3.26:80iptables -t nat -A POSTROUTING -d 10.0.3.26 -p tcp --dport 80 -j SNAT --to 10.0.3.49:80iptables -A FORWARD -d 10.0.3.26 -j ACCEPT

nat表需要的三个链:

  1.PREROUTING:可以在这里定义进行目的NAT的规则,因为路由器进行路由时只检查数据包的目的ip地址,所以为了使数据包得以正确路由,我们必须在路由之前就进行目的NAT;

  2.POSTROUTING:可以在这里定义进行源NAT的规则,系统在决定了数据包的路由以后在执行该链中的规则。
  3.OUTPUT:定义对本地产生的数据包的目的NAT规则。

需要用到的几个动作选项:(真实环境中用大写)

redirect 将数据包重定向到另一台主机的某个端口,通常用实现透明代理和对外开放内网某些服务。snat    源地址转换,改变数据包的源地址dnat    目的地址转换,改变数据包的目的地址masquerade    IP伪装,只适用于ADSL等动态拨号上网的IP伪装,如果主机IP是静态分配的,就用snat

 

PRERROUTING:DNAT 、REDIRECT   (路由之前)只支持-i,不支持-o。在作出路由之前,对目的地址进行修改

 POSTROUTING:SNAT、MASQUERADE (路由之后)只支持-o,不支持-i。在作出路由之后,对源地址进行修改

 OUTPUT:DNAT 、REDIRECT   (本机)DNAT和REDIRECT规则用来处理来自NAT主机本身生成的出站数据包.

 

一、打开内核的路由功能。

   要实现nat,要将文件/proc/sys/net/ipv4/ip_forward内的值改为1,(默认是0)。

 

二、nat不同动作的配置

 1)MASQUERADE:是动态分配ip时用的IP伪装:在nat表的POSTROUTING链加入一条规则:所有从ppp0口送出的包会被伪装(MASQUERADE)

iptables -t nat -A POSTROUTING -o ppp0 -j MASQUERADE要想系统启动时自动实现nat,在/etc/rc.d/rc.local文件的末尾添加 echo "1">/proc/sys/net/ipv4/ip_forward

 

 2) SNAT:一般正常共享上网都用的这个。

 所有从eth0(外网卡)出来的数据包的源地址改成61.99.28.1(这里指定了一个网段,一般可以不指定)

iptables -t nat -A POSTROUTING -s 192.168.1.0/24 -o eth0 -j SNAT --to 61.99.28.1

 

3)DNAT:目的nat 做智能DNS时会用到

 智能DNS:就是客户端在dns项里无论输入任何ip,都会给他定向到服务器指定的一个dnsip上去。

 在路由之前所有从eth0(内网卡)进入的目的端口为53的数据包,都发送到1.2.3.4这台服务器解析。

iptables -t nat -I PREROUTING -i eth0 -p udp --dport 53 -j DNAT --to-destination 1.2.3.4:53

 

4)REDIRECT:重定向,这个在squid透明代理时肯定要用到它

 所有从eth1进入的请求80和82端口的数据,被转发到80端口,由squid处理。

iptables -t nat -A PREROUTING - -i eth1 -p tcp -m multiport --dports 80,82 -j REDIRECT --to-ports 80

 

转载于:https://www.cnblogs.com/fatt/p/8393421.html

你可能感兴趣的文章
如何在 Linux 上使用 BackupPC 来架设跨平台的备份服务器
查看>>
《Python Cookbook(第2版)中文版》——1.22 在标准输出中打印Unicode字符
查看>>
盘点互联网巨头奉献的十大开源安全工具
查看>>
Windows 和 Ubuntu 双系统完全独立的安装方法
查看>>
删除 Ubuntu Linux 系统旧内核的方法
查看>>
Java基础-19总结IO流,异常try…catch,throws,File类
查看>>
Operating Principle and Implementation of Flink: Memory Management
查看>>
webview和js交互
查看>>
云服务器ECS安全组实践(二)
查看>>
如何精确地测量java对象的大小
查看>>
HugePage优点缺点大盘点
查看>>
[LeetCode]--389. Find the Difference
查看>>
Fiddler (六) 最常用的快捷键
查看>>
老司机的微服务架构实现,照亮你的人生 | 朱攀
查看>>
【阿里招聘】三个与阿里初恋的故事
查看>>
MySQL数字类型int与tinyint、float与decimal如何选择
查看>>
Git远程01:git remote相关操作
查看>>
PostgreSQL · 特性分析 · 统计信息计算方法
查看>>
Struts2中的ModelDriven机制及其运用
查看>>
怎样理解阻塞非阻塞与同步异步的区别?
查看>>