网络通信概述

文章目录

一般认为计算机网络就是利用通信线路和通信设备将地理上分散的、具有独立功能的多个计算机系统按不同的形式连接起来,以功能完善的网络软件及通信协议实现资源共享和信息传递的系统。

  • ++通讯设备(具有自治功能的)++
  • ++介质互联(双绞线、光纤...)++
  • ++资源共享(目的)++

IP地址

;网络通信的目的是资源共享,数据之间基于介质传输数据,那么这些传输数据的节点之间是如何判断信息的来源,和目的呢?

  • 用于++标识网络设备的网络地址++
  • 用4个字节32位二进制表示(一般写作++点分十进制++如127.0.0.1)
  • 环回IP 127.0.0.1

环回IP:本机环回主要用于本机到本机的网络通信(系统内部为了性能,不会走网络的方式传输),对于开发网络通信的程序(即网络编程)而言,常见的开发方式都是本机到本机的网络通信。是使用一个特殊的ip地址127.0.0.1来实现的

端口号

端口号可以标识主机中发送数据、接收数据的进程。例如mysql服务器默认绑定3306端口。

  • ++标识一个具体的应用程序(进程)++
  • 使用++2个字节++16位表示(0 ~ 65535)
  • 0 号端口一般不使用,1 ~ 1023为知名端口号,不应占用
    • 22 - ssh
    • 80 - http
    • 443 - https
    • 23 - teIntent

协议

网络协议为计算机网络中进行++数据交换++而建立的规则、标准或约定的集合。协议最终体现为在网络上传输的数据包的格式。

三要素

  1. 语义。语义是解释控制信息每个部分的意义 。它规定了需要发出何种控制信息,以及完成的动作 与做出什么样的响应
  2. 语法。语法是用户数据与控制信息的结构与格式,以及数据出现的顺序。
  3. 时序。时序是对事件发生顺序 的详细说明。(也可称为"同步")。
    人们形象地把这三个要素描述为:语义表示要做什么,语法表示要怎么做,时序表示做的顺序。

作用

由于++网络环境的复杂性++,在进行网络通信时的状况比较复杂,所以在传输时就需要提前确定好如何传输,数据如何组织,如何发送数据,网络线路如何选择...

如果使用一个协议来约定和解决所有问题,会导致这个协议非常复杂,非常的庞大,因此在设计网络协议时,就++对网络协议进行拆分 ++,这样:++++

  • 上层协议调用下层协议,不需要了解下层协议的实现细节(封装)

  • 下层协议给上层协议提高支持

  • 可以灵活的调整替换某层协议

有了这样的层次结构,就可以++避免夸层次交互,降低了协议之间的耦合,提高了协议系统的可读性++

五元组

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

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

协议分层

网络通信是一个比较复杂的工作,如果靠一个协议来解决所有的问题,会导致这个协议非常庞大、复杂。

网络分层就可以让网络的体系结构更加清晰的呈现。上层协议调用下层协议,下层协议给上层协议提高支持。每个层次之间不需要明确层次结构,每个层次对外隐藏实现细节 ,对每个层次之间的协议也可以根据需要灵活调整 。这样就降低了耦合

由于理论和实践之间的差异,理论上网络有七层OSI七层模型 - 参考模型,而各大产商支持的普遍是TCP/IP五层协议。

OSI七层模型

TCP/IP 五层模型

在具体实践中,将OSI中的应用层、表示层、会话层合并为TCP/IP中的应用层。

应用层

++通信双方通信数据的规范++

通常是根据场景和需求,由程序员自主决定的

传输层

++只关注通信的起点和终点 - 端口++

网络层

++网络传输路线如何规划 - IP地址++

数据链路层

++描相邻节点之间的如何 - MAC地址++

物理层

++描述了网络基础设施的规范和标准++

封装和分用

我们通过一个例子来看网络中的封装和分用。比如我给对方发送一句"hello",这句"hello",对方是如何收到的。

发送方 - 封装

(我 微信号:111111):

  1. 应用层:微信客户端按照应用层的协议将"hello"封装成应用层的数据报,然后交给传输层。假设微信的应用层的协议这样组织(发送方微信号,接收方微信号,时间,正文):

应用层就可以根据协议构造上述的应用层数据报,构造好后调用传输层API将这个数据报交给传输层。

  1. 传输层:传输层有很多协议,其中最主要的是TCP和UDP协议此处假设传输层协议为UDP,传输层收到应用层的数据报后,根据UDP协议构造UDP数据报。

UDP不会关心应用层的数据是什么,将其当做本层载荷进行封装。传输层封装完成后,进一步将UDP数据报交给网络层。

  1. 网络层:网络层最主要的协议是IP协议,此处网络层拿到UDP数据报后会将其封装成IP数据报:

    同样的,IP层也不会关心UDP的内容,只会将其当做本层的载荷,进行封装。

  2. 数据链路层:使用以太网对上层协议(IP数据报)进行封装,加上以太网帧头和帧尾。

  3. 物理层:物理层根据物理层协议规范(网卡)将以太网数据报转换成01序列进一步转换成光/电信号进行发送

中间转发

中间情况:中间可能会经过路由器交换机的转发,先拆包,在封装,具体拆到那一层取决于是交换机还是路由器。

  • 交换机将电信号转换成二进制数据送往交换机的数据链路层,因为交换机属于数据链路层的设备,所以它将可以查看数据帧头部的内容,但不会进行封装和解封装的过程。
  • 当路由器收到数据后会拆掉数据链路层的 MAC 头部信息,将数据送达网络层,这样 IP 头部信息就"暴露"在最外面了。 路由器将检测数据包头部的目标 IP 地址信息,并根据该信息进行路由过程,智能地将数据报文转发到下一跳路由器上(重复过程)

接收方 - 分用

(对方 微信号:222222):

  1. 物理层:物理层(硬件设备网卡),收到光电信号,需要将信号转换成01序列,得到以太网数据报,进一步将以太网数据报交给数据链路层。
  2. 数据链路层:数据链路层得到以太网数据报后就会根据以太网协议进行解析,拿到以太网数据报的载荷,再将以太网数据报的载荷交给网络层IP协议处理。
  3. 网络层:网络层得到IP数据报,根据IP协议进行解析,去掉IP报头得到IP载荷,交给传输层处理:
  4. 传输层:传输层得到UDP数据报后,根据UDP协议进行解析,去掉UDP报头,得到UDP载荷,交给应用层。
  5. 应用层:应用层拿到后就可以根据应用层的协议进行解析,解析完毕后就可以拿到数据"hello",进一步就收到了"hello"这条消息了。

发送方从应用层到物理层逐层封装,接收方从物理层到应用层逐层解析,每个层次之间相互独立,完成自己的功能,相互配合,完成了数据的传输。

总结:

  1. 封装:将数据从应用层开始,层层封装,最后通过网卡转换成光电信号进行传输
  2. 转发:中间会进过交换机和路由器进行转发
    • 交换机:会解析出以太网数据帧(数据链路层),获取到帧头中的"mac地址"
      • 重新封装,根据"mac地址"进行转发
    • 路由器:解析出ip数据报(网络层),拿到"目的ip地址"
      • 进一步规划处接下来的路线
      • 将数据进行封装,进行转发
  3. 分用:数据报到达目的主机后,根据各层协议,层次解析,最终拿到传输的数据
相关推荐
怡人蝶梦1 小时前
Java后端技术栈问题排查实战:Spring Boot启动慢、Redis缓存击穿与Kafka消费堆积
java·jvm·redis·kafka·springboot·prometheus
瓯雅爱分享1 小时前
MES管理系统:Java+Vue,含源码与文档,实现生产过程实时监控、调度与优化,提升制造企业效能
java·mysql·vue·软件工程·源代码管理
bubiyoushang8881 小时前
matlab雷达定位仿真
开发语言·matlab
鬼多不菜2 小时前
一篇学习CSS的笔记
java·前端·css
深色風信子2 小时前
Eclipse 插件开发 5.3 编辑器 监听输入
java·eclipse·编辑器·编辑器 监听输入·插件 监听输入
yezipi耶不耶2 小时前
Rust入门之并发编程基础(一)
开发语言·后端·rust
Blossom.1182 小时前
人工智能在智能健康监测中的创新应用与未来趋势
java·人工智能·深度学习·机器学习·语音识别
shangjg33 小时前
Kafka 如何保证不重复消费
java·分布式·后端·kafka
无处不在的海贼3 小时前
小明的Java面试奇遇之互联网保险系统架构与性能优化
java·面试·架构