javaEE - 7( 网络原理初识 --- 4000字 )

一:网络初识

计算机的独立模式是指多台计算机在网络中相互独立运行,彼此之间不共享资源或信息。在早期,计算机主要采用独立模式,每台计算机都拥有自己的操作系统、应用程序和数据,它们之间没有直接的连接或通信。

在独立模式下,用户需要手动将数据从一个计算机传输到另一个计算机。可以通过使用可移动介质,如软盘或磁带,将数据从一台计算机复制到另一台计算机来实现。这种方式非常耗时且容易出错。

此外,计算机之间也无法共享硬件资源,例如打印机或存储设备。每台计算机需要具有自己的独立设备,这导致了资源浪费和设备利用率低的问题。

在这里插入图片描述

由于独立模式的局限性,人们开始寻求一种更有效的方式来连接和共享计算机资源,这就引出了联机模式的概念,即计算机之间通过网络连接在一起,并能够共享资源和信息,数据共享本质是网络数据传输,即计算机之间通过网络来传输数据,也称为网络通信。

根据网络互连的规模不同,可以将网络划分为局域网和广域网。

1.1 局域网 LAN

局域网,即 Local Area Network,简称 LAN,又称为内网,局域网是指在一个相对较小范围内( 例如办公室、学校、家庭等 )建立起来的网络。它的主要作用是提供内部计算机之间的通信和资源共享。在局域网中,计算机可以共享文件、打印机、数据库和其他资源,这样可以提高工作效率和便利性。

1.1.1 局域网的连接

局域网和局域网之间在没有连接的情况下,是无法通信的,局域网组建网络的方式有很多种:

  1. 基于网线直连

在这里插入图片描述

  1. 基于集线器组建

在这里插入图片描述

加粗样式

  1. 基于交换机组建

在这里插入图片描述

  1. 基于交换机和路由器组建
    在这里插入图片描述

1.2 广域网 WAN

广域网,即 Wide Area Network,简称 WAN,它是指连接多个局域网,在物理上组成很大范围的网络,它利用各种通信线路、设备和协议将地理位置相对较远的分散局域网连接在一起,形成一个覆盖范围更广的网络。

一个路由器可以连接一个局域网,接着通过多个路由器把多个局域网连接成广域网。

在这里插入图片描述

广域网内部的局域网都属于其子网。

二:网络通信基础

网络互连的目的是进行网络数据传输,网络主机中的不同进程间数据的传输是基于网络传输数据的,那么,在组建的网络中,如何判断到底是从哪台主机,将数据传输到哪台主机呢?这就需要使用 IP 地址来标识。

2.1 IP 地址

IP 地址是互联网协议中用于标识和定位网络设备的一串数字,用于标识网络主机、其他网络设备的网络地址,IP 地址是一个 32 位的二进制数,形式通常如下:

  • 01100100.00000100.00000101.00000110

当然我们也可以用“点分十进制”的方式来表示 IP 地址,如:

  • 100.4.5.6

此外还有一个特殊的 IP :

  • 127 . *

这个 IP 地址用于本机环回测试,通常是127.0.0.1,本机环回主要用于本机到本机的网络通信,对于开发网络通信的程序而言,常见的开发方式都是本机到本机的网络通信。

IP 地址解决了网络通信时,定位网络主机的问题,但是还存在一个问题,传输到目的主机后,由哪个进程来接收这个数据呢?这就需要端口号来标识。

2.2 端口号

在网络通信中,IP 地址用于标识主机网络地址,而端口号用于定位主机中的进程。进程通过绑定一个端口号,来发送及接收网络数据,这就类似发送快递时,不光需要指定收货地址( IP地址 ),还需要指定收货人( 端口号 )

系统端口号范围为 0 ~ 65535,其中:0 ~ 1023 为知名端口号,这些端口预留给服务端程序绑定广泛使用的应用层协议,如:

  • 22 端口:预留给 SSH 服务器绑定 SSH 协议
  • 21 端口:预留给 FTP 服务器绑定 FTP 协议
  • 23 端口:预留给 Telnet 服务器绑定 Telnet 协议
  • 80 端口:预留给 HTTP 服务器绑定 HTTP 协议
  • 443 端口:预留给 HTTPS 服务器绑定 HTTPS 协议

注意:以上只是说明 0 ~ 1023 范围的知名端口号用于绑定知名协议,但也可以使用其他 1024 ~65535 范围内的端口来绑定知名协议。

注意:

  • 一个端口号只能绑定一个进程,但一个进程可以绑定多个端口号。
  • 协议只是一种标准,具体由协议支撑的服务才是进程

2.3 协议

有了 IP 地址和端口号,可以定位到网络中唯一的一个进程,但还存在一个问题,网络通信是基于二进制 0 / 1 数据来传输,如何告诉对方发送的数据是什么样的呢?

网络通信传输的数据类型可能有多种:图片,视频,文本等。同一个类型的数据,格式可能也不同,比如发送一个文本字符串“你好!”:如何标识发送的数据是文本类型,及文本的编码格式呢?答案是使用协议来规定双方的数据格式。

协议是网络协议的简称,网络协议是网络通信所有网络设备都必须共同遵从的一组约定、规则。比如怎么样建立连接、怎么样互相识别等。只有遵守这个约定,计算机之间才能相互通信交流。

2.3.1 协议的作用

在这里插入图片描述

计算机之间的传输媒介是光信号和电信号。通过 “频率” 和 “强弱” 来表示 0 和 1 这样的信息。要想传递各种不同的信息,就需要约定好双方的数据格式。为什么呢?

  • 计算机生产厂商有很多;
  • 计算机操作系统,也有很多;
  • 计算机网络硬件设备,还是有很多;

如何让这些不同厂商之间生产的计算机能够相互顺畅的通信?

如果这个厂商按照 a 的方式去定义和解析协议,那个厂商按照 b 的方式定义和解析协议,那么这就不难够保证通信的畅通了,所以这时就需要有人站出来,约定一个共同的标准,大家都来遵守,这样才能够使不同厂商之间生产的计算机能够相互顺畅的通信,而这种大家都遵守的标准就是网络协议。

2.4 五元组

在 TCP / IP 协议中,用五元组来标识一个网络通信:

  1. 源 IP:标识源主机
  2. 源端口号:标识源主机中该次通信发送数据的进程
  3. 目的 IP:标识目的主机
  4. 目的端口号:标识目的主机中该次通信接收数据的进程
  5. 协议号:标识发送进程和接收进程双方约定的数据格式

在这里插入图片描述
五元组在网络通信中的作用,类似于发送快递:

在这里插入图片描述

2.5 协议分层

协议分层是一种将网络通信过程划分为不同层级的方法。每个层级都有自己的功能和责任,并且它们相互协作来实现可靠的数据传输。

网络协议为什么需要分层呢?协议分层好处有两个:

  1. 分层之后就可以做到,层次之间,耦合程度比较低.上层协议不必了解下层的细节,下层也不必了解上层的细节.
  2. 方便的对某一层的协议进行替换.

2.6 OSI 七层模型

OSI( Open System Interconnection),即开放系统互连,OSI 七层网络模型把网络从逻辑上分为了 7 层,分别是:

  1. 应用层:为用户提供与网络通信的接口,包括各种应用程序服务。
  2. 表示层:负责数据格式的转换、数据加密和压缩。
  3. 会话层:负责建立、管理和终止会话( 多个应用程序之间的通信 )。
  4. 传输层:负责提供端到端的可靠或不可靠的数据传输,包括流量控制和拥塞控制。
  5. 网络层:负责设定数据包的路径,实现不同网络间的通信和路由控制。
  6. 数据链路层:负责将原始比特流转换为数据帧,并提供物理层的可靠传输。
  7. 物理层:负责传输原始比特流,处理物理连接和电子信号传输。

在这里插入图片描述
在这里插入图片描述

OSI 七层模型既复杂又不实用,所以 OSI 七层模型没有落地、实现,在实际组建网络时,只是以 OSI 七层模型设计中的部分分层,实际是以下 TCP / IP 五层( 或四层 )模型来实现。

2.7 TCP / IP 五层模型

TCP / IP 通讯协议采用了 5 层的层级结构:

  1. 应用层:负责应用程序间沟通,我们的网络编程主要就是针对应用层。
  2. 传输层:负责两台主机之间的数据传输。如传输控制协议 TCP,能够确保数据可靠的从源主机发送到目标主机。
  3. 网络层:负责地址管理和路由选择。例如在 IP 协议中,通过路由表的方式规划出两台主机之间的数据传输的线路。路由器工作在网路层。
  4. 数据链路层:负责设备之间的数据帧的传送和识别。交换机工作在数据链路层。
  5. 物理层:负责光 /电信号的传递方式,物理层的能力决定了最大传输速率、传输距离、抗干扰性等。集线器工作在物理层。

在这里插入图片描述
各个层次的作用大概如下:

  1. 应用层,应用程序,拿到数据怎么用.
  2. 传输层,负责关注传输过程中起点和终点.
  3. 网络层,负责整个传输过程的路径规划.
  4. 数据链路层,负责两个相邻节点之间数据传输
  5. 物理层,网络通信的硬件设备和基础设施.,比如说网线,光纤等等

其中:

  • 应用层属于应用程序层面的
  • 传输层和网络层属于系统内核封装层面的
  • 数据链路层和物理层属于硬件和驱动层面的

物理层我们考虑的比较少,有时候会忽略物理层,因此很多时候也可以称为 TCP / IP 四层模型。

2.8 常见网络设备所在分层

  • 对于一台主机,它的操作系统内核实现了从传输层到物理层的内容,也即是 TCP / IP 五层模型的下四层;
  • 对于一台路由器,它实现了从网络层到物理层,也即是TCP / IP五层模型的下三层;
  • 对于一台交换机,它实现了从数据链路层到物理层,也即是TCP / IP五层模型的下两层;
  • 对于集线器,它只实现了物理层;

注意我们这里说的是传统意义上的交换机和路由器,随着现在网络设备技术的不断发展,也出现了很多 3 层或 4 层交换机,4 层路由器。我们以上说的网络设备都是传统意义上的交换机和路由器。

2.8.1 网络分层对应

网络数据传输时,经过不同的网络节点时,网络分层需要对应,以下为同一个网段内的两台主机进行文件传输:
在这里插入图片描述
以下为跨网段的主机的文件传输:数据从一台计算机到另一台计算机传输过程中要经过一个或多个路由器:
在这里插入图片描述

2.9 协议的封装和分用

  • 不同的协议层对数据包有不同的称谓,在传输层叫做段,在网络层叫做数据报,在链路层叫做帧。
  • 应用层数据通过协议栈发到网络上时,每层协议都要加上一个数据首部,称为封装。
  • 首部信息中包含了一些类似于首部有多长,载荷有多长,上层协议是什么等信息。
  • 数据封装成帧后发到传输介质上,到达目的主机后每层协议再剥掉相应的首部,根据首部中的 “上层协议字段” 将数据交给对应的上层协议处理。

下图为数据封装的过程:
在这里插入图片描述

在协议分层的背景下,数据如何通过网络传输?答案是封装和分用.

  • 发送方发送数据,要把数据从上到下,依次交给对应的层次的协议进行封装.
  • 接收方收到数据,要把数据从下到上,依次交给对应的层次的协议进行解析.

接收过程和上述过程,刚好相反

  • 发送,从上到下,依次封装,新增报头
  • 接收,从下到上,依次分用,去掉报头
评论 15
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

ice___Cpu

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值