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

前言:

学习视频:中科大郑烇、杨坚全套《计算机网络(自顶向下方法 第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.hqwc.cn/news/453166.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Android Studio 安装Flutter插件但是没法创建项目

Android Studio 安装Flutter插件但是没法创建项目 如果你在Android Studio已经安装了Dart、Flutter插件,但是不能创建Flutter项目。 原因是因为Android Studio的版本更新,Android APK Support这个插件没被选中。 一旦勾选这个插件之后,就能…

Linux校准时间 Centos

Linux校准时间 Centos 首先,确保系统中已经安装了tzdata包。如果没有安装,可以使用以下命令安装: sudo yum install tzdata设置系统时区为上海: sudo timedatectl set-timezone Asia/Shanghai验证时区设置是否生效:…

IDEA新建文件夹后右击不能创建class类排错方法

目录 1 查看自身文件名是否为关键词 2 查看是否被“蓝色文件夹”给包含了 3 检查设置那边的class模板 4 报错解决 1 查看自身文件名是否为关键词 如下使用了 Java中的关键词"class"所以才无法创建包 ---------------------------------------------------------…

Undertow使用详解

简介 Undertow是一个开源的、灵活的、高性能的非阻塞性应用服务器,由JBoss提供。它可以用作嵌入式服务器,也可以用作大型项目的全功能应用服务器。Undertow的设计以提供最高的性能和最大的灵活性为主要目标,支持非阻塞性和阻塞性处理方式&…

08. 【Linux教程】CentOS 目录介绍

CentOS 目录介绍 前面小节介绍了如何安装并登录连接 CentOS 系统,本小节围绕 CentOS 系统的目录,介绍其各个目录的作用,方便读者以后在工作中很好地将项目和软件归类存储,熟悉 CentOS 系统各个目录的功能介绍,有助于加…

Centos 内存和硬盘占用情况以及top作用

目录 只查看内存使用情况: 内存使用排序取前5个: 硬盘占用情况 定位占用空间最大目录 top查看cpu及内存使用信息 前言-与正文无关 生活远不止眼前的苦劳与奔波,它还充满了无数值得我们去体验和珍惜的美好事物。在这个快节奏的世界中&…

【计算机网络】Socket的SO_TIMEOUT与连接超时时间

SO_TIMEOUT选项是Socket的一个选项,用于设置读取数据的超时时间。它指定了在读取数据时等待的最长时间,如果在指定的时间内没有数据可读取,将抛出SocketTimeoutException异常。 SO_TIMEOUT的设置 默认情况下,SO_TIMEOUT选项的值…

L1-016 查验身份证-java

输入样例1: 4 320124198808240056 12010X198901011234 110108196711301866 37070419881216001X输出样例1: 12010X198901011234 110108196711301866 37070419881216001X输入样例2: 2 320124198808240056 110108196711301862输出样例2&#…

项目02《游戏-06-开发》Unity3D

基于 项目02《游戏-05-开发》Unity3D , 接下来做 背包系统的 存储框架 , 首先了解静态数据 与 动态数据,静态代表不变的数据,比如下图武器Icon, 其中,武器的名称,描述&#xff…

7min到40s:SpringBoot 启动优化实践!

目录 背景 1 耗时问题排查 1.1 观察 SpringBoot 启动 run 方法 1.2 监控 Bean 注入耗时 2 优化方案 2.1 如何解决扫描路径过多? 2.2 如何解决 Bean 初始化高耗时? 3 新的问题 3.1 SpringBoot 自动化装配,让人防不胜防 3.2 使用 sta…

12. onnx转为rknn测试时有很多重叠框的修改(python)

我们下载rknn-toolkit2-master后并进行前面的处理后,进入到rknn-toolkit2-master\examples\onnx\yolov5文件夹,里面有个test.py文件,打开该文件,其代码如下: # -*- coding: utf-8 -*- # coding:utf-8import os import…

文心一言 VS 讯飞星火 VS chatgpt (194)-- 算法导论14.3 2题

二、用go语言,改写 INTERVAL-SEARCH 的代码,使得当所有区间都是开区间时,它也能正确地工作。 文心一言,代码正常运行: 在Go语言中,处理开区间(open intervals)时,我们需…