DNS协议、ICMP协议、NAT技术(二)

简介: DNS协议、ICMP协议、NAT技术

三、NAT技术(重点)

NAT(Network Address Translation,网络地址转换)技术,是解决IP地址不足的主要手段,并且能够有效地避免来自网络外部的攻击,隐藏并保护网络内部的计算机


3.1 NAT技术背景

在IPv4协议中,IP地址数量不足是一个大问题,而NAT技术就是当前解决IP地址不够用的主要手段,是路由器的一个重要功能


在进行对外通信时,NAT能够将私有IP经过一系列替换操作最终转为全局IP,即NAT是一种将私有IP和全局IP相互转化的技术

装有NAT软件的路由器叫做NAT路由器,所有使用私有IP的主机在和外界通信时,都要在NAT路由器上将其私有IP转换成全局IP

很多学校、家庭、公司内部每个终端设置的IP都是私有IP,而只在路由器或必要的服务器上设置全局IP

全局IP要求唯一,但是私有IP不需要,在不同的局域网中出现相同的私有IP是完全不影响的

3.2 NAT IP转换过程

假设某个局域网中有A、B、C三台主机,在公网中有一台服务器,以主机A访问公网中的这台服务器为例,观察数据包在传输过程中IP地址的转换过程


数据包从局域网到公网的过程


b5b42b3400394138bd8e90cd217f2626.png


主机A向服务器发起数据请求的过程中,数据包中IP地址的转换过程如下:


开始,该数据包中的源IP地址就是主机A的私有IP地址,目的IP地址就是服务器的公网IP地址

当数据包经过NAT路由器时,路由器会将该数据包的源IP地址替换成WAN口IP地址,此时该数据包的源和目的IP地址就都是公网IP了

该数据包在互联网中经过各种路由转发,最终到达服务器主机

服务器收到主机A的数据请求并处理后,就会对主机A发来的请求进行响应


数据包从公网到局域网的过程


111fcaf6242e47b68de9e43fb0558dc4.png


服务器向主机A进行响应的过程中,数据包中IP地址的转换过程如下:


开始,该数据包中的源IP地址就是服务器的公网IP地址,目的IP地址就是NAT路由器的WAN口IP地址

数据包在互联网中进行路由转发,到达主机A所在局域网的NAT路由器,此时路由器会将该数据包的目的IP地址替换成主机A的私有IP地址

最终路由器就会将该数据包转发给局域网中的主机A

因为主机A向服务器发起数据请求时,该数据包中的源IP地址被替换成了NAT路由器的WAN口IP地址,相当于是该路由器代替主机A向服务器发起了数据请求,因此服务器发出的响应数据包的目的IP地址应该是NAT路由器的WAN口IP地址


3.3 NAPT

地址转换表


当局域网中的主机要访问外网时,NAT路由器会将这些数据包的源IP地址替换成WAN口IP地址

当外网发来响应数据时,NAT路由器又会将响应数据包的目的IP地址替换成局域网中对应主机的IP地址

那NAT路由器是如何判断,应该将从外网收到的数据包转发给局域网中的哪一台主机呢?


实际在NAT路由器内部,有一张自动生成的,用于地址转换的表

该转换表中维护的就是局域网中主机的私有IP,与其对应访问的外网中的某个公网IP之间的映射关系

局域网中的主机第一次向外网发起数据请求时,就会生成表中的映射关系

如在TCP建立连接时,会建立对应的映射关系,在TCP断开连接后,就会删除对应的映射关系

在刚才的例子中,主机A第一次向服务器发起数据请求时,路由器中就会建立以下映射关系


d6181b94af674e09913c54e8e76efbbe.png


当NAT路由器收到服务器向主机A发来的响应数据时,就可以通过查表得知该响应数据是发送给局域网当中的主机A的


但若转换表中维护的只是局域网中主机的私有IP,与其对应访问的外网中的某个公网IP之间的映射关系,那么就会出现某些问题。若局域网中的主机A和主机B同时都在访问该服务器,那么此时转换表中就会建立如下两对映射关系:

ba4286fd11ae48789f1f980c8ccbfa8e.png



此时这张转换表只能保证从左到右的唯一性,而不能保证从右到左的唯一性,当服务器发来响应数据时,该数据包中的目的IP地址都是路由器的WAN口IP,此时NAT路由器就无法判断该数据包应该转发给主机A还是主机B,此时就需要用到NAPT技术


NAPT


NAPT(Network Address Port Translation,网络地址端口转换),可以将多个内部地址映射为一个合法公网地址


当局域网中的主机向外网发送数据时,路由器会将该数据包的源IP地址替换为WAN口IP地址,并建立该主机私有IP与其对应访问的公网IP之间的映射关系

但若局域网中的多台主机同时访问同一个外网服务,当路由器收到外网发来的响应数据时,路由器无法判断该响应数据应该转发给局域网中哪台主机,因为该局域网中所有主机的数据包都由路由器代替发送了,因此发来的响应数据包的目的IP地址都是路由器的WAN口IP地址

于是NAPT在建立转换表的映射关系时,除了建立局域网中私有IP与其对应访问的公网IP之间的映射关系外,还会加上一个由NAT路由器选定的端口号

此时当局域网中的多台主机同时访问同一个外网服务时,虽然外网发来的响应数据的目的IP地址都是路由器的WAN口IP,但发给局域网中不同主机的响应数据对应的目的端口号是不同的,此时路由器就能通过 IP+Port 的方式来区分发给不同主机的数据包

如局域网中的主机A和主机B都在访问同一个服务器,并且访问服务器时采用的端口号都是1025


假设主机A发送的数据包先到达路由器,此时路由器将数据包的源IP地址替换成WAN口IP地址,由于路由器用于访问该服务器的1025号端口没有被使用,因此该数据包的源端口号可以不变

当主机B发来的数据包到达路由器时,路由器同样将数据包的源IP地址替换成WAN口IP地址,但此时路由器用于访问该服务器的1025号端口已被使用,因此路由器会重新选定一个端口号对数据包的源端口号进行替换

7a5cc854eeac4d9fa3b489a787ceae90.png


此时这张转换表既能保证从左到右的唯一性,也能保证从右到左的唯一性


当服务器发来的响应数据到达NAT路由器时,虽然服务器发给主机A和主机B的数据包对应的目的IP地址相同

但路由器用1025号端口代替主机A进行数据请求的,用1026号端口代替主机B进行数据请求的

因此NAT路由器可以根据数据包目的端口号,来判断应将数据包转发给主机A还是主机B,进行对数据包中的目的IP地址进行替换,然后转发给局域网内对应主机

路由器


路由器是工作在网络层的一个设备,负责将数据包从一个网络转发到另一个网络,但不能狭义的认为路由器只能工作在网络层


NAT路由器在进行数据转发时,不仅能替换数据包的源和目的IP地址,在必要的情况下还可能会替换数据包的源和目的端口号,而端口号实际是传输层的概念


为了对IP地址动态管理,大部分路由器都带有DHCP功能,而DHCP是应用层的一个协议。因此现在的路由器其实并不仅仅提供网络层相关的服务,网络协议栈中的各层路由器可能都有涉及


3.4 NAT的缺陷

NAT技术进行私有IP和公网之间的替换,主要是依赖NAT路由器中维护的网络地址转换表,但这张转换表也体现出了NAT的一些缺陷:


无法从NAT外部向内部服务器建立连接,因为外部无法知道内部的私网IP,就无法主动与内部服务器建立连接

转换表的生成和销毁都需要额外开销

通信过程中一旦NAT设备异常,即使存在热备,所有的TCP连接也都会断开

3.5 NAT与代理服务器

代理服务器(Proxy Server)的功能就是代理网络用户发送、获取网络信息,代理服务器又分为正向代理和反向代理


正向代理


正向代理,位于客户端和目标服务器之间,客户端并不直接访问目标服务器,而是先访问代理服务器,由代理服务器代替客户端去访问对应的目标服务器,并将目标服务器的响应结果返回给客户端


be9d91e6343c4428a546f5f0409e5f80.png


公司内部一般都有自己的服务器,当使用公司内网上网时


对外网发起的数据请求,先转发到公司服务器上,然后由公司的这台服务器代替你对外网进行访问

当公司的服务器收到对应外网的响应数据后,再由公司服务器将数据转发给你

正向代理的好处:


正向代理最大的一个好处就是可以加速资源访问

如公司中大量员工都要访问外网的同一个资源,那么正向代理服务器就可以将对应的资源缓存到本地,当其他人要访问该资源时,直接在正向代理服务器获取即可,而不需要再次进行外网访问

反向代理


反向代理,也位于客户端和目标服务器之间,对于客户端而言,反向代理服务器就相当于目标服务器,用户不需要知道目标服务器的真实地址,用户只需访问反向代理服务器就可获得目标服务器提供的服务


客户端直接向反向代理服务器发起数据请求,然后再由反向代理服务器将客户端的数据请求转发给真正的目标服务器进行处理,数据处理完毕后反向代理服务器再将数据结果返回给客户端


e0f9edb627c54c63a1afdc6df8c4e1b7.png


如域名www.baidu.com对应的服务器实际就是一个反向代理服务器


百度内部实际并不只有一台服务器,但不同地区的人们都可以通过访问www.baidu.com享受到百度提供的服务,实际访问的就是百度的反向代理服务器

当这台反向代理服务器收到客户端的数据请求后,就会将数据请求转发给百度内部的某台服务器进行数据处理,然后再将数据处理的结果返回给客户端

反向代理的好处:


反向代理可以起到负载均衡的作用。比如不设置反向代理服务器,那么用户在访问百度时,就会随机访问到百度内部的某台服务器,此时就可能导致某些服务器压力太大,而某些服务器却处于闲置状态。而设置了反向代理服务器后,就能够通过某些方法让用户的数据请求较为平均的落到每台服务器上

反向代理还能起到安全防护的作用。有了反向代理服务器后,不需直接将提供服务的服务器对应的信息暴露。当有非法请求发送到反向代理服务器时,反向代理服务器就相当于一层软件屏障,可以在反向代理服务器中部署一些防护措施,让这些非法请求在反向代理服务器就被过滤,而不会影响内部实际提供服务的服务器

注意:代理服务器的主要工作只是对数据进行转发,因此代理服务器处理数据的压力不会特别大,并且代理服务器也可以有多个,因此不必担心代理服务器过载的情况


正向代理和反向代理的异同


正向代理和反向代理的相同点:


正向代理服务器和反向代理服务器都位于客户端和服务器之间

正向代理服务器和反向代理服务器的主要工作,都是将客户端的请求转发给服务器,再将服务器的响应转发给客户端

正向代理和反向代理的不同点:


正向代理一般为客户端架设,需要对客户端主机进行设置,可帮助客户端访问其无法访问的服务器资源的,如:vpn翻墙

反向代理一般是服务端架设的,可帮助服务器做负载均衡、安全防护等工作,如百度的反向代理服务器

正向代理中,服务器不知道真正的客户端到底是谁,服务器认为正向代理服务器就是真实的客户端,而反向代理中,客户端不知道真正的服务器是谁,客户端认为反向代理服务器就是真实的服务器

NAT和代理服务器的区别


NAT和代理服务器都是代理向服务器发起数据请求的,但有如下区别:


从应用上讲,NAT设备是网络基础设备之一,解决的是IP不足的问题,而代理服务器更贴近具体应用,如通过代理服务器进行翻墙、像迅游这样的加速器也是使用的代理服务器

从底层实现上讲,NAT工作在网络层,直接对IP地址进行替换,而代理服务器往往工作在应用层

从使用范围上讲,NAT一般在局域网的出口部署,而代理服务器可以在局域网代理,也可以在广域网代理,也可以跨网代理

从部署位置上看,NAT一般集成在防火墙、路由器等硬件设备上,而代理服务器则是一个软件程序(比如Nginx和Apache),需要部署在服务器上


目录
相关文章
|
域名解析 存储 网络协议
深入解析网络通信关键要素:IP 协议、DNS 及相关技术
本文详细介绍了IP协议报头结构及其各字段的功能,包括版本、首部长度、服务类型、总长度、标识、片偏移、标志、生存时间(TTL)、协议、首部检验和等内容。此外,还探讨了IP地址的网段划分、特殊IP地址的应用场景,以及路由选择的大致流程。最后,文章简要介绍了DNS协议的作用及其发展历史,解释了域名解析系统的工作原理。
568 5
深入解析网络通信关键要素:IP 协议、DNS 及相关技术
|
XML JSON API
ServiceStack:不仅仅是一个高性能Web API和微服务框架,更是一站式解决方案——深入解析其多协议支持及简便开发流程,带您体验前所未有的.NET开发效率革命
【10月更文挑战第9天】ServiceStack 是一个高性能的 Web API 和微服务框架,支持 JSON、XML、CSV 等多种数据格式。它简化了 .NET 应用的开发流程,提供了直观的 RESTful 服务构建方式。ServiceStack 支持高并发请求和复杂业务逻辑,安装简单,通过 NuGet 包管理器即可快速集成。示例代码展示了如何创建一个返回当前日期的简单服务,包括定义请求和响应 DTO、实现服务逻辑、配置路由和宿主。ServiceStack 还支持 WebSocket、SignalR 等实时通信协议,具备自动验证、自动过滤器等丰富功能,适合快速搭建高性能、可扩展的服务端应用。
825 3
|
9月前
|
网络协议
为何UDP协议不可靠?DNS为何选择UDP?
总的来说,UDP和TCP各有优势,选择哪种协议取决于应用的具体需求。UDP可能不如TCP可靠,但其简单、快速的特性使其在某些场景下成为更好的选择。而DNS就是这样的一个例子,它利用了UDP的优势,以实现快速、高效的名字解析服务。
513 14
|
11月前
|
存储 缓存 网络协议
DNS协议详解
通过本文,您可以全面了解DNS协议的各个方面,从而更好地理解和应用这一重要的互联网基础服务。
1896 44
|
10月前
|
编解码 监控 网络协议
RTSP协议规范与SmartMediaKit播放器技术解析
RTSP协议是实时流媒体传输的重要规范,大牛直播SDK的rtsp播放器基于此构建,具备跨平台支持、超低延迟(100-300ms)、多实例播放、高效资源利用、音视频同步等优势。它广泛应用于安防监控、远程教学等领域,提供实时录像、快照等功能,优化网络传输与解码效率,并通过事件回调机制保障稳定性。作为高性能解决方案,它推动了实时流媒体技术的发展。
567 5
|
网络协议 安全 网络安全
探索网络模型与协议:从OSI到HTTPs的原理解析
OSI七层网络模型和TCP/IP四层模型是理解和设计计算机网络的框架。OSI模型包括物理层、数据链路层、网络层、传输层、会话层、表示层和应用层,而TCP/IP模型则简化为链路层、网络层、传输层和 HTTPS协议基于HTTP并通过TLS/SSL加密数据,确保安全传输。其连接过程涉及TCP三次握手、SSL证书验证、对称密钥交换等步骤,以保障通信的安全性和完整性。数字信封技术使用非对称加密和数字证书确保数据的机密性和身份认证。 浏览器通过Https访问网站的过程包括输入网址、DNS解析、建立TCP连接、发送HTTPS请求、接收响应、验证证书和解析网页内容等步骤,确保用户与服务器之间的安全通信。
799 3
|
监控 网络协议 网络性能优化
网络通信的核心选择:TCP与UDP协议深度解析
在网络通信领域,TCP(传输控制协议)和UDP(用户数据报协议)是两种基础且截然不同的传输层协议。它们各自的特点和适用场景对于网络工程师和开发者来说至关重要。本文将深入探讨TCP和UDP的核心区别,并分析它们在实际应用中的选择依据。
478 3
|
网络协议 网络安全 网络虚拟化
本文介绍了十个重要的网络技术术语,包括IP地址、子网掩码、域名系统(DNS)、防火墙、虚拟专用网络(VPN)、路由器、交换机、超文本传输协议(HTTP)、传输控制协议/网际协议(TCP/IP)和云计算
本文介绍了十个重要的网络技术术语,包括IP地址、子网掩码、域名系统(DNS)、防火墙、虚拟专用网络(VPN)、路由器、交换机、超文本传输协议(HTTP)、传输控制协议/网际协议(TCP/IP)和云计算。通过这些术语的详细解释,帮助读者更好地理解和应用网络技术,应对数字化时代的挑战和机遇。
1215 3
|
存储 网络协议 安全
30 道初级网络工程师面试题,涵盖 OSI 模型、TCP/IP 协议栈、IP 地址、子网掩码、VLAN、STP、DHCP、DNS、防火墙、NAT、VPN 等基础知识和技术,帮助小白们充分准备面试,顺利踏入职场
本文精选了 30 道初级网络工程师面试题,涵盖 OSI 模型、TCP/IP 协议栈、IP 地址、子网掩码、VLAN、STP、DHCP、DNS、防火墙、NAT、VPN 等基础知识和技术,帮助小白们充分准备面试,顺利踏入职场。
1826 2
|
传感器
Modbus协议深入解析
Modbus协议是由Modicon公司(现施耐德电气)于1979年发明的串行通信协议,主要用于工业自动化系统中的PLC通信。本文深入解析了Modbus协议的主从模式、数据类型(线圈、离散输入、保持寄存器、输入寄存器)、帧结构和通信过程,并介绍了其应用场景和重要性。

热门文章

最新文章

推荐镜像

更多
  • DNS