NAT 笔记
iptables NAT规则
NAT表需要的三个链:
1.PREROUTING:可以在这里定义进行DNAT的规则,因为路由器进行路由时只检查数据包的目的ip地址,所以为了使数据包得以正确路由,我们必须在路由之前就进行DNAT;
2.POSTROUTING:可以在这里定义进行SNAT的规则,系统在决定了数据包的路由以后在执行该链中的规则。
3.OUTPUT:定义对本地产生的数据包的DNAT规则。
需要用到的几个动作选项:(真实环境中用大写)
| 类型 | 描述 |
|---|---|
| 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不同动作的配置
- MASQUERADE:是动态分配ip时用的IP伪装:在nat表的POSTROUTING链加入一条规则:所有从ppp0口送出的包会被伪装(MASQUERADE)
|
|
- SNAT:一般正常共享上网都用的这个。
所有从eth0(外网卡)出来的数据包的源地址改成61.99.28.1(这里指定了一个网段,一般可以不指定)
|
|
- DNAT:目的nat 做智能DNS时会用到
智能DNS:就是客户端在dns项里无论输入任何ip,都会给他定向到服务器指定的一个dnsip上去。
在路由之前所有从eth0(内网卡)进入的目的端口为53的数据包,都发送到1.2.3.4这台服务器解析。
|
|
- REDIRECT:重定向,这个在透明代理时肯定要用到它
所有从eth1进入的请求80和82端口的数据,被转发到80端口,由squid处理。
|
|
三、保存配置规则
要想系统启动时自动实现nat,则可以保存iptables规则iptables-save > /etc/iptable.rules,在启动脚本加入iptables-restore < /etc/iptable.rules即可
- 原文作者:Ganing
- 原文链接:/2022/01/NAT-%E7%AC%94%E8%AE%B0/
- 版权声明:本作品采用知识共享署名-非商业性使用-禁止演绎 4.0 国际许可协议. 进行许可,非商业转载请注明出处(作者,原文链接),商业转载请联系作者获得授权。