[网络原理]关于网络的基本概念 及 协议

2024-09-06 02:52

本文主要是介绍[网络原理]关于网络的基本概念 及 协议,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • 一. 关于网络的概念介绍
    • 1. 局域⽹LAN
    • 2. ⼴域⽹WAN
    • 3. 主机
    • 4. 路由器
    • 5. 交换机
    • IP地址
    • 端口号
  • 二. 协议
    • 协议分层
    • TCP/IP五层模型(或四层)
    • OSI七层模型
    • 封装分用

一. 关于网络的概念介绍

1. 局域⽹LAN

局域⽹,即 Local Area Network,简称LAN。
Local 即标识了局域⽹是本地,局部组建的⼀种私有⽹络。
局域⽹内的主机之间能⽅便的进⾏⽹络通信,⼜称为内⽹;局域⽹和局域⽹之间在没有连接的情况
下,是⽆法通信的。

2. ⼴域⽹WAN

⼴域⽹,即 Wide Area Network,简称WAN。
通过路由器,将多个局域⽹连接起来,在物理上组成很⼤范围的⽹络,就形成了⼴域⽹。⼴域⽹内部
的局域⽹都属于其⼦⽹。
全世界现在最大的广域网, 就叫做The Internet, 万维网

3. 主机

简单来说, 就是上网的设备, 包括电脑, 手机…其他设备

4. 路由器

用来组建网络的重要设备
一个路由器上有一个WAN口和若干个LAN口
LAN口用来连接自己的主机
WAN口用来连接运营商自己的路由器
这个路由器上面也有一个WAN口和若干个LAN口, WAN再用来连接更大的路由器
这样, 就把越来越多的设备组件到网络中了
此时, 自己买的路由器和主机就构成了一个局域网
在这里插入图片描述

5. 交换机

也是一个重要的网络设备
路由器虽然有很多网口, 可以让你插网线, 但是实际上, 路由器上的口可能不够用
此时就可以通过使用交换机, 对LAN接口进行拓展

IP地址

表示网络上的一个设备的位置
通过这个位置找到这个设备, 可以进行进一步通信
IP地址, 其实是32为的整数, 就是4个字节的数字
往往使用"点分十进制"方式来表示IP地址
使用3个. 把上述IP地址分成4哥部分, 每个部分一个字节, 表示范围是0-255

在这里插入图片描述

端口号

表示一个主机上的不同应用程序
要求每个程序, 在启动的时候, 就需要关联(也可以叫绑定)上一个和别人不重复的端口号

有的程序, 是有固定端口号的
例如: http服务器, 80 ssh服务器 22…, 这些知名的端口号一共有1024个
但是这些端口号, 对我们来说只是建议, 比如我们弄一个http服务器, 可以使用80, 也可以使用别的

二. 协议

协议, 就是一种约定, 通信双方, 对于通信规则的约定
协议, 可以认可面非常广, 也可以是认可面不广的

协议分层

网络通信, 是一个非常复杂的事情, 这个过程中涉及到很多细节
如果使用一个协议来约定上述所有的细节, 这个协议就会非常庞大, 非常复杂
此时, 就可以把一个功能复杂的协议, 拆分成多个功能单一的协议

协议分层, 就是把很多协议, 按照功能分成不同的层级, 每个层级都有对应的主线任务
上层协议会调用下层协议的功能, 下层协议给上层协议提供服务

分层的好处:
分层最⼤的好处,类似于⾯向接⼝编程:定义好两层间的接⼝规范,让双⽅遵循这个规范来对接。
在代码中,类似于定义好⼀个接⼝,⼀⽅为接⼝的实现类(提供⽅,提供服务),⼀⽅为接⼝的使⽤
类(使⽤⽅,使⽤服务):
• 对于使⽤⽅来说,并不关⼼提供⽅是如何实现的,只需要使⽤接⼝即可
• 对于提供⽅来说,利⽤封装的特性,隐藏了实现的细节,只需要开放接⼝即可。

当前网络, 就有很多协议, 这些协议就是按照一定的分层规则组织起来的

TCP/IP五层模型(或四层)

就是真实世界中采取的网络分层模型, 咱们接触到的网络, 大部分都是TCP/IP模型

  1. 物理层
    就是硬件层面上的相关约定
  2. 数据链路层
    关注的是, 通信过程中, 两个相邻的节点之间的通信
  3. 网络层
    关注的是, 通信中, 通信路径的规划, 规划出的路径, 就决定了要经过哪些结点
  4. 传输层
    关注的是通信双方的起点和终点
  5. 应用层
    和具体的应用程序直接相关, 传输的数据是干啥用的, 如何使用…

举例:
我要在网上买卫生纸
我要怎么使用卫生纸 ---- 应用层
我和商家都要提供各自的地址和电话 ---- 传输层
快递公司, 根据快的目的地, 分配搭配不同的运输路线上 ---- 网络层
假设快递是从北京发杭州, 中间可能会经过上海, 那么从北京到上海可能是铁路运输, 从上海到杭州可能轮船运输, 只关注两个相邻节点之间的通信 ---- 数据链路层

如果说成是四层模型, 就是不算物理层

OSI七层模型

这种模型, 只存在于教科书上, 客观世界不存在
比TCP/IP五层模型, 多了表示层和会话层
在TCP / IP五层模型中, 应用层, 表示层, 会话层都合并成应用层

在这里插入图片描述

笔试题:
路由器工作在协议中的那一层?
交换机工作在协议中的那一层?
如果是在考试卷子上, 就是指经典的路由器交换机
路由器工作在网络层
交换机工作在数据链路层
但是在真实世界中, 现在的路由去交换机功能越来越多, 甚至有的路由器交换机能工作在应用层

封装分用

协议的层和层之间
上层协议用调用下层协议
上层协议给上层提供服务

通过一个例子来理解:
假设A通过qq给B发送hello

第一层: 应用层
qq中就有应用层的网络协议
假设这个协议就是约定了数据按照什么格式来组织
网络上传输的数据, 本质上是二进制的字符串, 因此就要把要传输的发送人, 接收人, 消息时间, 消息内容…这些结构化的数据组织成一个字符串中, 按照协议里规定的格式来组织

结构化数据 --> 字符串 这个过程称为**“序列化”**
字符串 --> 结构化数据 这个过程称为**“反序列化”**

A在聊天窗口中, 输入hello, 点击发送, qq应用程序, 首先就把上述要传递的内容, 组织成**“应用层数据包”**
假设是这样组织的:
发送人qq号, 接收人qq号, 发送时间, 消息正文\n
在这里插入图片描述
接下来, 应用层要调用传输层提供的api, 就把刚才的应用层数据交给了传输层(进入到系统内核了)

第二层: 传输层
传输层拿到应用层数据包后, 就会把这个数据包进行进一步封装, 构造成数据层传输包
在传输层, 典型有两个协议, TCP, UDP
此处假设用UDP来作为传输协议
UDP会给数据加上报头, 报头中放的是UDP相关的属性(比如发件人和收件人的端口号, 就在UDP报头中)
在这里插入图片描述
传输层构造好数据包之后, 就会继续把数据包交给网络层(传输层会调用网络层提供的api, 这个调用过程, 都是系统内核自行负责的, 程序猿感知不到)

第三层: 网络层
网络层拿到传输层数据包后, 就会把这个数据包进行进一步封装, 构造成IP传输包
典型的协议就是IP协议
IP协议也会给数据包加上IP报头, 存放的是IP地址(这里就包含了收件人和发件人的IP地址)
在这里插入图片描述
网络层构造好数据包之后, 就会继续把数据包交给数据链路层(网络层会调用数据链路层提供的api, 这个调用过程, 都是系统内核自行负责的, 程序猿感知不到, 这里的api, 往往是网卡的驱动程序提供的)

驱动程序: 硬件厂商, 发布硬件时, 提供配套的软件(驱动程序), 通过驱动程序, 可以让操作系统实现对硬件的精细控制

第四层:数据链路层
典型协议: 以太网协议
以太网也有自己的数据包格式, 就会拿到上述的IP数据包, 进一步封装
在这里插入图片描述
上述数据已经进入到网卡驱动中了

第五层: 物理层
上述的以太网数据帧, 本质上还是0101二进制数据
硬件设备, 要把上述二进制数据, 转成光信号 / 电信号 / 电磁波, 才能真正的发射

像上述层层包装数据, 不停地加载数据报头的过程, 称为"封装"

上述数据, 并非直接到了B, 而是要先到和A连接的交换机 / 路由器
交换机和路由器也要封装分用, 也是上述的过程
交换机, 封装分用到数据链路层, 即可直到下一步如何转发
路由器, 封装到网络层, 即可知道下一步如何转发

那么当数据到达B的主机, 完成上述过程的逆过程, 即分用过程, B即可收到A的消息了

这篇关于[网络原理]关于网络的基本概念 及 协议的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Linux中压缩、网络传输与系统监控工具的使用完整指南

《Linux中压缩、网络传输与系统监控工具的使用完整指南》在Linux系统管理中,压缩与传输工具是数据备份和远程协作的桥梁,而系统监控工具则是保障服务器稳定运行的眼睛,下面小编就来和大家详细介绍一下它... 目录引言一、压缩与解压:数据存储与传输的优化核心1. zip/unzip:通用压缩格式的便捷操作2.

从原理到实战深入理解Java 断言assert

《从原理到实战深入理解Java断言assert》本文深入解析Java断言机制,涵盖语法、工作原理、启用方式及与异常的区别,推荐用于开发阶段的条件检查与状态验证,并强调生产环境应使用参数验证工具类替代... 目录深入理解 Java 断言(assert):从原理到实战引言:为什么需要断言?一、断言基础1.1 语

MySQL中的表连接原理分析

《MySQL中的表连接原理分析》:本文主要介绍MySQL中的表连接原理分析,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、背景2、环境3、表连接原理【1】驱动表和被驱动表【2】内连接【3】外连接【4编程】嵌套循环连接【5】join buffer4、总结1、背景

如何在Spring Boot项目中集成MQTT协议

《如何在SpringBoot项目中集成MQTT协议》本文介绍在SpringBoot中集成MQTT的步骤,包括安装Broker、添加EclipsePaho依赖、配置连接参数、实现消息发布订阅、测试接口... 目录1. 准备工作2. 引入依赖3. 配置MQTT连接4. 创建MQTT配置类5. 实现消息发布与订阅

深度解析Spring AOP @Aspect 原理、实战与最佳实践教程

《深度解析SpringAOP@Aspect原理、实战与最佳实践教程》文章系统讲解了SpringAOP核心概念、实现方式及原理,涵盖横切关注点分离、代理机制(JDK/CGLIB)、切入点类型、性能... 目录1. @ASPect 核心概念1.1 AOP 编程范式1.2 @Aspect 关键特性2. 完整代码实

Java Stream的distinct去重原理分析

《JavaStream的distinct去重原理分析》Javastream中的distinct方法用于去除流中的重复元素,它返回一个包含过滤后唯一元素的新流,该方法会根据元素的hashcode和eq... 目录一、distinct 的基础用法与核心特性二、distinct 的底层实现原理1. 顺序流中的去重

使用Python进行GRPC和Dubbo协议的高级测试

《使用Python进行GRPC和Dubbo协议的高级测试》GRPC(GoogleRemoteProcedureCall)是一种高性能、开源的远程过程调用(RPC)框架,Dubbo是一种高性能的分布式服... 目录01 GRPC测试安装gRPC编写.proto文件实现服务02 Dubbo测试1. 安装Dubb

Spring @Scheduled注解及工作原理

《Spring@Scheduled注解及工作原理》Spring的@Scheduled注解用于标记定时任务,无需额外库,需配置@EnableScheduling,设置fixedRate、fixedDe... 目录1.@Scheduled注解定义2.配置 @Scheduled2.1 开启定时任务支持2.2 创建

Spring Boot 实现 IP 限流的原理、实践与利弊解析

《SpringBoot实现IP限流的原理、实践与利弊解析》在SpringBoot中实现IP限流是一种简单而有效的方式来保障系统的稳定性和可用性,本文给大家介绍SpringBoot实现IP限... 目录一、引言二、IP 限流原理2.1 令牌桶算法2.2 漏桶算法三、使用场景3.1 防止恶意攻击3.2 控制资源

Python中使用uv创建环境及原理举例详解

《Python中使用uv创建环境及原理举例详解》uv是Astral团队开发的高性能Python工具,整合包管理、虚拟环境、Python版本控制等功能,:本文主要介绍Python中使用uv创建环境及... 目录一、uv工具简介核心特点:二、安装uv1. 通过pip安装2. 通过脚本安装验证安装:配置镜像源(可