【应用层协议原理】

news2025/1/18 18:10:27

文章目录

  • 第二章 应用层
    • 2.1 应用层协议原理
      • 2.1.1 网络应用的体系结构
      • 2.1.2 客户-服务器(C/S)体系结构
      • 2.1.3 对等体(P2P)体系结构
      • 2.2.4 C/S和P2P体系结构的混合体
      • 2.2.5 进程通信
      • 问题1:对进程进行编址(addressing)
      • 问题2:传输层提供的服务-需要穿过层间的信息。
      • 问题3:传输层提供的服务-层间信息的代表
      • TCP之上的套接字(socket)
      • 问题2:传输层提供的服务-层间信息代码
      • UDP之上的套接字(socket)
      • 套接字(Socket)
      • 应用层协议
      • 应用需要传输层提供什么样的服务?如何描述传输层的服务?
      • Internet传输层的服务
      • UDP存在的必要性

第二章 应用层

目标:

  • 网络应用的原理:网络应用协议的概念和实现方面。
    • 传输层的服务模型
    • 客户-服务器模式
    • 对等模式(peer-to-peer)
    • 内容分发网络
  • 网络应用的实例:互联网流行的应用层协议
    • HTTP
    • FTP
    • AMTP/POP3/IMAP
    • DNS
  • 编程:网络应用程序
    • socket API

2.1 应用层协议原理

2.1.1 网络应用的体系结构

可能的应用架构:

  • 客户-服务器模式(C/S)
  • 对等模式(Peer To Peer)
  • 混合体:客户-服务器和对等体系结构

2.1.2 客户-服务器(C/S)体系结构

  • 服务器:
    • 一直运行
    • 固定的IP地址和周知的端口号(约定)
    • 扩展性:服务器场
      • 数据中心进行扩展
      • 扩展性差
  • 客户端:
    • 主动与服务器通信
    • 与互联网有间歇性的连接
    • 可能是动态IP地址
    • 不直接与其他客户端通信

2.1.3 对等体(P2P)体系结构

  • 几乎没有一直运行的服务器
  • 任意端系统之间可以进行通信
  • 每一个结点既是客户端又是服务器
    • 自扩展性-新peer节点带来的新的服务能力,当然也能带来新的服务请求。
  • 参与的主机间歇性连接可以改变IP地址。
    • 难以管理
  • 例:迅雷

2.2.4 C/S和P2P体系结构的混合体

Napster
- 文件搜索:集中
- 主机在中心服务器上注册其资源
- 主机向中心服务器查询资源位置
- 文件传输:P2P
- 任意Peer节点之间
即时通信
- 在线检测:集中
- 当用户上线时,向中心服务器注册其IP地址
- 当用户中心服务器联系,以找到其在线好友的位置
- 两个用户之间聊天:P2P

2.2.5 进程通信

进程:在主机上运行的应用程序

  • 在同一个主机内,使用进程间通信机制通信(操作系统定义)
  • 不同主机,通过交换报文(Message)来通信
    • 使用OS提供的通信服务
    • 按照应用协议交换报文
      • 借助传输层提供的服务
        在这里插入图片描述

问题1:对进程进行编址(addressing)

  • 进程为了接收报文,必须有一个标识,即SAP(Service Access Point 服务访问点)(发送也需要标识)。
    • 主机:唯一的·32位IP地址
      • 仅仅有IP地址不能够唯一标示一个进程;在一台端系统上有很多应用进程在运行。
    • 所采用的传输层协议:TCP or UDP
    • 端口号(Port Number)
  • 一个进程:用IP+port标识 端节点
  • 本质上,一对主机进程之间的通信由2个端节点构成。

问题2:传输层提供的服务-需要穿过层间的信息。

在这里插入图片描述

  • 层间接口必须要携带的信息
    • 要传输的报文(对于本层来说:SDU(Service Data Unit))
    • 谁传的:对方的应用进程的标识:IP+TCP(UDP) 端口
    • 传给谁:对方的应用进程的标识:对方的IP+TCP(UDP)端口号
  • 传输层实体(tcp或者udp实体)根据这些信息进行TCP报文段(UDP数据报)的封装
    • 源端口号,目标端口号,数据等。
    • 将IP地址往下交IP实体,用于封装IP数据报:源IP,目标IP。

问题3:传输层提供的服务-层间信息的代表

  • 如果Soket API 每次传输报文,都携带如此多的信息,太繁琐,不便于管理。
  • 用个代号标识通信的双方或者单方:soket
  • 就像OS打开文件返回的句柄一样
  • TCP socket:
    • TCP服务,两个进程之间的通信需要之前要建立连接
      • 两个进程通信会持续一段时间,通信关系稳定
    • 可以用一个整数表示两个应用实体之间的通信关系,本地标识。
    • 穿过层间接口的信息量最小
    • TCP socket:源IP,源端口,目标IP,目标端口。

TCP之上的套接字(socket)

  • 对于使用面向连接服务(TCP)的应用而言,套接字是4元组的一个具有本地意义的标示。
    • 4元组:(源IP,源port,目标IP,目标port)
    • 唯一的指定了一个会话(2个进程之间的会话关系)。
    • 应用使用这个标示,与远程的应用进程通信。
    • 不必在每一个报文的发送都要指定这4元组。
      在这里插入图片描述
      在这里插入图片描述

    问题2:传输层提供的服务-层间信息代码

    • UDP socket:
      • UDP服务,两个进程之间的通信需要之前无需建立连接。
        • 每个报文都是独立传输的。
        • 前后报文可能给不同的分布式进程。
      • 过层间接口的信息大小最小。
      • UDP socket:本IP,本端口
      • 但是传输报文:必须要提供对方IP,port。
        • 接收报文时:传输层要上传对方的IP,port。

UDP之上的套接字(socket)

  • 对于使用无连接服务(UDP)的应用而言,套接字是2元组的一个具有本地意义的标示。
    • 2元组:IP,port (源端指定)。
    • UDP套接字指定了应用所在的一个端节点(end point)。
    • 在发送数据报时,采用创建好的本地套接字(标示ID),就不必在发送每个报文中指明自己所采用的ip和port。
    • 但是在发送报文时,必须要指定对方的ip和udp port(另外一个段节点)。
      在这里插入图片描述

套接字(Socket)

  • 进程向套接字发送报文或从套接字接收报文。
  • 套接字<---->门户
    • 发送进程将报文推出门户,发送进程依赖于传输层设施在另外一侧的门将报文交付给接受进程。
    • 接收进程从另外一端的门户收到报文(依赖于传输层设施)。

应用层协议

  • 定义了:运行在不同端系统上的应用进程如何相互交换报文。

应用需要传输层提供什么样的服务?如何描述传输层的服务?

数据丢失率

  • 有些应用则要求100%的可靠数据传输(如文件)。
  • 有些应用(如音频)能容忍一定比例以下的数据丢失。
    延迟
    吞吐
  • 一些应用(如多媒体)必须需要最小限度的吞吐,从而使得应用能够有效运转。

Internet传输层的服务

TCP服务:

  • 可靠的传输服务
  • 流量控制:发送方不会淹没接受方。
  • 拥塞控制:当网络出现拥塞时,能抑制发送方。
  • 面向连接:要求在客户端进程和服务器进程之间建立连接。

UDP服务:

  • 不可靠的数据传输。
    不提供的服务:可靠,流量控制,拥塞控制,时间,带宽控制,建立连接。

UDP存在的必要性

  • 能够区分不同的进程,而IP服务不能。
  • 无需建立连接,省去了建立连接时间,适合事务性的应用。
  • 不做可靠性的工作,例如检错重发,适合那些对实时性要求比较高而对正确性要求不高的应用。
  • 没有拥塞控制和流量控制,应用能够按照设定的速度发送数据。

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1557407.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

厦门攸信技术亮相新技术研讨会,展现物流自动化解决方案新高度!

今日&#xff0c;厦门攸信信息技术有限公司受邀参加了一场备受行业关注的电子制造高端盛会——一步步新技术研讨会&#xff0c;凭借卓越的智能制造与物流自动化技术在会议中大放异彩。作为一家引领行业发展的企业&#xff0c;厦门攸信技术不仅展示了其深厚的技术底蕴&#xff0…

算法之美:堆排序原理剖析及应用案例分解实现

这段时间持续更新关于“二叉树”的专栏文章&#xff0c;关心的小伙伴们对于二叉树的基本原理已经有了初步的了解。接下来&#xff0c;我将会更深入地探究二叉树的原理&#xff0c;并且展示如何将这些原理应用到更广泛的场景中去。文章将延续前面文章的风格&#xff0c;尽量精炼…

数据结构 - 图

参考链接&#xff1a;数据结构&#xff1a;图(Graph)【详解】_图数据结构-CSDN博客 图的定义 图(Graph)是由顶点的有穷非空集合 V ( G ) 和顶点之间边的集合 E ( G ) 组成&#xff0c;通常表示为: G ( V , E ) &#xff0c;其中&#xff0c; G 表示个图&#xff0c; V 是图 G…

深入理解 Hadoop 上的 Hive 查询执行流程

在 Hadoop 生态系统中&#xff0c;Hive 是一个重要的分支&#xff0c;它构建在 Hadoop 之上&#xff0c;提供了一个开源的数据仓库系统。它的主要功能是查询和分析存储在 Hadoop 文件中的大型数据集&#xff0c;包括结构化和半结构化数据。Hive 在数据查询、分析和汇总方面发挥…

Linux(CentOS7)安装 MySQL8

目录 下载 上传 解压 创建配置文件 初始化 MySQL 服务 启动 MySQL 服务 连接 MySQL 创建软链接 下载 官方地址&#xff1a; MySQL :: Download MySQL Community Serverhttps://dev.mysql.com/downloads/mysql/选择版本前需先看一下服务器的 glibc 版本 ldd --versio…

计算机视觉之三维重建(5)---双目立体视觉

文章目录 一、平行视图1.1 示意图1.2 平行视图的基础矩阵1.3 平行视图的极几何1.4 平行视图的三角测量 二、图像校正三、对应点问题3.1 相关匹配法3.2 归一化相关匹配法3.3 窗口问题3.4 相关法存在的问题3.5 约束问题 一、平行视图 1.1 示意图 如下图即是一个平行视图。特点&a…

基于Apriori关联规则的电影推荐系统(python实现)

基于Apriori关联规则的电影推荐系统 1、效果图 2、算法原理 Apriori算法是一种用于挖掘关联规则的频繁项集算法,它采用逐层搜索的迭代方法来发现数据库中项集之间的关系并形成规则。 其核心思想是利用Apriori性质来压缩搜索空间,即如果一个项集是非频繁的,那么它的所有父…

结构体类型,结构体变量的创建和初始化 以及结构中存在的内存对齐

一般结构体类型的声明 struct 结构体类型名 { member-list; //成员表列 }variable-list; //变量表列 例如描述⼀个学⽣&#xff1a; struct Stu { char name[20]; //名字 int age; //年龄 char sex[5]; //性别 }&#xff1b; //结构体变量的初始化 int main() { S…

Django详细教程(二) - 部门用户管理案例

文章目录 前言一、新建项目二、新建app三、设计表结构四、新建数据库五、新建静态文件六、部门管理1.部门展示2.部门添加3.部门删除4.部门编辑 七、模板继承八、用户管理1.辨析三种方法方法一&#xff1a;原始方法方法二&#xff1a;Form组件(简便)方法三&#xff1a;ModelForm…

macOS搭建php环境以及调试Symfony

macOS搭建php环境以及调试Symfony macOS搭建php环境以及调试Symfony 古老的传说运行环境快速前置安装环境 php 的安装安装 Xdebug 来调试 php如何找到你的 php.iniXdebug 安装成功 创建并调试的 Hello world 安装 PHP Debug 安装 Symfony 安装 Composer安装 Symfony CLI 创建 …

vue系统——v-html

<!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0"><title>v-html指令</title> </head> <body&…

微信小程序备案流程详细操作指南

自2023年9月1日起&#xff0c;所有新上架的微信小程序均需事先完成备案手续&#xff0c;方能成功上线。而对于已经上架的存量小程序&#xff0c;也需要在2024年3月31日前完成备案工作。若在规定时间内未完成备案&#xff0c;平台将依据备案相关规定&#xff0c;自2024年4月1日起…

大语言模型---强化学习

本文章参考&#xff0c;原文链接&#xff1a;https://blog.csdn.net/qq_35812205/article/details/133563158 SFT使用交叉熵损失函数&#xff0c;目标是调整参数使模型输出与标准答案一致&#xff0c;不能从整体把控output质量 RLHF&#xff08;分为奖励模型训练、近端策略优化…

java数组与集合框架(二)-- 集合框架,Iterator迭代器,list

集合框架&#xff1a; 用于存储数据的容器。 Java 集合框架概述 一方面&#xff0c;面向对象语言对事物的体现都是以对象的形式&#xff0c;为了方便对多个对象的操作&#xff0c;就要对对象进行存储。另一方面&#xff0c;使用Array存储对象方面具有一些弊端&#xff0c;而…

小狐狸ChatGPT付费AI创作系统V2.8.0独立版 + H5端 + 小程序前端

狐狸GPT付费体验系统的开发基于国外很火的ChatGPT&#xff0c;这是一种基于人工智能技术的问答系统&#xff0c;可以实现智能回答用户提出的问题。相比传统的问答系统&#xff0c;ChatGPT可以更加准确地理解用户的意图&#xff0c;提供更加精准的答案。同时&#xff0c;小狐狸G…

09_Web组件

文章目录 Web组件Listener监听器ServletContextListener执行过程 Filter过滤器Filter与Servlet的执行 案例&#xff08;登录案例&#xff09; 小结Web组件 Web组件 JavaEE的Web组件&#xff08;三大Web组件&#xff09;&#xff1a; Servlet → 处理请求对应的业务Listener →…

图论做题笔记:dfs

Leetcode - 797&#xff1a;所有可能的路径 题目&#xff1a; 给你一个有 n 个节点的 有向无环图&#xff08;DAG&#xff09;&#xff0c;请你找出所有从节点 0 到节点 n-1 的路径并输出&#xff08;不要求按特定顺序&#xff09; graph[i] 是一个从节点 i 可以访问的所有节…

公司官网怎么才会被百度收录

在互联网时代&#xff0c;公司官网是企业展示自身形象、产品与服务的重要窗口。然而&#xff0c;即使拥有精美的官网&#xff0c;如果不被搜索引擎收录&#xff0c;就无法被用户发现。本文将介绍公司官网如何被百度收录的一些方法和步骤。 1. 创建和提交网站地图 创建网站地图…

el-select的错误提示不生效、el-select验证失灵、el-select的blur规则失灵

发现问题 在使用el-select进行表单验证的时候&#xff0c;发现点击下拉列表没选的情况下&#xff0c;他不会提示没有选择选项的信息&#xff0c;我设置了rule如下 <!--el-select--><el-form-item label"等级" prop"level"><el-select v-m…

代码随想录算法训练营Day39|LC62 不同路径LC63 不同路径II

一句话总结&#xff1a;不是太难&#xff0c;状态转移方程好想。 原题链接&#xff1a;62 不同路径 位置为(i, j)的点只能从上面或者左边过来&#xff0c;由此可列出状态转移方程。状态转移方程的初始化为所有第一排和第一列的点都初始化为1即可。 class Solution {public i…