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

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

相关文章

深入探索协同过滤:从原理到推荐模块案例

文章目录 前言一、协同过滤1. 基于用户的协同过滤(UserCF)2. 基于物品的协同过滤(ItemCF)3. 相似度计算方法 二、相似度计算方法1. 欧氏距离2. 皮尔逊相关系数3. 杰卡德相似系数4. 余弦相似度 三、推荐模块案例1.基于文章的协同过滤推荐功能2.基于用户的协同过滤推荐功能 前言     在信息过载的时代,推荐系统成为连接用户与内容的桥梁。本文聚焦于

hdu4407(容斥原理)

题意:给一串数字1,2,......n,两个操作:1、修改第k个数字,2、查询区间[l,r]中与n互质的数之和。 解题思路:咱一看,像线段树,但是如果用线段树做,那么每个区间一定要记录所有的素因子,这样会超内存。然后我就做不来了。后来看了题解,原来是用容斥原理来做的。还记得这道题目吗?求区间[1,r]中与p互质的数的个数,如果不会的话就先去做那题吧。现在这题是求区间[l,r]中与n互质的数的和

Linux 网络编程 --- 应用层

一、自定义协议和序列化反序列化 代码: 序列化反序列化实现网络版本计算器 二、HTTP协议 1、谈两个简单的预备知识 https://www.baidu.com/ --- 域名 --- 域名解析 --- IP地址 http的端口号为80端口,https的端口号为443 url为统一资源定位符。CSDNhttps://mp.csdn.net/mp_blog/creation/editor

【机器学习】高斯过程的基本概念和应用领域以及在python中的实例

引言 高斯过程(Gaussian Process,简称GP)是一种概率模型,用于描述一组随机变量的联合概率分布,其中任何一个有限维度的子集都具有高斯分布 文章目录 引言一、高斯过程1.1 基本定义1.1.1 随机过程1.1.2 高斯分布 1.2 高斯过程的特性1.2.1 联合高斯性1.2.2 均值函数1.2.3 协方差函数(或核函数) 1.3 核函数1.4 高斯过程回归(Gauss

ASIO网络调试助手之一:简介

多年前,写过几篇《Boost.Asio C++网络编程》的学习文章,一直没机会实践。最近项目中用到了Asio,于是抽空写了个网络调试助手。 开发环境: Win10 Qt5.12.6 + Asio(standalone) + spdlog 支持协议: UDP + TCP Client + TCP Server 独立的Asio(http://www.think-async.com)只包含了头文件,不依

poj 3181 网络流,建图。

题意: 农夫约翰为他的牛准备了F种食物和D种饮料。 每头牛都有各自喜欢的食物和饮料,而每种食物和饮料都只能分配给一头牛。 问最多能有多少头牛可以同时得到喜欢的食物和饮料。 解析: 由于要同时得到喜欢的食物和饮料,所以网络流建图的时候要把牛拆点了。 如下建图: s -> 食物 -> 牛1 -> 牛2 -> 饮料 -> t 所以分配一下点: s  =  0, 牛1= 1~

poj 3068 有流量限制的最小费用网络流

题意: m条有向边连接了n个仓库,每条边都有一定费用。 将两种危险品从0运到n-1,除了起点和终点外,危险品不能放在一起,也不能走相同的路径。 求最小的费用是多少。 解析: 抽象出一个源点s一个汇点t,源点与0相连,费用为0,容量为2。 汇点与n - 1相连,费用为0,容量为2。 每条边之间也相连,费用为每条边的费用,容量为1。 建图完毕之后,求一条流量为2的最小费用流就行了

poj 2112 网络流+二分

题意: k台挤奶机,c头牛,每台挤奶机可以挤m头牛。 现在给出每只牛到挤奶机的距离矩阵,求最小化牛的最大路程。 解析: 最大值最小化,最小值最大化,用二分来做。 先求出两点之间的最短距离。 然后二分匹配牛到挤奶机的最大路程,匹配中的判断是在这个最大路程下,是否牛的数量达到c只。 如何求牛的数量呢,用网络流来做。 从源点到牛引一条容量为1的边,然后挤奶机到汇点引一条容量为m的边

【Linux】应用层http协议

一、HTTP协议 1.1 简要介绍一下HTTP        我们在网络的应用层中可以自己定义协议,但是,已经有大佬定义了一些现成的,非常好用的应用层协议,供我们直接使用,HTTP(超文本传输协议)就是其中之一。        在互联网世界中,HTTP(超文本传输协议)是一个至关重要的协议,他定义了客户端(如浏览器)与服务器之间如何进行通信,以交换或者传输超文本(比如HTML文档)。

hdu4407容斥原理

题意: 有一个元素为 1~n 的数列{An},有2种操作(1000次): 1、求某段区间 [a,b] 中与 p 互质的数的和。 2、将数列中某个位置元素的值改变。 import java.io.BufferedInputStream;import java.io.BufferedReader;import java.io.IOException;import java.io.Inpu