NAT( 网络地址转换) 实现

NAT( 网络地址转换) 实现

大家好,又见面了,我是全栈君,今天给大家准备了Idea注册码。

NAT基本介绍:

        网络地址转换(NAT,Network Address Translation)属接入广域网(WAN)技术。是一种将私有(保留)地址转化为合法IP地址的转换技术,它被广泛应用于各种类型Internet接入方式和各种类型的网络中。原因非常easy,NAT不仅完美地解决了lP地址不足的问题,并且还可以有效地避免来自网络外部的攻击,隐藏并保护网络内部的计算机。

       借助于NAT,私有(保留)地址的”内部”网络通过路由器发送数据包时。私有地址被转换成合法的IP地址,一个局域网仅仅需使用少量IP地址(甚至是1个)就可以实现私有地址网络内全部计算机与Internet的通信需求。

  NAT将自己主动改动IP报文的源IP地址和目的IP地址。Ip地址校验则在NAT处理过程中自己主动完毕。有些应用程序将源IP地址嵌入到IP报文的数据部分中,所以还须要同一时候对报文的数据部分进行改动。以匹配IP头中已经改动过的源IP地址。

否则,在报文数据都分别嵌入IP地址的应用程序就不能正常工作。

NAT的三种实现方式:

NAT的实现方式有三种,即静态转换Static Nat、动态转换Dynamic Nat 和port多路复用OverLoad。

  静态转换是指将内部网络的私有IP地址转换为公有IP地址,IP地址对是一对一的,是一成不变的,某个私有IP地址仅仅转换为某个公有IP地址。借助于静态转换,能够实现外部网络对内部网络中某些特定设备(如server)的訪问。
  动态转换是指将内部网络的私有IP地址转换为公用IP地址时,IP地址是不确定的,是随机的。全部被授权訪问上Internet的私有IP地址可随机转换为不论什么指定的合法IP地址。也就是说,仅仅要指定哪些内部地址能够进行转换,以及用哪些合法地址作为外部地址时。就能够进行动态转换。动态转换能够使用多个合法外部地址集。当ISP提供的合法IP地址略少于网络内部的计算机数量时。能够採用动态转换的方式。

  port多路复用(Port address Translation,PAT)是指改变外出数据包的源port并进行port转换,即port地址转换(PAT,Port Address Translation).採用port多路复用方式。内部网络的全部主机均可共享一个合法外部IP地址实现对Internet的訪问,从而能够最大限度地节约IP地址资源。

同一时候,又可隐藏网络内部的全部主机。有效避免来自internet的攻击。

因此。眼下网络中应用最多的就是port多路复用方式。


I. 静态地址转换的实现

如果内部局域网使用的lP地址段为192.168.0.1~192.168.0.254,路由器局域网端(即默认网关)的IP地址为192.168.0.1。子网掩码为255.255.255.0。

网络分配的合法IP地址范围为61.159.62.128~61.159.62.135,路由器在广域网中的IP地址为61.159.62.129,子网掩码为255.255.255.248可用于转换的IP地址范围为61.159.62.130~61.159.62.134。

要求将内部网址192.168.0.2~192.168.0.6分别转换为合法IP地址61.159.62.130~61.159.62.134。
>>>第一步,设置外部port。
  interface serial 0
  ip address 61.159.62.129 255.255.255.248
  ip nat outside
>>>第二步。设置内部port。
  interface ethernet 0
  ip address 192.168.0.1 255.255.255.0
  ip nat inside
>>>第三步,在内部本地与外部合法地址之间建立静态地址转换。
  ip nat inside source static 内部本地地址内部合法地址。
  演示样例:
  ip nat inside source static 192.168.0.2 61.159.62.130 //将内部网络地址192.168.0.2转换为合法IP地址61.159.62.130
  ip nat inside source static 192.168.0.3 61.159.62.131 //将内部网络地址192.168.0.3转换为合法IP地址61.159.62.131
  ip nat inside source static 192.168.0.4 61.159.62.132 //将内部网络地址192.168.0.4转换为合法IP地址61.159.62.132
  ip nat inside source static 192.168.0.5 61.159.62.133 //将内部网络地址192.168.0.5转换为合法IP地址61.159.62.133
  ip nat inside source static 192.168.0.6 61.159.62.134 //将内部网络地址192.168.0.6转换为合法IP地址61.159.62.134
  至此。静态地址转换配置完成。

II. 动态地址转换的实现

如果内部网络使用的IP地址段为172.16.100.1~172.16.100.254,路由器局域网port(即默认网关)的IP地址为172.16.100.1,子网掩码为255.255.255.0。网络分配的合法IP地址范围为61.159.62.128~61.159.62.191,路由器在广域网中的IP地址为61.159.62.129,子网掩码为255.255.255.192,可用于转换的IP地址范围为61.159.62.130~61.159.62.190。

要求将内部网址172.16.100.1~172.16.100.254动态转换为合法IP地址61.159.62.130~61.159.62.190。
>>>第一步,设置外部port。

  设置外部port命令的语法例如以下:
  ip nat outside
  演示样例:
  interface serial 0 //进入串行portserial 0
  ip address 61.159.62.129 255.255.255.192//将其IP地址指定为61.159.62.129,子网掩码为255.255.255.192
  ip nat outside //将串行口serial 0设置为外网port
  注意,能够定义多个外部port。

>>>第二步。设置内部port。

  设置内部接口命令的语法例如以下:
  ip nat inside
  演示样例:
  interface ethernet 0 //进入以太网portEthernet 0
  ip address 172.16.100.1 255.255.255.0 // 将其IP地址指定为172.16.100.1。子网掩码为255.255.255.0
  ip nat inside //将Ethernet 0 设置为内网port。
  注意。能够定义多个内部port。

>>>第三步,定义合法IP地址池。
  定义合法IP地址池命令的语法例如以下:
  ip nat pool 地址池名称起始IP地址 终止IP地址子网掩码
  当中。地址池名字能够随意设定。
  演示样例:
  ip nat pool chinanet 61.159.62.130 61.159.62.190 netmask 255.255.255.192 //指明地址缓冲池的名称为chinanet,IP地址范围为61.159.62.130~61.159.62.190。子网掩码为255.255.255.192。须要注意的是,即使掩码为255.255.255.0,也会由起始IP地址和终止IP地址对IP地址池进行限制。
  或ip nat pool test 61.159.62.130 61.159.62.190 prefix-length 26
  注意,假设有多个合法IP地址范围,能够分别加入。

比如,假设另一段合法IP地址范围为”211.82.216.1~211.82.216.254″,那么。能够再通过下述命令将其加入至缓冲池中。

  ip nat pool cernet 211.82.216.1 211.82.216.254 netmask 255.255.255.0
  或
  ip nat pool test 211.82.216.1 211.82.216.254 prefix-length 24
>>>第四步。定义内部网络中同意訪问Internet的訪问列表。
  定义内部訪问列表命令的语法例如以下:
  access-list 标号 permit 源地址通配符(当中,标号为1~99之间的整数)
  access-list 1 permit 172.16.100.0 0.0.0.255 //同意訪问Internet的网段为172.16.100.0~172.16.100.255,反掩码为0.0.0.255。须要注意的是。在这里採用的是反掩码,而非子网掩码。反掩码与子网掩码的关系为:反掩码+子网掩码=255.255.255.255。

比如,子网掩码为255.255.0.0,则反掩码为0.0.255.255。子网掩码为255.0.0.0,则反掩码为0.255.255.255。子网掩码为255.252.0.0,则反掩码为0.3.255.255。子网掩码为255.255.255.192,则反掩码为0.0.0.63。
  另外,假设想将多个IP地址段转换为合法IP地址,能够加入多个訪问列表。比如,当欲将172.16.98.0~172.16.98.255和172.16.99.0~172.16.99.255转换为合法IP地址时,应当加入下述命令:
  access-list2 permit 172.16.98.0 0.0.0.255
  access-list3 permit 172.16.99.0 0.0.0.255
>>>第五步。实现网络地址转换。

  在全局设置模式下。将第四步由access-list指定的内部本地地址列表与第三步指定的合法IP地址池进行地址转换。

命令语法例如以下:
  ip nat inside source list 訪问列表标号 pool 内部合法地址池名字
  演示样例:
  ip nat inside source list 1 pool chinanet
  假设有多个内部訪问列表,能够一一加入,以实现网络地址转换。如
  ip nat inside source list 2 pool chinanet
  ip nat inside source list 3 pool chinanet
  假设有多个地址池,也能够一一加入,以添加合法地址池范围,如
  ip nat inside source list 1 pool cernet
  ip nat inside source list 2 pool cernet
  ip nat inside source list 3 pool cernet
  至此,动态地址转换设置完成。

III. port复用动态地址转换(PAT)

内部网络使用的IP地址段为10.100.100.1~10.100.100.254,路由器局域网port(即默认网关)的IP地址为10.100.100.1,子网掩码为255.255.255.0。

网络分配的合法IP地址范围为202.99.160.0~202.99.160.3。路由器广域网中的IP地址为202.99.160.1,子网掩码为255.255.255.252,可用于转换的IP地址为202.99.160.2。要求将内部网址10.100.100.1~10.100.100.254 转换为合法IP地址202.99.160.2。

>>>第一步,设置外部port。

  interface serial 0
  ip address 202.99.160.1 255.255.255.252
  ip nat outside
>>>第二步,设置内部port。
  interface ethernet 0
  ip address 10.100.100.1 255.255.255.0
  ip nat inside
>>>第三步,定义合法IP地址池。
  ip nat pool onlyone 202.99.160.2 202.99.160.2 netmask 255.255.255.252
  // 指明地址缓冲池的名称为onlyone,IP地址范围为202.99.160.2,子网掩码为255.255.255.252。因为本例仅仅有一个IP地址可用。所以,起始IP地址与终止IP地址均为202.99.160.2。

假设有多个IP地址,则应当分别键入起止的IP地址。
>>>第四步,定义内部訪问列。

  access-list 1 permit 10.100.100.0 0.0.0.255
  同意訪问Internetr的网段为10.100.100.0~10.100.100.255,子网掩码为255.255.255.0。须要注意的是,在这里子网掩码的顺序跟寻常所写的顺序相反,即0.0.0.255。
>>>第五步,设置复用动态地址转换。
  在全局设置模式下。设置在内部的本地地址与内部合法IP地址间建立复用动态地址转换。命令语法例如以下:
  ip nat inside source list訪问列表号pool内部合法地址池名字overload
  演示样例:
  ip nat inside source list1 pool onlyone overload //以port复用方式。将訪问列表1中的私有IP地址转换为onlyone IP地址池中定义的合法IP地址。
  注意:overload是复用动态地址转换的关键词。

  至此,port复用动态地址转换完毕。

  还能够这样写:
  ip nat inside source list 1 interface serial 0 overload



版权声明:本文博客原创文章,博客,未经同意,不得转载。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/117611.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • Struts2拦截器实现异常处理[通俗易懂]

    Struts2拦截器实现异常处理[通俗易懂]Struts2拦截器实现异常处理机制在j2ee项目中,系统内部难免会出现一些异常,如果把异常放任不管直接打印到浏览器可能会让用户感觉莫名其妙,也有可能让某些用户找到搞定系统的方法。所以不要在页面上输出错误信息,使用log日志的方式处理异常并记录异常。就拿struts2+hibernate+spring项目说明:通常一个页面请求到后台以后,首先是到action(也就是所谓mvc的c

  • c++ 优先级队列_低优先级队列要等几局

    c++ 优先级队列_低优先级队列要等几局作者有话说:本来兴致勃勃的准备写一篇优先级队列的总结,但查资料时发现一篇写的不错的博文,偷个懒!!!!!!!!!!!转载大神的就ok了。https://www.cnblogs.com/xzxl/p/7266404.html一、相关定义优先队列容器与队列一样,只能从队尾插入元素,从队首删除元素。但是它有一个特性,就是队列中最大的元素总是位于队首,所以出队时,并非按照先进先出的原则进行,而…

  • 为什么会有内存屏障呢_内存出问题有什么现象

    为什么会有内存屏障呢_内存出问题有什么现象复习一下内存屏障主要解决指令重排和可见性,需要了解JMM架构原文链接为什么会有内存屏障每个CPU都会有自己的缓存(有的甚至L1,L2,L3),缓存的目的就是为了提高性能,避免每次都要向内存取。但是这样的弊端也很明显:不能实时的和内存发生信息交换,分在不同CPU执行的不同线程对同一个变量的缓存值不同。用volatile关键字修饰变量可以解决上述问题,那么volatile是如何做到这一点的呢?那就是内存屏障,内存屏障是硬件层的概念,不同的硬件平台实现内存屏障的手段并不是一样,java通过屏蔽这些差异,统

  • mytabiscodehelp在线激活激活码[最新免费获取]「建议收藏」

    (mytabiscodehelp在线激活激活码)本文适用于JetBrains家族所有ide,包括IntelliJidea,phpstorm,webstorm,pycharm,datagrip等。IntelliJ2021最新激活注册码,破解教程可免费永久激活,亲测有效,下面是详细链接哦~https://javaforall.cn/100143.html…

  • 阿里云服务器定时在线运行python爬虫代码「建议收藏」

    阿里云服务器定时在线运行python爬虫代码「建议收藏」服务器:centos任务管理:cron服务对于cron服务不了解的可以看我这篇文章

  • Gradle 15分钟入门教程

    1-Gradle入门介绍在阅读或实践本文中的实例前,必须首先确保已将Gradle插件安装到Eclipse中。如果没有,可以点击下面的链接查看Gradle安装说明: – http://www.yiibai.com/gradle/how-install-gradle-windows.html本教程的目标:这是项目完成后的代码结构图: 2-创建Gradle

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号