IP 协议相关技术

在与 IP 协议相关的技术中,有一些重要且常见的技术,其中包括 DNS 域名解析、ARP 协议、DHCP 动态获取 IP 地址以及NAT 网络地址转换。这些技术在网络通信中起着关键的作用。

首先,DNS 域名解析是将人类可读的域名转换为 IP 地址的过程。当我们在浏览器中输入一个网址时,浏览器会向 DNS 服务器发送查询请求,以获取与该域名对应的 IP 地址。这个过程涉及到域名服务器的层级查询和缓存,以实现高效的域名解析。

其次,ARP(地址解析协议)是在局域网中解析 IP 地址与 MAC 地址之间对应关系的协议。当一台主机需要与另一台主机通信时,它会发送一个 ARP 请求广播,其中包含了想要知道的目标主机的 IP 地址。同一局域网中的其他设备会解析该 ARP 请求包,如果目标 IP 地址与自身 IP 地址一致,就会将自己的 MAC 地址添加到 ARP 响应包中,返回给发送方。操作系统通常会将第一次获取的 MAC 地址缓存起来,以便下次直接从缓存中找到对应 IP 地址的 MAC 地址,提高通信效率。

DNS

我们在上网时通常使用域名而不是IP地址,因为域名更容易记忆。这种技术的实现是通过DNS域名解析,DNS可以将域名自动转换为具体的IP地址。

在DNS中,域名使用句点进行分隔,例如www.server.com, 句点表示不同层次之间的界限。在域名中,靠右的位置表示层级越高。

由于域名是由外国人发明的,所以思维方式与中国人不同。例如,在表示一个城市地点时,外国人喜欢按从小到大的顺序(例如XX街道 XX区 XX市 XX省),而中国人喜欢按从大到小的顺序(例如XX省 XX市 XX区 XX街道)。根域位于最顶层,下一层是顶级域com,再下面是server.com。

因此,域名的层级关系类似于树状结构:

  • 根DNS服务器
  • 顶级域DNS服务器(com)
  • 权威DNS服务器(server.com)

在互联网中,根域的 DNS 服务器信息被广泛保存在所有 DNS 服务器中,这样任何一个 DNS 服务器都能够轻松地找到并访问根域 DNS 服务器。客户端只需连接到任意一台可用的 DNS 服务器,就能够通过这台服务器找到根域 DNS 服务器,并通过一系列的查询和响应,逐步找到位于下层的目标 DNS 服务器。这种分层的 DNS 服务器体系极大地提高了域名解析的效率和可靠性。

域名解析的工作流程可以描述如下:

首先,浏览器会检查自己的缓存中是否存有所请求域名的IP地址,如果存在则直接使用。如果缓存中没有,则浏览器会向操作系统的缓存请求,如果操作系统的缓存中存在,则返回给浏览器。如果操作系统的缓存中也没有,则浏览器会检查本机的域名解析文件 hosts,如果 hosts 文件中有对应的域名和IP映射关系,则返回给浏览器。

如果以上步骤都没有返回结果,浏览器会通过网络发送DNS请求到本地DNS服务器(也就是在TCP/IP设置中配置的DNS服务器地址)。

  1. 客户端发送DNS请求到本地DNS服务器,询问所需域名的IP地址,例如www.server.com。
  2. 本地DNS服务器接收到客户端的请求后,先在自己的缓存中查找是否存在对应的IP地址记录,如果有,则直接返回给客户端。
  3. 如果本地DNS服务器的缓存中没有所需的IP地址记录,它会向根域名服务器发送请求,询问该域名的顶级域名服务器的地址,例如.com顶级域名服务器的地址。
  4. 根域名服务器收到本地DNS服务器的请求后,发现该域名属于.com顶级域名,返回给本地DNS服务器.com顶级域名服务器的地址。
  5. 本地DNS服务器收到.com顶级域名服务器的地址后,向该顶级域名服务器发送请求,询问所需域名的权威DNS服务器的地址,即负责解析该域名的权威DNS服务器地址。
  6. 顶级域名服务器返回给本地DNS服务器所需域名的权威DNS服务器的地址。
  7. 本地DNS服务器向权威DNS服务器发送请求,询问所需域名的IP地址。
  8. 权威DNS服务器查询自己的记录,并将所需域名对应的IP地址返回给本地DNS服务器。
  9. 本地DNS服务器将IP地址返回给客户端。客户端使用获取到的IP地址与目标服务器建立连接。

至此,经过详细的解析过程,我们成功完成了 DNS 的解析过程。现在,让我来对整个过程进行总结,并将其以图示的方式呈现出来。

DNS(Domain Name System)域名解析的过程非常有趣,它与我们在日常生活中询问路线的过程非常相似,它只是为我们指引方向,而不是亲自带路。

需要注意的是,当我们申请域名时,并没有带上"www"前缀。这个前缀是在域名服务商的后台进行配置的。如果你不进行配置,域名是不会指向你自己的服务器的。此外,你还可以配置多种不同的前缀,以访问不同的服务。并不是更改前缀就需要再次申请一个新的域名。一旦在域名平台购买了域名,通常需要自行进行配置,具体步骤如下:

ARP

在传输一个 IP 数据报的时候,一旦源 IP 地址和目标 IP 地址确定,主机会通过查询「路由表」来确定 IP 数据包的下一跳。然而,网络层的下一层是数据链路层,因此我们还需要知道下一跳的 MAC 地址。主机的路由表中可以找到下一跳的 IP 地址,因此我们可以利用 ARP 协议来获取下一跳的 MAC 地址。

那么,ARP 是如何获取对方的 MAC 地址呢?

简言之,ARP 使用 ARP 请求和 ARP 响应这两种类型的数据包来获取对方的 MAC 地址。

在网络中,当主机需要与其他设备通信时,它会发送一个ARP请求。这个请求包含了主机想要知道的目标设备的MAC地址和对应的IP地址。当同一链路上的设备收到ARP请求后,会检查请求包中的目标IP地址是否与自己的IP地址匹配。如果匹配,该设备将自己的MAC地址放入ARP响应包中返回给主机。

为了提高效率,操作系统通常会将第一次获取到的MAC地址缓存起来,以便下次直接从缓存中获取对应IP地址的MAC地址。这样就不需要再发送ARP请求来获取MAC地址,从而节省了网络资源和时间。

总结

在与IP协议相关的技术中,存在一些非常重要且常见的技术。在本章节中,我们将主要讨论DNS域名解析以及ARP协议,这些技术在网络通信中扮演着关键的角色。

首先,DNS域名解析是将人类可读的域名转换为IP地址的过程。它采用了分层的域名服务器体系,以实现高效的域名解析。

其次,ARP(地址解析协议)用于在局域网中解析IP地址与MAC地址之间的对应关系,以获取下一跳的MAC地址。

在接下来的章节中,我们将详细讲解DHCP动态获取IP地址以及NAT网络地址转换技术。这些技术对于网络通信的顺利进行也具有重要的意义。

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

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

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

  2. ARP 地址分类 NAT技术

    第1章 OSI回顾 1.1 TCP/IP协议族组成 应用层 主机到主机层   互联网层   网络接入层 1.2 总结应用层掌握的协议与端口号对应关系 http(80) telnet(23) ftp(2 ...

  3. 八大 IoT 安全关键技术解析

    IoT 设备的增长也伴随着网络攻击的风险的增长,因此在设计产品时就必须考虑到系统的安全. 高德纳咨询公司最近的报告预测,到 2020 年,全世界将有 200.4 亿的物联网设备相互连接,且平均每天约还 ...

  4. 5G关键技术评述

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

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

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

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

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

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

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

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

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

  9. 以雅酷网为实例从技术上说说dedecms的seo优化要注意哪些?

    目前在做雅酷网 ,雅酷卡是雅酷时空公司的产品,我个人感觉用雅酷卡消费还是比较实惠的,而雅酷卡的特色便是雅酷健身卡,很多站长成天的趴电脑上,可以考虑办一张这样的卡,在周末的时候去健身中心活动活动,还是比 ...

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

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

随机推荐

  1. 聊聊Flink必知必会(二)

    Checkpoint与Barrier Flink是一个有状态的流处理框架,因此需要对状态做持久化,Flink定期保存状态数据到存储空间上,故障发生后从之前的备份中恢复,这个过程被称为Checkpoin ...

  2. 1. CS和BS的优缺点

    1. CS CS : 客户端服务器架构模式 优点 : 充分利用客户端机械的资源 , 减轻服务器的符合 缺点 : 需要安装 : 升级维护成本较高 ‍ 2. BS ‍ 优点 : 客户端不需要安装 : 维护 ...

  3. 一文了解Go语言的匿名函数

    1. 引言 无论是在Go语言还是其他编程语言中,匿名函数都扮演着重要的角色.在本文中,我们将详细介绍Go语言中匿名函数的概念和使用方法,同时也提供一些考虑因素,从而帮助在匿名函数和命名函数间做出选择. ...

  4. Python运维开发之路《高阶函数》

    一.列表生成式,迭代器&生成器 列表生成式 需求:data列表里有如下三个值,需要给每个值加1 1 data = [1,2,3] 2 list = map(lambda x:x+1,data) ...

  5. 【后端面经-Java】AQS详解

    目录 1. AQS是什么? 2. AQS核心思想 2.1 基本框架 2.1.1 资源state 2.1.2 CLH双向队列 2.2 AQS模板 3. 源码分析 3.1 acquire(int) 3.1 ...

  6. 当cmd运行python无法显示中文报错 SyntaxError: Non-UTF-8 code starting with 时

    报错图片: 解决方法: 在python的脚本开头加上 再运行后

  7. [转]-- ISP(图像信号处理)算法概述、工作原理、架构、处理流程

    目录 ISP的主要内部构成: ISP内部包含 CPU.SUP IP(各种功能模块的通称).IF 等设备 ISP的控制结构:1.ISP逻辑 2.运行在其上的firmware ISP上的Firmware包 ...

  8. linux top中 VSS,RSS,PSS,USS 4个字段的解读

    参考文章:linux中top命令 VSS,RSS,PSS,USS 四个内存字段的解读

  9. TypeScript: 類型 'HTMLElement | null' 不可指派給類型 'HTMLElement'。 類型 'null' 不可指派給類型 'HTMLElement'

    报错截图 解决方案 在结尾添加叹号 // 获取页面中food的元素并将其赋值给element this.element = document.getElementById('food')!;

  10. spring-mvc系列:简介和基本使用

    目录 一.简介 1.什么是MVC 2.什么是SpringMVC 3.SpringMVC的特点 二.基本使用 1.开发环境 2.创建maven工程 3.配置web.xml 4.创建SpringMVC的配 ...