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

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深度学习库DJL实现Python的NumPy方式

《Java深度学习库DJL实现Python的NumPy方式》本文介绍了DJL库的背景和基本功能,包括NDArray的创建、数学运算、数据获取和设置等,同时,还展示了如何使用NDArray进行数据预处理... 目录1 NDArray 的背景介绍1.1 架构2 JavaDJL使用2.1 安装DJL2.2 基本操

关于Spring @Bean 相同加载顺序不同结果不同的问题记录

《关于Spring@Bean相同加载顺序不同结果不同的问题记录》本文主要探讨了在Spring5.1.3.RELEASE版本下,当有两个全注解类定义相同类型的Bean时,由于加载顺序不同,最终生成的... 目录问题说明测试输出1测试输出2@Bean注解的BeanDefiChina编程nition加入时机总结问题说明

关于最长递增子序列问题概述

《关于最长递增子序列问题概述》本文详细介绍了最长递增子序列问题的定义及两种优化解法:贪心+二分查找和动态规划+状态压缩,贪心+二分查找时间复杂度为O(nlogn),通过维护一个有序的“尾巴”数组来高效... 一、最长递增子序列问题概述1. 问题定义给定一个整数序列,例如 nums = [10, 9, 2

MySQL中的MVCC底层原理解读

《MySQL中的MVCC底层原理解读》本文详细介绍了MySQL中的多版本并发控制(MVCC)机制,包括版本链、ReadView以及在不同事务隔离级别下MVCC的工作原理,通过一个具体的示例演示了在可重... 目录简介ReadView版本链演示过程总结简介MVCC(Multi-Version Concurr

将sqlserver数据迁移到mysql的详细步骤记录

《将sqlserver数据迁移到mysql的详细步骤记录》:本文主要介绍将SQLServer数据迁移到MySQL的步骤,包括导出数据、转换数据格式和导入数据,通过示例和工具说明,帮助大家顺利完成... 目录前言一、导出SQL Server 数据二、转换数据格式为mysql兼容格式三、导入数据到MySQL数据

关于rpc长连接与短连接的思考记录

《关于rpc长连接与短连接的思考记录》文章总结了RPC项目中长连接和短连接的处理方式,包括RPC和HTTP的长连接与短连接的区别、TCP的保活机制、客户端与服务器的连接模式及其利弊分析,文章强调了在实... 目录rpc项目中的长连接与短连接的思考什么是rpc项目中的长连接和短连接与tcp和http的长连接短

Oracle查询优化之高效实现仅查询前10条记录的方法与实践

《Oracle查询优化之高效实现仅查询前10条记录的方法与实践》:本文主要介绍Oracle查询优化之高效实现仅查询前10条记录的相关资料,包括使用ROWNUM、ROW_NUMBER()函数、FET... 目录1. 使用 ROWNUM 查询2. 使用 ROW_NUMBER() 函数3. 使用 FETCH FI

Python MySQL如何通过Binlog获取变更记录恢复数据

《PythonMySQL如何通过Binlog获取变更记录恢复数据》本文介绍了如何使用Python和pymysqlreplication库通过MySQL的二进制日志(Binlog)获取数据库的变更记录... 目录python mysql通过Binlog获取变更记录恢复数据1.安装pymysqlreplicat

Redis主从/哨兵机制原理分析

《Redis主从/哨兵机制原理分析》本文介绍了Redis的主从复制和哨兵机制,主从复制实现了数据的热备份和负载均衡,而哨兵机制可以监控Redis集群,实现自动故障转移,哨兵机制通过监控、下线、选举和故... 目录一、主从复制1.1 什么是主从复制1.2 主从复制的作用1.3 主从复制原理1.3.1 全量复制

Redis主从复制的原理分析

《Redis主从复制的原理分析》Redis主从复制通过将数据镜像到多个从节点,实现高可用性和扩展性,主从复制包括初次全量同步和增量同步两个阶段,为优化复制性能,可以采用AOF持久化、调整复制超时时间、... 目录Redis主从复制的原理主从复制概述配置主从复制数据同步过程复制一致性与延迟故障转移机制监控与维