【计算机网络】第2章:应用层—应用层协议原理

news2025/6/5 17:00:02

目录

1. 网络应用的体系结构

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

3. 对等体(P2P)体系结构

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

Napster

即时通信

5. 进程通信

6. 分布式进程通信需要解决的问题

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

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

需穿过层间的信息(层间接口)

层面信息代表(Socket)

9. TCP 套接字(Socket)详解

10. TCP socket

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

UDP Socket

12. UDP之上的套接字(Socket)

13. UDP socket

14. 套接字(Socket)

15. 问题 3:如何使用传输层提供的服务实现应用

16. 应用层协议


1. 网络应用的体系结构

可能的应用架构:

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

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

服务器:

  • 一直运行
  • 固定的 IP 地址和周知的端口号(约定)
  • 扩展性:服务器场
    • 数据中心进行扩展
    • 扩展性差

客户端:

  • 主动与服务器通信
  • 与互联网有间歇性的连接
  • 可能是动态 IP 地址
  • 不直接与其它客户端通信


3. 对等体(P2P)体系结构

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


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

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

5. 进程通信

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

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

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

注意:P2P 架构的应用也有客户端进程和服务器进程之分


6. 分布式进程通信需要解决的问题

  1. 进程标示和寻址问题(服务用户)
  2. 传输层-应用层提供服务方式(服务)
    • 位置:层间界面的 SAP(TCP/IP:socket)
    • 形式:应用程序接口 API(TCP/IP:socket API)
  3. 如何使用传输层服务实现应用(用户使用服务)
    • 定义应用层协议:报文格式、解释、时序等
    • 编制程序,使用 OS API 调用网络设施传报文

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

  • 进程接收报文必须标识 SAP(发送同理)
  • 主机:唯一 32 位 IP 地址(但不足以唯一标识进程)
  • 需额外标识:
    • 传输层协议:TCP/UDP
    • 端口号(Port Numbers)
  • 知名端口号示例
    • HTTP: TCP 80
    • Mail: TCP 25
    • FTP: TCP 21(注:原图标注为 TCP 2,实际应为 21)
  • 进程唯一标识IP地址 + 端口号(端节点)
  • 本质:主机间通信由 2 个端节点构成

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

需穿过层间的信息(层间接口)
  • 要传输的报文(本层 SDU)
  • 对方应用进程标识:
    • 目标 IP + TCP/UDP 端口号
  • 传输层实体(TCP/UDP)据此封装:
    • TCP 段/UDP 数据报(含源/目标端口号)
    • 将 IP 地址交 IP 实体封装数据报(源/目标 IP)
层面信息代表(Socket)
  • Socket 作用
    • 避免每次携带完整 4 元组信息(繁琐易错)
    • 用户通过代号(socket)标识通信方
    • 类似 OS 文件句柄:操作句柄=操作文件
  • TCP Socket 特性
    • 需预先建立连接(会话关系稳定)
    • 用整数本地标示通信关系
    • 层间接口携带信息量最小
    • 本质代表 4 元组:(源IP, 源端口, 目标IP, 目标端口)

9. TCP 套接字(Socket)详解

  • 定义:面向连接服务(TCP)的本地意义标示
  • 4 元组(源IP, 源端口, 目标IP, 目标端口)
  • 核心特性
    • 唯一指定一个会话(两进程间)
    • 应用通过此标示与远程程序通信
    • 无需每次发送报文指定完整 4 元组
  • 优势
    • 类似 OS 文件句柄(替代目录名/文件名)
    • 简单高效,便于管理

10. TCP socket

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

UDP Socket
  • UDP服务特性
    • 无需预先建立连接
    • 每个报文独立传输
    • 前后报文可能发送至不同分布式进程
  • 本地标识
    • 仅需一个整数表示本应用实体
    • 原因:报文可能传输至不同进程(无固定通信关系)
  • 层间接口信息
    • 最小化信息量
    • UDP Socket内容:本机IP + 本机端口
  • 传输要求
    • 发送报文时必须提供目标IP及端口
    • 接收报文时,传输层需上传发送方的IP及端口

12. UDP之上的套接字(Socket)

  • 无连接服务(UDP)的Socket定义
    • 本地意义的2元组标识:(本机IP, 本机端口)
      • 指定应用所在的端节点(end point)
  • 发送数据时的优势
    • 使用预创建的本地Socket(标识ID),避免每次发送都重复指明本机IP和端口
  • 关键限制
    • 发送报文时必须显式指定目标IP和UDP端口(另一端点)

13. UDP socket

14. 套接字(Socket)

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

15. 问题 3:如何使用传输层提供的服务实现应用

  • 定义应用层协议:报文格式,解释,时序等
  • 编制程序,通过 API 调用网络基础设施提供通信服务传报文,解析报文,实现应用时序等

16. 应用层协议

  • 定义了:运行在不同端系统上的应用进程如何相互交换报文
    • 交换的报文类型:请求和应答报文
    • 各种报文类型的语法:报文中的各个字段及其描述
    • 字段的语义:即字段取值的含义
    • 进程何时、如何发送报文及对报文进行响应的规则
  • 应用协议仅仅是应用的一个组成部分
    • Web 应用:HTTP 协议,web 客户端,web 服务器,HTML

公开协议

  • 由 RFC 文档定义
  • 允许互操作
  • 如 HTTP, SMTP

专用(私有)协议

  • 协议不公开
  • 如:Skype

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

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

相关文章

【Zephyr 系列 6】使用 Zephyr + BLE 打造蓝牙广播与连接系统(STEVAL-IDB011V1 实战)

🧠关键词:Zephyr、BLE、广播、连接、GATT、低功耗蓝牙、STEVAL-IDB011V1 📌适合人群:希望基于 Zephyr 实现 BLE 通信的嵌入式工程师、蓝牙产品开发人员 🧭 前言:为什么选择 Zephyr 开发 BLE? 在传统 BLE 开发中,我们大多依赖于厂商 SDK(如 Nordic SDK、BlueNRG SD…

利用 Scrapy 构建高效网页爬虫:框架解析与实战流程

目录 前言1 Scrapy 框架概述1.1 Scrapy 的核心优势1.2 Scrapy 的典型应用场景 2 Scrapy 工作原理解析2.1 框架结构图2.2 Spider&#xff1a;定义数据采集策略2.3 Scheduler&#xff1a;调度请求与去重2.4 Downloader&#xff1a;网页下载器2.5 Item&#xff1a;结构化数据容器2…

RPG20.创建敌人的初始能力和加载武器

1. 基于StartUpAbilitiy基类创建专门用于敌人数据的DAStartUpABility&#xff0c;然后再基于新创建的DA再创建一个蓝图 2.打开 DataAsset_EnemyStartUpData.h // Fill out your copyright notice in the Description page of Project Settings.#pragma once#include "Cor…

自适应移动平均(Adaptive Moving Average, AMA)

文章目录 1. 考夫曼自适应移动平均 (KAMA)算法推导及Python实现2. 对 (KAMA)算法参数进行优化及实现 自适应移动平均&#xff08;Adaptive Moving Average, AMA&#xff09;由Perry Kaufman在其著作《Trading Systems and Methods》中提出&#xff0c;它通过动态调整平滑系数来…

涨薪技术|0到1学会性能测试第95课-全链路脚本开发实例

至此关于系统资源监控、apache监控调优、Tomcat监控调优、JVM调优、Mysql调优、前端监控调优、接口性能监控调优的知识已分享完,今天学习全链路脚本开发知识。后续文章都会系统分享干货,带大家从0到1学会性能测试。 前面章节介绍了如何封装.h头文件,现在通过一个实例来介绍…

Spring AI Alibaba + Nacos 动态 MCP Server 代理方案

作者&#xff1a;刘宏宇&#xff0c;Spring AI Alibaba Contributor 文章概览 Spring AI Alibaba MCP 可基于 Nacos 提供的 MCP server registry 信息&#xff0c;建立一个中间代理层 Java 应用&#xff0c;将 Nacos 中注册的服务信息转换成 MCP 协议的服务器信息&#xff0c…

MCP:让AI工具协作变得像聊天一样简单 [特殊字符]

想象一下,你正在处理一个项目,需要从A平台查看团队讨论,从B平台获取客户信息,还要在GitHub上检查代码进度。传统做法是什么?打开三个不同的网页,在各个平台间来回切换,复制粘贴数据,最后还可能因为信息分散而遗漏重要细节。 听起来很熟悉?这正是当前工作流程的痛点所…

AI炼丹日志-27 - Anubis 通过 PoW工作量证明的反爬虫组件 上手指南 原理解析

点一下关注吧&#xff01;&#xff01;&#xff01;非常感谢&#xff01;&#xff01;持续更新&#xff01;&#xff01;&#xff01; Java篇&#xff1a; MyBatis 更新完毕目前开始更新 Spring&#xff0c;一起深入浅出&#xff01; 大数据篇 300&#xff1a; Hadoop&…

阿姆达尔定律的演进:古斯塔夫森定律

前言 在上一篇文章《使用阿姆达尔定律来提升效率》中提到的阿姆达尔定律前提是假设问题的规模保持不变&#xff0c;并且给定一台速度更快的机器&#xff0c;目标是更快地解决问题。然而&#xff0c;在大多数情况下&#xff0c;这并不完全正确。当有一台更快的机器时&#xff0…

JavaScript极致性能优化全攻略

JavaScript性能优化深度指南 1 引言 JavaScript性能优化在现代Web开发中至关重要。随着Web应用日益复杂,性能直接影响用户体验、搜索引擎排名和业务转化率。研究表明,页面加载时间每增加1秒,转化率下降7%,跳出率增加32%。通过优化JavaScript性能,开发者可以: 提升用户满…

Transformer核心原理

简介 在人工智能技术飞速发展的今天&#xff0c;Transformer模型凭借其强大的序列处理能力和自注意力机制&#xff0c;成为自然语言处理、计算机视觉、语音识别等领域的核心技术。本文将从基础理论出发&#xff0c;结合企业级开发实践&#xff0c;深入解析Transformer模型的原…

Grafana-State timeline状态时间线

显示随时间推移的状态变化 状态区域&#xff1a;即状态时间线上的状态显示的条或带&#xff0c;区域长度表示状态持续时间或频率 数据格式要求&#xff08;可视化效果最佳&#xff09;&#xff1a; 时间戳实体名称&#xff08;即&#xff1a;正在监控的目标对应名称&#xf…

解决CSDN等网站访问不了的问题

原文网址&#xff1a;解决CSDN等网站访问不了的问题-CSDN博客 简介 本文介绍解决CSDN等网站访问不了的方法。 问题描述 CSDN访问不了了&#xff0c;页面是空的。 问题解决 方案1&#xff1a;修改DNS 可能是dns的问题&#xff0c;需要重新配置。 国内常用的dns是&#x…

C++ Vector算法精讲与底层探秘:从经典例题到性能优化全解析

前引&#xff1a;在C标准模板库&#xff08;STL&#xff09;中&#xff0c;vector作为动态数组的实现&#xff0c;既是算法题解的基石&#xff0c;也是性能优化的关键战场。其连续内存布局、动态扩容机制和丰富的成员函数&#xff0c;使其在面试高频题&#xff08;如LeetCode、…

Flowith,有一种Agent叫无限

大家好&#xff0c;我是羊仔&#xff0c;专注AI工具、智能体、编程。 今天羊仔要和大家聊聊一个最近发现的超级实用的Agent平台&#xff0c;名字叫Flowith。 这篇文章会带你从零了解到实战体验&#xff0c;搞清楚Flowith是如何让工作效率飙升好几倍&#xff0c;甚至重新定义未…

系统思考:短期利益与长期系统影响

一个决策难题&#xff1a;一家公司接到了一个大订单&#xff0c;客户提出了10%的降价要求&#xff0c;而企业的产能还无法满足客户的需求。你会选择增加产能&#xff0c;接受这个订单&#xff0c;还是拒绝&#xff1f;从系统思考的角度来看&#xff0c;这个决策不仅仅是一个简单…

HTTP连接管理——短连接,长连接,HTTP 流水线

连接管理是一个 HTTP 的关键话题&#xff1a;打开和保持连接在很大程度上影响着网站和 Web 应用程序的性能。在 HTTP/1.x 里有多种模型&#xff1a;短连接、_长连接_和 HTTP 流水线。 下面分别来详细解释 短连接 HTTP 协议最初&#xff08;0.9/1.0&#xff09;是个非常简单的…

【免费】2004-2020年各省电力消费量数据

2004-2020年各省电力消费量数据 1、时间&#xff1a;2004-2020年 2、来源&#xff1a;国家统计局、统计年鉴 3、指标&#xff1a;行政区划代码、地区、年份、电力消费量(亿千瓦小时) 4、范围&#xff1a;31省 5、指标说明&#xff1a;电力消费量是指在一定时期内&#xff…

登录的写法,routerHook具体配置,流程

routerHook挂在在index.js/main.js下的&#xff0c;找不到可以去那边看一下 vuex需要做的&#xff1a; //创建token的sate&#xff0c;从本地取 let token window.localStorage.getItem(token) // 存储用户登录信息let currentUserInfo reactive({userinfo: {}}) //存根据不…

工作服/反光衣检测算法AI智能分析网关V4安全作业风险预警方案:筑牢矿山/工地/工厂等多场景安全防线

一、方案背景​ 在工地、矿山、工厂等高危作业场景&#xff0c;反光衣是保障人员安全的必备装备。但传统人工巡查存在效率低、易疏漏等问题&#xff0c;难以实现实时监管。AI智能分析网关V4基于人工智能技术&#xff0c;可自动识别人员着装状态&#xff0c;精准定位未穿反光衣…