`
z_jiankun
  • 浏览: 159435 次
  • 性别: Icon_minigender_1
  • 来自: 南京
社区版块
存档分类
最新评论
阅读更多
  •    摘要:本文是“用iptales实现包过虑型防火墙”的姊妹篇,主要介绍如何使用iptbales实现linux2.4下的强大的NAT功能。关于 iptables的详细语法请参考“用iptales实现包过虑型防火墙”一文。需要申明的是,本文绝对不是NAT-HOWTO的简单重复或是中文版,在 整个的叙述过程中,作者都在试图用自己的语言来表达自己的理解,自己的思想。

    一、概述

    1. 什么是NAT
    在传统的标准的TCP/IP通信过程中,所有的路由器仅仅是充当一个中间人的角色,也就是通常所说的存储转发,路由器 并不会对转发的数据包进行修改,更为确切的说,除了将源MAC地址换成自己的MAC地址以外,路由器不会对转发的数据包做任何修改。 NAT(Network Address Translation网络地址翻译)恰恰是出于某种特殊需要而对数据包的源ip地址、目的ip地址、源端口、目的端口进行改写的操作。

    2. 为什么要进行NAT
    我们来看看再什么情况下我们需要做NAT。
    假设有一家ISP提供园区Internet接入服务,为了 方便管理,该ISP分配给园区用户的IP地址都是伪IP,但是部分用户要求建立自己的WWW服务器对外发布信息,这时候我们就可以通过NAT来提供这种服 务了。我们可以再防火墙的外部网卡上绑定多个合法IP地址,然后通过NAT技术使发给其中某一个IP地址的包转发至内部某一用户的WWW服务器上,然后再 将该内部WWW服务器响应包伪装成该合法IP发出的包。
    再比如使用拨号上网的网吧,因为只有一个合法的IP地址,必须采用某种手段让其他机器 也可以上网,通常是采用代理服务器的方式,但是代理服务器,尤其是应用层代理服务器,只能支持有限的协议,如果过了一段时间后又有新的服务出来,则只能等 待代理服务器支持该新应用的升级版本。如果采用NAT来解决这个问题,
    因为只在应用层以下进行处理,不但可以获得很高的访问速度,而且可以无缝的支持任何新的服务或应用。
    还有一个方面的应用就是重定向,也就是当接收到一个包后,不是转发这个包,而是将其重定向到系统上的某一个应用程序。最常见的应用就是和squid配合使用成为透明代理,在对http流量进行缓存的同时,可以提供对Internet的无缝访问。

    3. NAT的类型
    在linux2.4的NAT-HOWTO中,作者从原理的角度将NAT分成了两种类型,即源NAT(SNAT)和目的NAT(DNAT),顾名思义,所谓SNAT就是改变转发数据包的源地址,所谓DNAT就是改变转发数据包的目的地址。

    二、原理

    下图是linux2.4的原理图:


    在“用iptales实现包过虑型防火墙”一文中我们说过,netfilter是Linux 核心中一个通用架构,它提供了一系列的"表"(tables),每个表由若干"链"(chains)组成,而每条链中可以有一条或数条规则(rule)组 成。并且系统缺省的表是"filter"。但是在使用NAT的时候,我们所使用的表不再是"filter",而是"nat"表,所以我们必须使用"-t nat"选项来显式地指明这一点。因为系统缺省的表是"filter",所以在使用filter功能时,我们没有必要显式的指明"-t filter"。
    同filter表一样,nat表也有三条缺省的"链"(chains),这三条链也是规则的容器,它们分别是:
    PREROUTING:可以在这里定义进行目的NAT的规则,因为路由器进行路由时只检查数据包的目的ip地址,所以为了使数据包得以正确路由,我们必须在路由之前就进行目的NAT;
    POSTROUTING:可以在这里定义进行源NAT的规则,系统在决定了数据包的路由以后在执行该链中的规则。
    OUTPUT:定义对本地产生的数据包的目的NAT规则。

    三、操作语法

    如前所述,在使用iptables的NAT功能时,我们必须在每一条规则中使用"-t nat"显示的指明使用nat表。然后使用以下的选项:

    1. 对规则的操作
    加入(append) 一个新规则到一个链 (-A)的最后。
    在链内某个位置插入(insert) 一个新规则(-I),通常是插在最前面。
    在链内某个位置替换(replace) 一条规则 (-R)。
    在链内某个位置删除(delete) 一条规则 (-D)。
    删除(delete) 链内第一条规则 (-D)。

    2. 指定源地址和目的地址

    通过--source/--src/-s来指定源地址(这里的/表示或者的意思,下同),通过--destination/--dst/-s来指定目的地址。可以使用以下四中方法来指定ip地址:
    a. 使用完整的域名,如“www.linuxaid.com.cn”;
    b. 使用ip地址,如“192.168.1.1”;
    c. 用x.x.x.x/x.x.x.x指定一个网络地址,如“192.168.1.0/255.255.255.0”;
    d. 用x.x.x.x/x指定一个网络地址,如“192.168.1.0/24”这里的24表明了子网掩码的有效位数,这是 UNIX环境中通常使用的表示方法。
    缺省的子网掩码数是32,也就是说指定192.168.1.1等效于192.168.1.1/32。


    3. 指定网络接口

    可以使用--in-interface/-i或--out-interface/-o来指定网络接口。从NAT的原理可以看出,对于 PREROUTING链,我们只能用-i指定进来的网络接口;而对于POSTROUTING和OUTPUT我们只能用-o指定出去的网络接口。

    4. 指定协议及端口

    可以通过--protocol/-p选项来指定协议,如果是udp和tcp协议,还可--source-port/--sport和 --destination-port/--dport来指明端口。

    四、准备工作

    1. 编译内核,编译时选中以下选项,具体可参看“用iptales实现包过虑型防火墙”一文:

    Full NAT
    MASQUERADE target support
    REDIRECT target support

    2. 要使用NAT表时,必须首先载入相关模块:

    modprobe ip_tables
    modprobe ip_nat_ftp
    iptable_nat 模块会在运行时自动载入。


    五、使用实例

    1. 源NAT(SNAT)

    比如,更改所有来自192.168.1.0/24的数据包的源ip地址为1.2.3.4:

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

    这里需要注意的是,系统在路由及过虑等处理直到数据包要被送出时才进行SNAT。

    有一种SNAT的特殊情况是ip欺骗,也就是所谓的Masquerading,通常建议在使用拨号上网的时候使用,或者说在合法ip地址不固定的情况下使用。比如

    # iptables -t nat -A POSTROUTING -o ppp0 -j MASQUERADE

    可以看出,这时候我们没有必要显式的指定源ip地址等信息。

    2. 目的SNAT(DNAT)

    比如,更改所有来自192.168.1.0/24的数据包的目的ip地址为1.2.3.4:

    iptables -t nat -A PREROUTING -s 192.168.1.0/24 -i eth1 -j DNAT --to 1.2.3.4

    这里需要注意的是,系统是先进行DNAT,然后才进行路由及过虑等操作。

    有一种DNAT的特殊情况是重定向,也就是所谓的Redirection,这时候就相当于将符合条件的数据包的目的ip地址改为数据包进入系统时的 网络接口的ip地址。通常是在与squid配置形成透明代理时使用,假设squid的监听端口是3128,我们可以通过以下语句来将来自 192.168.1.0/24,目的端口为80的数据包重定向到squid监听
    端口:

    iptables -t nat -A PREROUTING -i eth1 -p tcp -s 192.168.1.0/24 --dport 80
    -j REDIRECT --to-port 3128

    六、综合例子

    1. 使用拨号带动局域网上网

    小型企业、网吧等多使用拨号网络上网,通常可能使用代理,但是考虑到成本、对协议的支持等因素,建议使用ip欺骗方式带动区域网上网。

    成功升级内核后安装iptables,然后执行以下脚本:

    #载入相关模块
    modprobe ip_tables
    modprobe ip_nat_ftp

    #进行ip伪装
    iptables -t nat -A POSTROUTING -o ppp0 -j MASQUERADE

    2. ip映射

    假设有一家ISP提供园区Internet接入服务,为了方便管理,该ISP分配给园区用户的IP地址都是伪IP,但是部分用户要求建立自己的 WWW服务器对外发布信息。我们可以再防火墙的外部网卡上绑定多个合法IP地址,然后通过ip映射使发给其中某一个IP地址的包转发至内部某一用户的 WWW服务器上,然后再将该内部WWW服务器响应包伪装成该合法IP发出的包。

    我们假设以下情景:

    该ISP分配给A单位www服务器的ip为:
    伪ip:192.168.1.100
    真实ip:202.110.123.100

    该ISP分配给B单位www服务器的ip为:
    伪ip:192.168.1.200
    真实ip:202.110.123.200

    linux防火墙的ip地址分别为:
    内网接口eth1:192.168.1.1
    外网接口eth0:202.110.123.1

    然后我们将分配给A、B单位的真实ip绑定到防火墙的外网接口,以root权限执行以下命令:

    ifconfig eth0 add 202.110.123.100 netmask 255.255.255.0
    ifconfig eth0 add 202.110.123.200 netmask 255.255.255.0

    成功升级内核后安装iptables,然后执行以下脚本:

    #载入相关模块
    modprobe ip_tables
    modprobe ip_nat_ftp

    首先,对防火墙接收到的目的ip为202.110.123.100和202.110.123.200的所有数据包进行目的NAT(DNAT):

    iptables -A PREROUTING -i eth0 -d 202.110.123.100 -j DNAT --to 192.168.1.100
    iptables -A PREROUTING -i eth0 -d 202.110.123.200 -j DNAT --to 192.168.1.200

    其次,对防火墙接收到的源ip地址为192.168.1.100和192.168.1.200的数据包进行源NAT(SNAT):

    iptables -A POSTROUTING -o eth0 -s 192.168.1.100 -j SNAT --to 202.110.123.100
    iptables -A POSTROUTING -o eth0 -s 192.168.1.200 -j SNAT --to 202.110.123.200

    这样,所有目的ip为202.110.123.100和202.110.123.200的数据包都将分别被转发给192.168.1.100和 192.168.1.200;而所有来自192.168.1.100和192.168.1.200的数据包都将分别被伪装成由 202.110.123.100和202.110.123.200,从而也就实现了ip映射。

分享到:
评论

相关推荐

    linux下设置iptables实现NAT功能

    linux下设置iptables实现NAT功能

    Linux下使用Iptables配置NAT防火墙

    方案,能够实现NAT和对网络进行用户管理和信息过滤,并能防范一定的网络攻击手段和防病毒 能力,保护校园网内主机的安全和重要站点的信息安全,如各部门的信息服务器等。 设计论文内容要求: 1)分析网络安全技术和...

    iptables的代码实现nat

    使用iptables进行设置的基本命令,配置正确的iptables命令

    一个iptables的stateless NAT模块实现

    但是想做PAT为何不使用现有的iptables实现呢?它可以自动为你解决元组唯一性问题。不要从概念上分析,事实上,static双向NAT是完全对称的,一对一的 ,也只有在BOX两边的网络在拓扑级别是完全对等的情形下,这种NAT...

    iptables的使用说明 配置nat功能

    配置nat功能,软件实现ip伪装,使用iptables的说明,ubuntu下,嵌入式linux下。

    一种新的IPSEC穿越NAT方法 (2007年)

    目前存在的3种解决方法都具有局限性:“先于IPSEC进行 NAT转换”方法难以实现,“特定域IP通信(RSIP)”方法部署困难,“用户数据包(UDP)封装 安全封装协议(ESP)数据包”方法只能部分地解决IPSEC与NAT不兼容问题。...

    iptables 端口转发

    iptables是一个Linux下优秀的nat+防火墙工具

    kubernetes-iptables-proxy:使用iptables快速实现Kubernetes代理

    这是使用iptables规则的Kubernetes代理的快速实现。 设置: iptables -t nat -I PREROUTING -j my-dnatiptables -t nat -I OUTPUT -j my-dnatiptables -t nat -I POSTROUTING -j my-snat/usr/bin/docker run --name ...

    [计算机毕设]基于jsp的基于Iptables图形管理工具系统设计与实现(源代码+项目报告).zip

    本文设计并实现了一个基于Web的Iptables图形管理工具,通过友好的配置界面,简化了Iptables防火墙的管理配置程序,更方便用户对Iptables防火墙的使用。 本工具采用Browser/Server模式,通过Web配置界面,用户可远程...

    基于JAVA JSP Iptables图形管理工具设计与实现的毕业设计,采用Browser/Server模式,通过Web配置界面

    本文设计并实现了一个基于Web的Iptables图形管理工具,通过友好的配置界面,简化了Iptables防火墙的管理配置程序,更方便用户对Iptables防火墙的使用。 本工具采用Browser/Server模式,通过Web配置界面,用户可远程...

    iptables防火墙的配置

    LINUX下用iptables进行协议和端口过滤,以及实现NAT功能,完成地址伪装和地址转换等功能。

    static-stateless-2-way-NAT-on-Linux-with-iptables:使用 iptables 执行静态无状态 2 路 NAT

    但是想做PAT为何不使用现有的iptables实现呢?它可以自动为你解决元组唯一性问题。不要从概念上分析,事实上,static双向NAT是完全对称的,一对一的 ,也只有在BOX两边的网络在拓扑级别是完全对等的情形下,这种NAT...

    把Iptables移植到嵌入式Linux系统

    Linux下支持netfilter机制的配置工具就是iptables,它也就相当与一个 应用程序,可以对netfilter进行配置(包过滤规则,NAT等等)。所以要实现netfilter(iptables)就要从两方面来着手:1)内 核支持netfilter;2)...

    iptables.docx

    利用iptables实现局域网设备上网。同时利用iptables实现外网端口映射内网服务。

    构筑Linux防火墙之IPtables的概念与用法

    通过使用iptables系统提供的特殊命令 iptables,建立这些规则,并将其添加到内核空间的特定信息包过滤表内的链中。关于添加、除去、编辑规则的命令的一般语法如下: iptables [-t table] command [match] [target...

    用uClinux中的IPtables实现IP共享器

    摘 要:本文阐述了Linux中IPtables的工作原理和利用其IP伪装的功能实现IP共享器的方法,并设计了一个多机共享上网的方案。IP共享器的作用和工作原理目前广泛使用的IPv4规范中的IP地址空间几乎分配完毕。随着网络的...

    Python实现ipatables及l7lter的使用.zip

    用Python实现的iptables。本项目使用vmwarefusion搭建实验环境,使用虚拟主机<=>虚拟路由<=>虚拟服务器形式。虚拟主机和虚拟路由均为虚拟机,虚拟服务器在本机搭建。 iptables 的核心为四表五链。四表为 raw ...

    高性能LINUX系统下双效防火墙HOWTO

    由iptables 实现包的过滤,由LINUX下大名鼎鼎的squid结合NAT来实现透明WEB代理。SQUID代理的性能本身已经是代理服务器中的佼佼者,本系统将其性 能发挥的极至:通过ramdisk技术,让SQUID把网页cahce到内存中,这样,你所...

    NAT、DR模型架构实现web服务负载均衡

    NAT模型:地址转换类型,主要是做地址转换,类似于iptables的DNAT类型,它通过多目标地址转换,来实现负载均衡,一个Director最多负载提供10个RealServer主机1、LVS上面需要双网卡:DIP和VIP2、内网的RealServer主机...

Global site tag (gtag.js) - Google Analytics