引言

在上一章中,我们详细介绍了域名系统(DNS)和地址解析协议(ARP)的工作原理,从而对域名解析和介质访问控制(MAC)地址寻址有了更深入的了解。在今天的章节中,我们将继续探讨动态主机配置协议(DHCP)和网络地址转换(NAT)技术,以便更好地理解IP地址的动态分配和解决IPv4地址枯竭问题的NAT技术的引入。

DHCP

在我们日常生活中,动态主机配置协议(DHCP)是非常常见的,尽管我们可能从未直接配置过DHCP,但它与我们息息相关。举个例子,我们的手机需要上网,我们有没有手动配置过IP地址呢?肯定没有,这是因为我们的手机或者电脑已经自动通过DHCP进行了配置。我们的电脑通常会通过DHCP动态获取IP地址,这大大简化了繁琐的IP配置过程。

接下来,让我们一起来看看我们的电脑是如何通过四个步骤来获取IP地址的过程。

首先需要说明的是,DHCP客户端进程监听的是端口号68,而DHCP服务器进程监听的是端口号67。

DHCP交互过程一共包括4个步骤:

  1. DHCP发现(DHCP DISCOVER):客户端首先发送一个DHCP发现报文,由于客户端没有IP地址,也不知道DHCP服务器的地址,因此使用UDP广播通信。该报文使用广播目的地址255.255.255.255(端口67),并将源IP地址设置为0.0.0.0(端口68)。DHCP客户端将该报文传递给链路层,链路层将帧广播到所有网络设备。
  2. DHCP提供(DHCP OFFER):DHCP服务器收到DHCP发现报文后,用DHCP提供报文向客户端做出响应。该报文仍然使用广播地址255.255.255.255,其中包含服务器提供的可租用的IP地址、子网掩码、默认网关、DNS服务器以及租用期。
  3. DHCP请求(DHCP REQUEST):客户端收到一个或多个服务器的DHCP提供报文后,从中选择一个服务器,并向选中的服务器发送DHCP请求报文,以确认所要求的配置参数。
  4. DHCP确认(DHCP ACK):最后,服务器用DHCP确认报文对DHCP请求报文进行响应,回应所要求的参数。一旦客户端收到DHCP确认后,交互过程完成,客户端可以在租用期内使用由DHCP服务器分配的IP地址。

如果租用的DHCP IP地址快要到期,客户端会向服务器发送DHCP请求报文:

  • 如果服务器同意继续租用,则用DHCP确认报文进行响应,客户端将继续使用该IP地址并延长租期。
  • 如果服务器不同意继续租用,则用DHCP否定确认(DHCP NACK)报文进行响应,客户端必须停止使用该租用的IP地址。

在DHCP交互过程中,全程使用UDP广播通信。

咦,我发现我们正在使用广播方式,但如果 DHCP 服务器和客户端不在同一个局域网中,而且路由器不会转发广播包,那难道每个网络都需要有一个独立的 DHCP 服务器吗?

为了解决这个问题,出现了 DHCP 中继代理。通过使用 DHCP 中继代理,我们可以统一由一个 DHCP 服务器来管理不同网段的 IP 地址分配。这样,我们就能够更有效地管理整个网络。

嗯,具体的运作过程是这样的:当 DHCP 客户端需要获取 IP 地址时,它会向 DHCP 中继代理发送 DHCP 请求包。而 DHCP 中继代理在接收到这个广播包后,会将其以单播的方式发送给 DHCP 服务器。

一旦服务器收到了这个包,它会向 DHCP 中继代理返回应答,并由 DHCP 中继代理将这个包转发给 DHCP 客户端。通过这种方式,即使 DHCP 服务器和客户端不在同一个链路上,我们仍然可以实现对 IP 地址的统一分配和管理。

有了 DHCP 中继代理的存在,我们可以更加灵活地设计和管理网络,不再需要为每个网络单独配置一个 DHCP 服务器,从而提高了网络的效率和可扩展性。

NAT

IPv4 地址的紧缺性是一个现实问题。尽管我们可以通过使用无分类地址来减缓 IPv4 地址消耗速度,但是互联网用户的快速增长仍然导致 IPv4 地址的耗尽风险。

为了应对这个问题,我们引入了网络地址转换(NAT)的方法,再次缓解了 IPv4 地址的耗尽问题。

简单来说,NAT 是一种技术,它在同一公司、家庭、教室等内部网络中的主机与外部通信时,将私有 IP 地址转换为公共 IP 地址。

如果每个私有IP地址都需要一个对应的公有IP地址的话,那么如何解决IPv4地址耗尽的问题呢?这种观点似乎有些站不住脚。

普通的NAT转换的确没有太多意义。不过,由于绝大多数的网络应用都是使用传输层协议TCP或UDP来传输数据,所以可以将IP地址和端口号一起进行转换。这样一来,只需要一个全球IP地址就可以了,这种转换技术被称为网络地址与端口转换NAPT。

或许这听起来有些抽象,但是通过下面的图解,你就能立即明白了。

在这个网络拓扑中,有两个客户端(192.168.1.10和192.168.1.11)同时与服务器(183.232.231.172)进行通信,这两个客户端的本地端口都是1025。

在这种情况下,两个私有IP地址都会被转换为公有地址120.229.175.121,但是通过使用不同的端口号进行区分。为了实现客户端A和B与服务器之间的同时通信,我们需要生成一个NAPT路由器的转换表。这个转换表可以正确地转换地址和端口的组合。这个转换表是在NAT路由器上自动生成的。例如,在TCP的情况下,当建立TCP连接的初始握手SYN包发送后,转换表就会被生成。当收到关闭连接的FIN包的确认应答时,该条目会从转换表中删除。

NAT 确实有着许多优点,但难道就没有任何局限性吗?

当然,没有任何方案是完美的,NAT也有一些缺陷。其中一些问题包括:

  1. 外部网络无法主动与NAT内部服务器建立连接,因为NAT转换表中没有相关记录。

  2. 生成和转换转换表会带来性能开销,可能会影响网络通信的速度和效率。

  3. 如果NAT路由器重启,所有的TCP连接都将被重置,可能导致网络中断和数据丢失。

  4. NAT可能会导致网络延迟,尤其是在大量数据传输和高负载情况下。

虽然NAT在解决IPv4地址短缺问题和网络安全方面发挥了重要作用,但它也有这些限制和缺点。在实际应用中,需要权衡利弊并综合考虑其他解决方案。

总结

在本章中,我们学习了动态主机配置协议(DHCP)和网络地址转换(NAT)技术。DHCP是一种常见的协议,它简化了IP地址配置的过程,通过四个步骤来实现IP地址的动态分配。DHCP中继代理的引入使得在不同网络中只需要一个DHCP服务器来管理IP地址的分配。而NAT技术则解决了IPv4地址的紧缺问题,通过将私有IP地址转换为公共IP地址来实现内部网络与外部通信。NAT还可以实现网络地址与端口转换(NAPT),通过端口号的转换来实现多个客户端与服务器的通信。然而,NAT也存在一些局限性,例如无法主动建立连接和性能开销。综上所述,DHCP和NAT技术在网络中起到了重要的作用,但在实际应用中需要综合考虑其利弊。

解密网络通信的关键技术(下):DNS、ARP、DHCP和NAT,你了解多少?的更多相关文章

  1. 基于隐私保护技术的DNS通信协议介绍

    本文提出了一种基于用户数据报协议的DNS传输中用户隐私保护的加密方法:DNSDEA.该方法采用PKI加密体系与DNS协议相融合,不仅解决了域名隐私保护问题,而且与传统DNS体系相兼容,保持了DNS系统 ...

  2. 5G关键技术评述

    业内重大事件: 张  平:无线通信领域专家,北京邮电大学教授,博士生导师,现任北京邮电大学无线新技术研究所(WTI)所长.泛网无线通信教育部重点实验室主任以及中德软件研究所副所长.张平教授是国家宽带无 ...

  3. 大型网站提速关键技术(页面静态化,memcached,MySql优化)(一)

    一:关键技术介绍: 衡量是否为大型网站的要素: A:PV值(page views 页面浏览量) 访问量大: 带来的问题:1:流量大 -->解决方案:增加带宽,优化程序(视频和图片较浪费带宽,尽量 ...

  4. Java进阶(三)多线程开发关键技术

    原创文章,同步发自作者个人博客,转载请务必以超链接形式在文章开头处注明出处http://www.jasongj.com/java/multi_thread/. sleep和wait到底什么区别 其实这 ...

  5. (1)RGB-D SLAM系列- 工具篇(硬件+关键技术)

    /*************************************************************************************************** ...

  6. 实时视频应用之QoS关键技术分析

    转自:http://www.aiweibang.com/m/detail/104476372.html?from=p 随着WebRTC标准的逐步推广,实时音视频通讯技术受到越来越多公司和技术人员的关注 ...

  7. Java Hotspot G1 GC的一些关键技术

    G1 GC,全称Garbage-First Garbage Collector,通过-XX:+UseG1GC参数来启用,作为体验版随着JDK 6u14版本面世,在JDK 7u4版本发行时被正式推出,相 ...

  8. 5G关键技术研究方向

    对于还没体验4G移动通信魅力的国内的移动通信用户而言,5G也许还是镜中花,雾中月:但对于科研界而言,5G研究已经启程,三星电子5月份宣布,率先开发出了首个基于5G核心技术的移动传输网络,实现每秒1Gb ...

  9. Windows平台下C++插件系统实现的几个关键技术问题及其解决思路

    根据我的实践,在Windows平台下设计并实现一个C++插件系统,需要解决几个关键技术问题.下面我谈谈需要解决的几个关键技术问题以及我想到的简单的解决思路.由于我主要专注于Windows平台C++程序 ...

  10. 的无线通信网络的学习LTE的关键技术HARQ(20141217)

    今天,我们就来一起看一下LTE申请的关键技术HARQ(自己主动混合重传技术) 因为在信道传输过程中的信息,它会产生信息丢失,因此,为了维持的信息的完整性.总是有重发信息,完成所有的迄今收到的资料. 首 ...

随机推荐

  1. ClickHouse技术研究及语法简介

    本文对Clickhouse架构原理.语法.性能特点做一定研究,同时将其与mysql.elasticsearch.tidb做横向对比,并重点分析与mysql的语法差异,为有mysql迁移clickhou ...

  2. 免费好用的录屏工具 —— EVCapture --九五小庞

    下载地址:https://wwfv.lanzoue.com/b022u08ib密码:acdu 1,简介 使用过很多种屏幕录像软件,最终这个软件留下来存到我的工具宝库. 因为界面非常简单友好,功能也很好 ...

  3. Task Execution and Scheduling In SpringBoot

    开天辟地 Task Execution and Scheduling In the absence of an Executor bean in the context, Spring Boot au ...

  4. python笔记:第二章基本数据类型

    基本数据类型 Python中的数据类型可以分为五大类:字符串.数字.容器.布尔.None 1.字符串 可以使用单引号或双引号创建字符串,可以用加号将两个字符串合并 name = '小明' age = ...

  5. linux150常用命令

    Linux最常用150个命令汇总 线上查询及帮助命令(2个) man 查看命令帮助,命令的词典,更复杂的还有info,但不常用. help 查看Linux内置命令的帮助,比如cd命令. 文件和目录操作 ...

  6. 2020 OC项目集成flutter

    看了网上基本上都是相同套路,但是到我这就不行了,终于解决了, 主要就是profile文件编写, 1.在oc项目的同级目录项创建flutter模块 就是在oc项目的父级目录下,执行 flutter cr ...

  7. 将mongodb注册成windows(win10)的服务

    首先参考这个大佬的文章: 下载mongodb 然后解压 为了方便路径,我改了个名字MongoDB, 然后把它拖到了c盘的Program Files文件夹中 这样他的路径就是 (这个路径在很多地方都要用 ...

  8. linux 查看进程使用的内存大小

    你可以使用 ps 命令结合 grep 命令来查看进程使用的内存大小.以下是示例代码: ps aux | grep <进程名> 这个命令会列出所有匹配 <进程名> 的进程,并显示 ...

  9. Linux下实现程序开机自启(rc.local 和 systemctl)

    需求: 实现了一个程序,需要在ubuntu上跑起来.能开机自启,且崩溃了也能自己重启.有两种实现方式,个人推荐第二种. 方式1: 实现方式: 直接将要启动程序的运行命令加在 /etc/rc.local ...

  10. asp.net core之Options

    本文将介绍 ASP.NET Core 中的 Options 概念和使用方法.Options 是一种配置管理机制,可以将应用程序的配置信息从代码中分离出来,提高代码的可维护性和可测试性.我们将详细介绍如 ...