网络原理——TCP/IP--数据链路层,DNS

2024-06-02 16:44

本文主要是介绍网络原理——TCP/IP--数据链路层,DNS,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在这里插入图片描述

T04BF

👋专栏: 算法|JAVA|MySQL|C语言

🫵 今天你敲代码了吗

目录

      • 数量链路层
        • 目的地址和原地址
        • 类型
        • 校验和
      • DNS

数量链路层

主要的协议是以太网协议.一个横跨数据链路层和 物理层的协议,既包含了数据链路层的内容, 也包含了⼀些物理层的内容

我们来了解一下以太网协议的格式
在这里插入图片描述
是像UDP一样比较简单的协议

目的地址和原地址

在这里插入图片描述
这是实际上指的是mac地址/物理地址

实际上,mac地址 和 IP地址,都是为了区分不同的主机上的设备,是由两伙人独立各自提出的,区别在于,mac地址是6个字节,数量目前来说还是够用的,因此可以认为是 每个设备都有唯一的mac地址,因此物理地址,也可以作为是 一台主机上面的一种身份标识

到后面,两种方式都被保留了下来,但是给他们分配了不同的工作

Ip地址的作用是支持整个传输过程转发

而Mac地址的作用是 支持两个相邻节点之间的转发

假设有一种情况是这样的
在这里插入图片描述
此时一个网络数据从A想要发给B

总的,目标IP是5.6.7.8

此时程序员写代码的时候,就直接告诉计算机,数据要往5.6.7.8这个主机发送

主机A就查询路由表,发现这个Ip在路由表里面没有,就将数据交给下一跳

那么IP层就决定了要找那个朋友,到了数据链路层就要决定,具体要怎么找(即数据包要从路由器的哪个接口发送出去)

此时主机 / 路由器在数据链路层里面也维护了一张表,这个表就维护了每个网口,以及网口对应端的设备的mac地址关联关系,就会根据这个来发

类型

在这里插入图片描述
就是用来区分,当前数据在分用的时候,是交给哪个协议

比如说分用的时候,发现类型是 0x0800的时候,此时就会将这个数据交给网络层的IP协议
在这里插入图片描述
但是我们这里会注意到,实际上一个以太网数据帧携带的最大的数据报的长度就只是1500字节

完全不够用

但是,实际上我们在IP协议讲到的拆包 组包问题,其实当IP协议达到1500字节的时候,就已经触发了
目的就是确保 数据报能够被以太网数据报装下

此处的1500也称为MTU,是和硬件结构相关联的

MTU这个东西,对于不同的数据链路层协议,是不一样的

至于这里的ARA 和 PARP,都不会携带业务上载荷数据,而是针对转发数据的过程起到"辅助"的作用

ARA协议是为了给每个路由器 / 交换机建立一个"转发表"(不是路由表)

这个表里面就记载了IP地址 =>mac地址映射

表项里面只是包含,路由器 / 交换机 周围的邻居设备

我们刚刚谈到的转发数据的过程中,确定接下来往哪里走,当路由器 / 交换机知道 下一跳的Ip(查路由表)

根据下一跳的Ip,就会去查转发表,此时就知道Ip对应的mac / 端口是哪个,然后再发

实际上这个东西的生成就比较简单,该设备在局域网中 通过广播地址,发送ARP数据包,收到的设备,都会返回ARP响应,响应里面就会包含每个设备,IP和mac

设备的转发表就可以保存上述的信息了

校验和

在这里插入图片描述
和我们之前讲过的校验和一样
此处也是只管报头的即可

DNS

DNS是一种重要的应用层协议,指的就是域名解析系统

我们之前讲过的IP地址,是32位的整数(IPV4),我们通过点分十进制将他更好的表示

为了让Ip地址给人使用更加方便,就引入DNS

域名就是一串单词,就可以通过这一串单词,来表示某个 / 某组IP地址了

比如我们常见的 baidu.com

在很早的时候,是有一个专门的文件,用来维护域名和Ip的映射关系,这个文件就是hosts文件

这个文件至今还存在
在这里插入图片描述
在以前,计算机访问各种域名,就会在这里进行查询

曾经很有用

但是现在不再使用了

之前每个人的电脑上,都会存有这样一个很大的文件,存有 所有的网站的域名对应的情况

但是弊端就在,这里的数据不方便更新,每天都有新的网站出现,也会有旧的网站消亡

导致文件就需要频繁更新

取而代之的就是搭载的DNS服务器,就是将这样的映射关系,使用DNS服务器来保存

此时我们的电脑就不必保存hosts了

如果要访问域名,就可以通过访问DNS服务器来查询到对应的IP地址了

但是越来越多的上网设备都需要使用DNS服务器,就会给DNS服务器造成很大的压力

解决方法就是:

(1)客户端缓存

当我们的电脑访问某个域名的时候,就会得到IP,此时就记住了,下次再访问同一个域名的时候,就不会重新查询DNS服务器了

这样的操作之后,就会使得DNS的服务器的压力减小不下百倍

(2)分布式的方式

全世界的各个地方,建设了很多DNS镜像服务器

比如国内的联通,电信,移动…,他们也会搭建DNS镜像服务器,此时我们请求的DNS服务器,就只需要就近访问我们附近的镜像服务器即可

但是同时也会引入新的麻烦,假设某个区域的DNS服务器挂了,可能就会对这一区域的设备造成影响(网页打不开了)

当前的域名体系是"分级"的体系
在这里插入图片描述
com就是一级域名,sogou就是2级域名,pic就是3级域名

DNS服务器是按照分组的方式,来存储不同的域名服务器的

域名有很多结尾:

com => 公司

org => 组织…

感谢您的访问!!期待您的关注!!!

在这里插入图片描述

T04BF

🫵 今天记得敲代码

这篇关于网络原理——TCP/IP--数据链路层,DNS的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1024521

相关文章

SpringBoot分段处理List集合多线程批量插入数据方式

《SpringBoot分段处理List集合多线程批量插入数据方式》文章介绍如何处理大数据量List批量插入数据库的优化方案:通过拆分List并分配独立线程处理,结合Spring线程池与异步方法提升效率... 目录项目场景解决方案1.实体类2.Mapper3.spring容器注入线程池bejsan对象4.创建

PHP轻松处理千万行数据的方法详解

《PHP轻松处理千万行数据的方法详解》说到处理大数据集,PHP通常不是第一个想到的语言,但如果你曾经需要处理数百万行数据而不让服务器崩溃或内存耗尽,你就会知道PHP用对了工具有多强大,下面小编就... 目录问题的本质php 中的数据流处理:为什么必不可少生成器:内存高效的迭代方式流量控制:避免系统过载一次性

C#实现千万数据秒级导入的代码

《C#实现千万数据秒级导入的代码》在实际开发中excel导入很常见,现代社会中很容易遇到大数据处理业务,所以本文我就给大家分享一下千万数据秒级导入怎么实现,文中有详细的代码示例供大家参考,需要的朋友可... 目录前言一、数据存储二、处理逻辑优化前代码处理逻辑优化后的代码总结前言在实际开发中excel导入很

ShardingProxy读写分离之原理、配置与实践过程

《ShardingProxy读写分离之原理、配置与实践过程》ShardingProxy是ApacheShardingSphere的数据库中间件,通过三层架构实现读写分离,解决高并发场景下数据库性能瓶... 目录一、ShardingProxy技术定位与读写分离核心价值1.1 技术定位1.2 读写分离核心价值二

深度解析Python中递归下降解析器的原理与实现

《深度解析Python中递归下降解析器的原理与实现》在编译器设计、配置文件处理和数据转换领域,递归下降解析器是最常用且最直观的解析技术,本文将详细介绍递归下降解析器的原理与实现,感兴趣的小伙伴可以跟随... 目录引言:解析器的核心价值一、递归下降解析器基础1.1 核心概念解析1.2 基本架构二、简单算术表达

MyBatis-plus处理存储json数据过程

《MyBatis-plus处理存储json数据过程》文章介绍MyBatis-Plus3.4.21处理对象与集合的差异:对象可用内置Handler配合autoResultMap,集合需自定义处理器继承F... 目录1、如果是对象2、如果需要转换的是List集合总结对象和集合分两种情况处理,目前我用的MP的版本

深入浅出Spring中的@Autowired自动注入的工作原理及实践应用

《深入浅出Spring中的@Autowired自动注入的工作原理及实践应用》在Spring框架的学习旅程中,@Autowired无疑是一个高频出现却又让初学者头疼的注解,它看似简单,却蕴含着Sprin... 目录深入浅出Spring中的@Autowired:自动注入的奥秘什么是依赖注入?@Autowired

Debian 13升级后网络转发等功能异常怎么办? 并非错误而是管理机制变更

《Debian13升级后网络转发等功能异常怎么办?并非错误而是管理机制变更》很多朋友反馈,更新到Debian13后网络转发等功能异常,这并非BUG而是Debian13Trixie调整... 日前 Debian 13 Trixie 发布后已经有众多网友升级到新版本,只不过升级后发现某些功能存在异常,例如网络转

GSON框架下将百度天气JSON数据转JavaBean

《GSON框架下将百度天气JSON数据转JavaBean》这篇文章主要为大家详细介绍了如何在GSON框架下实现将百度天气JSON数据转JavaBean,文中的示例代码讲解详细,感兴趣的小伙伴可以了解下... 目录前言一、百度天气jsON1、请求参数2、返回参数3、属性映射二、GSON属性映射实战1、类对象映

从原理到实战解析Java Stream 的并行流性能优化

《从原理到实战解析JavaStream的并行流性能优化》本文给大家介绍JavaStream的并行流性能优化:从原理到实战的全攻略,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的... 目录一、并行流的核心原理与适用场景二、性能优化的核心策略1. 合理设置并行度:打破默认阈值2. 避免装箱