【JavaEE】网络原理基础讲解

简介: 【JavaEE】网络原理基础讲解

1.网络的发展史

1.1网络的由来

很多先进的东西都是先是军用,后来发现这东西太方便了,才普遍下来。

网络是什么来的呢?在没有互联网之前,军队都是通过电报、电话来通信的,这东西有一个缺点就是在使用时容易被拦截。于是,美国人就研究,能不能搞一种通讯,可以防止拦截,此时,互联网这个东西就诞生了。

1.2网络互联

网络互连:将多台计算机连接在一起,完成数据共享。

数据共享本质是网络数据传输,即计算机之间通过网络来传输数据,也称为网络通信

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

1.2.1 独立模式(单机模式)

单机模式的含义就是,当我们有两台电脑时,A电脑处理的事情的结果,无法影响到B电脑的数据。就相当于我们打游戏无法进行人人交互(pvp)。

1.2.2局域网(LAN)

局域网,英文名称是Local Area Network,简称LAN

Local 即标识了局域网是本地,局部组建的一种私有网络。

局域网内的主机之间能方便的进行网络通信,又称为内网;局域网和局域网之间在没有连接的情况下,是无法通信的。

通过网线将若干台电脑链接在一起,这就构成了一个简单的局域网:



它们不仅仅可以使用网线进行连接,还可以使用集线器、交换机、路由器进行连接,只要是小规模的电脑连接就是局域网(小规模没有具体定义,需要参考具体对象)。

1.2.3广域网(WAN)

广域网,英文名称是Wide Area Network,简称WAN

通过路由器,将多个局域网连接起来,在物理上组成很大范围的网络,就形成了广域网。广域网内部的局域网都属于其子网。


 


在这个图中,我们可以将各个地区当成局域网,整个图当成一个广域网。如果属于全球化的公共型广域网,则称为互联网(又称公网,外网),属于广域网的一个子集。有时在不严格的环境下说的广域网,其实是指互联网。


2.网络通信基础

2.1IP地址

🐣概念

IP地址主要用于标识网络主机、其他网络设备(如路由器)的网络地址。简单说,IP地址用于定位主机的网络地址。就像我们发送快递一样,需要知道对方的收货地址,快递员才能将包裹送到目的地。

🐣格式

IP地址是一个32位的二进制数,通常被分割为4个“8位二进制数”(也就是4个字节),如:

01100100.00000100.00000101.00000110。通常用“点分十进制”的方式来表示,即 a.b.c.d 的形式(a,b,c,d都是0~255之间的十进制整数)。如:100.4.5.6。

🐣特殊IP

127.*的IP地址用于本机环回(loop back)测试,通常是127.0.0.1本机环回大部分时候用于本机到本机的网络通信(系统内部为了性能,不会走网络的方式传输),对于开发网络通信的程序(即网络编程)而言,常见的开发方式都是本机到本机的网络通信。

2.2端口号

🐣概念

在网络通信中,IP地址用于标识主机网络地址,端口号可以标识主机中发送数据、接收数据的进程。

简单说:我们可以通过IP地址来定位到这台设备,但是一台设备上有很多进程,我们如果想要知道那个进程发出的请求,我们就要依赖一个东西(端口号)。端口号就是用于定位主机中的进程。就像发送快递时,不光需要指定收货地址(IP地址),还需要指定收货人(端口号)。

🐣格式

端口号是0~65535范围的数字,在网络通信中,进程可以通过绑定一个端口号,来发送及接收网络数据。


3.计算机网络协议

3.1网络协议定义

我们想要让两个网络进行通信,我们就需要达成一些共识,通过这些共识进行通讯。例如,有两个人,一个中国人,一个美国人,他们俩个人说话(都说国语),他们相互说话就很难进行有效沟通,如果他们两个使用同一个语言说话,那他们聊天就会畅通无阻。



3.2网络协议分层

🐣为什么要分层 ?

网络通信其实是一个比较复杂的过程,需求场景越复杂,那么网络协议就越复杂,它越复杂对于我们的学习成本和维护成本就会增大。因此,我们就将就将复杂的难以通过大脑计算的大协议,一点一点的拆分成我们大脑可以解决的小协议,让每个小协议负责大协议中的一些事物,最终将这些小协议联系到一起完成当前的任务。

🐣网络协议分层的好处

1.最大的好处莫过于可以减小我们大脑的负载。

2.对于使用方来说,并不关心提供方是如何实现的,只需要使用接口即可,减低了学习成本。

3.对于提供方来说,利用封装的特性,隐藏了实现的细节,只需要开放接口即可,降低每层的耦合度,在后续需要迭代时,对于使用方也无需付出学习成本。


就像我们在打电话时,我们就是使用方,我们无需关注使用方式打电话(座机、无线电话),也不关心电话是如何进行传输我们的聊天的。


1585e8e45f794bc597e4b55b30906cbc.png


3.3OSI七层模型

OSI:英文名称是Open System Interconnection,即开放系统互连,它分为七层,分别是物理层、数据链路层、网络层、传输层、会话层、表示层、应用层。



OSI 七层模型既复杂又不实用:所以 OSI 七层模型没有落地、实现。

实际组建网络时,只是以 OSI 七层模型设计中的部分分层,也即是以下 TCP/IP 五层(或四层)模型来实现。

3.4TCP/IP模型(重点)

TCP/IP模型,它从应用层到物理层一个有五层,分别是应用层、传输层、互联网层(网络层)、网卡层(数据链路层)、物理层(硬件),有时候我们也叫它四层协议,因为物理层是硬件,对于我们程序员来说,我们不太关心这个。


82c8764f711e4b0db2d64ef12fed9cac.png


🐣各个协议层任务:

应用层: 只关注程序的作用是什么,如何使用的,网络编程主要就是针对应用层。

传输层:负责两台主机之间的数据传输。只关心两个主机的地址,不考虑如何到达这个地方。例如:就像我在淘宝上买东西,我只关心发货地址和收货地址。

网络层:负责地址管理和路由选择。负责两个地址如何走才是最佳路线。例如:我买的东西收获地址是北京,发货地址是上海,我是通过上海->深圳->北京,还是上海->河北->北京。

数据链路层:负责设备之间的数据帧的传送和识别。例如,快递选择了上海->河北->北京这条路,做出决定:是使用火车还是货车。

物理层:针对硬件设备间的协议,约定了网络通信中的基础的硬件设备的规格,保证主机和网络设备之间得到匹配。


在这些几个协议层当中,我们最关心的就是应用层,其他的层都是操作系统内核封装好的,只要应用层我们需要自己手动实现。


🐣各个协议层工作流程

我们就以qq发送信息为例, 假设A用户向B用户发送了一个“两年半”,时间在2023-04-04 19:00,

我们以发送方的角度看(粗略步骤,精专不考虑):


✨1.应用层

qq应用程序拿到了上方的数据,进行封装,封装成应用层数据报,他的本质就是数据拼接,在qq的具体情况中,比这要复杂的多。


758dabaf1a0a4b93b8ac68a855ce859c.png


在应用层,封装好这个数据报,qq就会通过调用传输层提供中的API将这个数据报传输给传输层。


✨2.传输层

传输层基于应用层发送过来的数据,调用传输层中的API,传输层的API最常用的是TCP和UDP,他会将应用层传输过来的数据包当作荷载进行封装,UDP报头中包含一个特定的字符串(源端口和目的端口)。这里我们用UDP来举例。

UDP会针对应用层发来的数据报再次封装。


00dc62cc5d004b098718a5364324f9b0.png


之后传输层将在传输层封装好的数据报发向网络层。


✨3.网络层

这里最典型协议是ip协议,会将传输层数据报继续封装,封装成IP数据报,在原来的数据报上添加一个IP报头,将传输层传输过来的数据报当成荷载。

在IP报头当中,它包含一组数据源ip和目的ip。


a02eb8cbe24342d4b176ecd434181e2e.png


✨4.数据链路层

数据链路层最典型的协议叫做“以太网”,他会在IP数据报的包头和包尾加上帧头和帧尾。

帧头中主要包括 源MAC地址和目的MAC地址,

MAC是指物理地址,描述一个主机在网络上的位置,他的功能和IP很相似,但是这两个地址分别作用于不同的用途。IP用于网络层的路径规划,MAC用来进行描述数据链路层,两个即将进行传输的相邻节点。


dc5cbddc1ee643a5b1221c0d418c04d8.png


之后,数据链路层会将封装好的数据报方式给物理层。


✨5.物理层

物理层会将上述的“以太网数据帧”的二进制数据转换成高低电平信号/光信号,通过网线或者无线电波的方式传出出去。



相关文章
|
29天前
|
机器学习/深度学习 存储 算法
神经网络分类算法原理详解
神经网络分类算法原理详解
52 0
|
21天前
|
运维 Kubernetes Cloud Native
探索Kubernetes的大二层网络:原理、优势与挑战🚀
在云原生领域,Kubernetes (K8s) 已经成为容器编排的事实标准☁️📦。为了支撑其灵活的服务发现和负载均衡🔍🔄,K8s采用了大二层网络的设计理念🕸️。本文将深入探讨大二层网络的工作原理、带来的好处✨,以及面临的挑战和解决方案❗🛠️。
探索Kubernetes的大二层网络:原理、优势与挑战🚀
|
9天前
|
安全 数据建模 网络安全
深入理解SSL数字证书:定义、工作原理与网络安全的重要性
本文阐述了SSL数字证书在网络安全中的关键作用,定义了其作为验证服务器身份的数字凭证,基于PKI体系保障数据传输安全。文章介绍了三种类型的证书,包括DV、OV和EV,适用于不同安全需求的网站。获取和安装证书涉及向证书颁发机构申请并部署到服务器。在网络安全挑战下,正确使用和管理SSL证书对于保护用户数据和提升信任度至关重要。
|
16天前
|
安全 网络协议 网络安全
网络原理(5)--HTTPS是如何进行加密的
网络原理(5)--HTTPS是如何进行加密的
11 0
|
16天前
|
存储 JSON 前端开发
网络原理(4)HTTP协议(下)
网络原理(4)HTTP协议
27 0
|
19天前
|
传感器 监控 安全
|
30天前
|
缓存 网络协议 数据库连接
【底层服务/编程功底系列】「网络通信体系」深入探索和分析TCP协议的运输连接管理的核心原理和技术要点
【底层服务/编程功底系列】「网络通信体系」深入探索和分析TCP协议的运输连接管理的核心原理和技术要点
24 0
|
1月前
|
存储 安全 网络安全
网络技术基础(20)——AAA原理与配置
【3月更文挑战第6天】华为设备的AAA框架实现网络安全管理,包括认证、授权、计费三要素,常使用RADIUS协议。用户、NAS(Network Access Server)和AAA服务器构成基本架构。认证方式有不认证、本地认证和远端认证,授权方式包括不授权、本地授权和远端授权,计费则为不计费和远端计费。RADIUS作为分布式协议,处理认证、计费和授权。常见应用场景如SSH登录,配置涉及创建认证方案、用户及服务类型。实验配置示例展示了SSH登录的AAA验证过程。
|
1月前
|
安全 网络性能优化 调度
SD-WAN 网络编排原理
【2月更文挑战第29天】网络编排是解决传统WAN部署复杂、耗时问题的关键技术,它通过策略驱动自动化协调硬件和软件资源。
|
1月前
|
机器学习/深度学习 人工智能 算法
详细介绍卷积神经网络(CNN)的原理 !!
详细介绍卷积神经网络(CNN)的原理 !!
78 0