中科大计网学习记录笔记(六):应用层概述 | 应用层原理

2024-02-04 20:52

本文主要是介绍中科大计网学习记录笔记(六):应用层概述 | 应用层原理,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

前言:

学习视频:中科大郑烇、杨坚全套《计算机网络(自顶向下方法 第7版,James F.Kurose,Keith W.Ross)》课程
该视频是B站非常著名的计网学习视频,但相信很多朋友和我一样在听完前面的部分发现信息量过大,有太多无法理解的地方,在我第一次点开的时候也有相同的感受,但经过了一段时间项目的学习,对计网有了更多的了解,所以我准备在这次学习的时候做一些记录并且加入一些我的理解,希望能够帮助到大家。
往期笔记可以看专栏中的内容😊😊😊

资料分享:
视频课件分享链接,提取码 pho1
计算机网络(第七版) 自顶向下方法分享链接,提取码 7ln4

02. 应用层

目标:

  1. 网络应用的原理:网络应用协议的概念和实现方面
    • 传输层的服务模型
    • 客户端-服务器模式(cs 模式,client / server)
    • 对等模式(p2p 模式,peer to peer)
    • 内容分发网络
  2. 网络应用的实例:互联网流行的应用层协议
    • HTTP
    • FTP
    • SMIP / POP3 / IMAP
    • DNS
  3. 编程:网络应用程序
    • Socker API

2.1 应用层协议原理

2.1.1 客户端服务器模式(cs 模式)

服务器是一直运行再固定的 IP 和端口号来等待客户端来进行请求的,客户端直接与服务器通信,而不能直接与其他客户端通信。

这样的缺点就是可扩展性比较差:

服务器会因为访问量增大到某个阈值而呈现断崖式的下降,如果服务器负载过高,可能需要增加服务器的硬件资源或引入负载均衡等技术来处理更多的请求。

且因为服务器是一个中心化的实体,服务器出现故障或需要维护,整个系统可能会受到影响,等等诸多问题导致其拓展性很差。

2.1.2 进程通信

进程:在主机上应用程序

  • 客户端进程:首先发起通信的进程
  • 服务器进程:等待连接的进程

不同的主机之间通过交换报文(Message)来通信(应用层的 PAU)

分布式进程之间通信需要解决的问题:

分布式就是在不同计算机上的进程,这里理解为客户端到服务端的通信即可

  • 问题 1:进程标识和寻址问题,如何找到要服务的用户
  • 问题 2:传输层-应用层之间是如何提供服务的,如何和下层进行交接
  • 问题 3:如何使用传输层提供的服务实现应用进程之间的报文转换,即当收到 不同的报文 的时候需要去做什么。

问题 1:如何标识一个应用进程?

  1. 用户提供的 IP
  2. 应用程序是在 UDP 之上还是 TCP 之上
  3. 应用程序是在那个端口上(port)

问题 2:传输层提供的服务

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

层间接口必须要携带的信息

  • 要传输的报文(SDU)
  • 谁传的:本应用进程的标识(IP + TCP(UDP)端口)
  • 传给谁:对方的应用进程的标示:对方的IP+TCP(UDP)端口号

传输层实体(tcp或者udp实体)根据这些信息进行TCP 报文段(UDP数据报)的封装

  • 源端口号,目标端口号,数据等。
  • 将 IP 地址往下交 IP 实体,用于封装IP数据报:源 IP,目标 IP。

但这又引出一个问题,每次都需要携带上面的三种信息会导致传输的信息重复,且层间传输的信息量会增大,有没有方法可以解决这个问题呢?

2.1.3 socket 的基础理解
  • 如果每次传输报文都需要携带如此多的信息,太繁琐而且不宜管理
  • 所以采用编号的方式来标识双方或者单方,例如当 TCP 连接建立的时候可以向操作系统请求一个 socket,这个 socket 会以编号的形式存在,且会携带上面的三种信息,以后每次发送请求和接受请求的时候就可以通过 socket 来实现标识的作用。
  • socket 可以看作是在网络中建立通信连接的一种手段,它在应用层和传输层之间提供了一个抽象层,使得应用程序能够通过简单而灵活的方式进行网络通信。

Socket 能够解决穿越层间的信息传递问题的原因:

  1. 抽象网络协议: Socket 提供了一个抽象层,隐藏了底层网络协议的细节。无论是 TCP 还是 UDP,应用程序可以使用相同的 Socket 接口进行通信。这种抽象性允许应用程序在不同的网络协议之间切换,而不必修改主要的通信逻辑。
  2. 统一的编程接口: Socket 提供了一致的编程接口,无论在不同的网络层次上。通过调用 Socket API,应用程序可以实现对底层网络协议的访问,而 无需关心底层协议的差异。这使得开发者能够使用相似的代码来处理不同的网络通信需求。
  3. 多协议支持: Socket 不仅支持 TCP 和 UDP,还可以在应用程序层面上支持其他自定义的协议。这种多协议支持使得应用程序能够选择最适合其需求的通信方式,而不受制于特定的网络层次。
  4. 跨越网络层次: Socket 的设计目标之一就是跨越网络层次,使得应用程序可以在不同的网络层次上进行通信。通过 Socket,应用程序可以在传输层(如 TCP 和 UDP)以及应用层(通过自定义协议)实现通信。
  5. 灵活性和通用性: Socket 提供了灵活且通用的接口,能够适应不同的网络场景。这种通用性使得 Socket 成为一个广泛应用于各种应用领域的通信工具,从简单的文件传输到复杂的分布式系统通信。

这样就可以做到减少从应用层到传输层之间传递的信息量。

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

2.1.4 TCP 和 UDP 的 socket

TCP(Transmission Control Protocol)和UDP(User Datagram Protocol)是两种不同的传输层协议,它们在使用Socket进行通信时有一些区别。以下是TCP和UDP的Socket在通信中的一些特点:

  1. TCP Socket:
    • 连接导向: TCP是面向连接的协议,因此TCP Socket通信建立连接时需要进行三次握手。连接建立后,数据的传输是可靠的,有序的,且不会丢失。
    • 流式传输: TCP提供的是流式传输,数据被看作是连续的字节流。TCP会保证数据的完整性,按照发送的顺序进行重组。
    • 面向字节流: TCP是面向字节流的,发送和接收的是字节序列。应用程序需要负责解析消息的边界。
    • 连接维持: TCP保持连接的状态,双方在通信完成后需要进行四次挥手来终止连接。
  2. UDP Socket:
    • 无连接: UDP是无连接的协议,因此UDP Socket通信不需要建立连接,发送数据前不需要进行握手。每个数据包都是独立的,相互之间没有关系。
    • 数据报传输: UDP提供数据报传输,每个数据包是独立的单元,不会进行流式传输。数据包可能会丢失或乱序,因此不保证可靠性。
    • 面向消息: UDP是面向消息的,每个数据包都是一个独立的消息。
    • 无连接状态: UDP不保持连接状态,每次发送数据都是相互独立的操作。

TCP soket 中包含源主机的 IP 和端口,目标主机的 IP 和端口,所以传输的时候需要 socket 和传输的内容即可;UDP socket 中仅包含了本主机的端口和 IP,所以传输的时候需要 socket 、目标主机的 IP 和端口还有传输的内容

2.1.5 应用层协议

运行在 不同端系统 上的应用如何相互交换报文

HTTP:用于在客户端和服务器之间传输超文本,是 Web 应用中最常用的协议。HTTP 定义了客户端请求和服务器响应的格式,支持无状态的通信。

应用层需要传输层提供的服务

  • 数据丢失率:有些应用能容忍一定比例的数据丢失,比如音频;有些应用则要求 100% 的准确性
  • 延迟:有些应用对于延迟要求很高,比如数据电话,需要很低的延迟才能保证人们之间的正常交流
  • 吞吐
  • 安全性

常见应用需要传输层提供的服务

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

TCP 与 UDP 可提供的服务

TCP 提供 可靠的传输服务、流量控制、拥塞控制。

UDP 提供 不可靠的传输服务,没有以上的控制各种限制,但换来了更快的速度和更低的延迟。

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

这篇关于中科大计网学习记录笔记(六):应用层概述 | 应用层原理的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

java中pdf模版填充表单踩坑实战记录(itextPdf、openPdf、pdfbox)

《java中pdf模版填充表单踩坑实战记录(itextPdf、openPdf、pdfbox)》:本文主要介绍java中pdf模版填充表单踩坑的相关资料,OpenPDF、iText、PDFBox是三... 目录准备Pdf模版方法1:itextpdf7填充表单(1)加入依赖(2)代码(3)遇到的问题方法2:pd

Spring Security 单点登录与自动登录机制的实现原理

《SpringSecurity单点登录与自动登录机制的实现原理》本文探讨SpringSecurity实现单点登录(SSO)与自动登录机制,涵盖JWT跨系统认证、RememberMe持久化Token... 目录一、核心概念解析1.1 单点登录(SSO)1.2 自动登录(Remember Me)二、代码分析三、

在MySQL中实现冷热数据分离的方法及使用场景底层原理解析

《在MySQL中实现冷热数据分离的方法及使用场景底层原理解析》MySQL冷热数据分离通过分表/分区策略、数据归档和索引优化,将频繁访问的热数据与冷数据分开存储,提升查询效率并降低存储成本,适用于高并发... 目录实现冷热数据分离1. 分表策略2. 使用分区表3. 数据归档与迁移在mysql中实现冷热数据分

Zabbix在MySQL性能监控方面的运用及最佳实践记录

《Zabbix在MySQL性能监控方面的运用及最佳实践记录》Zabbix通过自定义脚本和内置模板监控MySQL核心指标(连接、查询、资源、复制),支持自动发现多实例及告警通知,结合可视化仪表盘,可有效... 目录一、核心监控指标及配置1. 关键监控指标示例2. 配置方法二、自动发现与多实例管理1. 实践步骤

从原理到实战深入理解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中集成RabbitMQ的实战记录

《在SpringBoot中集成RabbitMQ的实战记录》本文介绍SpringBoot集成RabbitMQ的步骤,涵盖配置连接、消息发送与接收,并对比两种定义Exchange与队列的方式:手动声明(... 目录前言准备工作1. 安装 RabbitMQ2. 消息发送者(Producer)配置1. 创建 Spr

深度解析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. 顺序流中的去重

k8s上运行的mysql、mariadb数据库的备份记录(支持x86和arm两种架构)

《k8s上运行的mysql、mariadb数据库的备份记录(支持x86和arm两种架构)》本文记录在K8s上运行的MySQL/MariaDB备份方案,通过工具容器执行mysqldump,结合定时任务实... 目录前言一、获取需要备份的数据库的信息二、备份步骤1.准备工作(X86)1.准备工作(arm)2.手