【计算机网络】第2章:应用层—应用层协议原理
目录
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. 分布式进程通信需要解决的问题
- 进程标示和寻址问题(服务用户)
- 传输层-应用层提供服务方式(服务)
- 位置:层间界面的 SAP(TCP/IP:socket)
- 形式:应用程序接口 API(TCP/IP:socket API)
- 如何使用传输层服务实现应用(用户使用服务)
- 定义应用层协议:报文格式、解释、时序等
- 编制程序,使用 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)
- 本地意义的2元组标识:
- 发送数据时的优势:
- 使用预创建的本地Socket(标识ID),避免每次发送都重复指明本机IP和端口
- 关键限制:
- 发送报文时必须显式指定目标IP和UDP端口(另一端点)
13. UDP socket
14. 套接字(Socket)
- 进程向套接字发送报文或从套接字接收报文
- 套接字 <-> 门户
- 发送进程将报文推出门户,发送进程依赖于传输层设施在另外一侧的门将报文交付给接受进程
- 接收进程从另外一端的门户收到报文(依赖于传输层设施)
15. 问题 3:如何使用传输层提供的服务实现应用
- 定义应用层协议:报文格式,解释,时序等
- 编制程序,通过 API 调用网络基础设施提供通信服务传报文,解析报文,实现应用时序等
16. 应用层协议
- 定义了:运行在不同端系统上的应用进程如何相互交换报文
- 交换的报文类型:请求和应答报文
- 各种报文类型的语法:报文中的各个字段及其描述
- 字段的语义:即字段取值的含义
- 进程何时、如何发送报文及对报文进行响应的规则
- 应用协议仅仅是应用的一个组成部分
- Web 应用:HTTP 协议,web 客户端,web 服务器,HTML
公开协议:
- 由 RFC 文档定义
- 允许互操作
- 如 HTTP, SMTP
专用(私有)协议:
- 协议不公开
- 如:Skype
相关文章:

【计算机网络】第2章:应用层—应用层协议原理
目录 1. 网络应用的体系结构 2. 客户-服务器(C/S)体系结构 3. 对等体(P2P)体系结构 4. C/S 和 P2P 体系结构的混合体 Napster 即时通信 5. 进程通信 6. 分布式进程通信需要解决的问题 7. 问题1:对进程进行编址…...

【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:定义数据采集策略2.3 Scheduler:调度请求与去重2.4 Downloader:网页下载器2.5 Item:结构化数据容器2…...

RPG20.创建敌人的初始能力和加载武器
1. 基于StartUpAbilitiy基类创建专门用于敌人数据的DAStartUpABility,然后再基于新创建的DA再创建一个蓝图 2.打开 DataAsset_EnemyStartUpData.h // Fill out your copyright notice in the Description page of Project Settings.#pragma once#include "Cor…...
P5684 [CSP-J2019 江西] 非回文串 题解
https://www.luogu.com.cn/problem/P5684 /* 比较简单的组合计数 题目没有以文字去描述,而是用下标来形式化题意,给我们一个关键信息:判定两个串是否相同不是看字符是否相同,而是看下标 换言之就是相同的字符,如果下标…...

自适应移动平均(Adaptive Moving Average, AMA)
文章目录 1. 考夫曼自适应移动平均 (KAMA)算法推导及Python实现2. 对 (KAMA)算法参数进行优化及实现 自适应移动平均(Adaptive Moving Average, AMA)由Perry Kaufman在其著作《Trading Systems and Methods》中提出,它通过动态调整平滑系数来…...
Java密码加密存储算法,SpringBoot 实现密码安全存储
文章目录 一、写在前面二、密码加密存储方式1、基于MD5加盐方式2、SHA-256 Salt(不需要第三方依赖包)3、使用 BCrypt 进行哈希4、使用 PBKDF2 进行哈希5、使用 Argon2 进行哈希6、SCrypt 一、写在前面 日常开发中,用户密码存储是严禁明文存…...
使用 Version Catalogs统一配置版本 (Gradle 7.0+ 特性)
1.在 gradle/libs.versions.toml 文件中定义: [versions] compileSdk "34" minSdk "21" targetSdk "34" 2. 在 build.gradle 中使用: android {compileSdkVersion libs.versions.compileSdk.get().toInteger()defaul…...

涨薪技术|0到1学会性能测试第95课-全链路脚本开发实例
至此关于系统资源监控、apache监控调优、Tomcat监控调优、JVM调优、Mysql调优、前端监控调优、接口性能监控调优的知识已分享完,今天学习全链路脚本开发知识。后续文章都会系统分享干货,带大家从0到1学会性能测试。 前面章节介绍了如何封装.h头文件,现在通过一个实例来介绍…...
C++文件和流基础
C文件和流基础 1. C文件和流基础1.1 文件和流的概念1.2 标准库支持1.3 常用文件流类ifstream 类ofstream 类fstream 类 2.1 打开文件使用构造函数打开文件使用 open() 成员函数打开文件打开文件的模式标志 2.2 关闭文件使用 close() 成员函数关闭文件关闭文件的重要性 3.1 写入…...

Spring AI Alibaba + Nacos 动态 MCP Server 代理方案
作者:刘宏宇,Spring AI Alibaba Contributor 文章概览 Spring AI Alibaba MCP 可基于 Nacos 提供的 MCP server registry 信息,建立一个中间代理层 Java 应用,将 Nacos 中注册的服务信息转换成 MCP 协议的服务器信息,…...

MCP:让AI工具协作变得像聊天一样简单 [特殊字符]
想象一下,你正在处理一个项目,需要从A平台查看团队讨论,从B平台获取客户信息,还要在GitHub上检查代码进度。传统做法是什么?打开三个不同的网页,在各个平台间来回切换,复制粘贴数据,最后还可能因为信息分散而遗漏重要细节。 听起来很熟悉?这正是当前工作流程的痛点所…...
C++ Learning string类模拟实现
string类模拟实现 std::string 类作为 C 标准库中非常重要的一个类型,它封装了字符串的动态分配、内存管理以及其他字符串操作。 基本构思与设计 一个简化版的 string 类需要满足以下基本功能: 存储一个字符数组(char*)。记录…...
Message=“HalconDotNet.HHandleBase”的类型初始值设定项引发异常
该异常通常与HalconDotNet库的版本冲突或环境配置问题有关,以下是常见解决方案: 版本冲突处理 检查项目中是否同时存在多个HalconDotNet引用(如NuGet安装和本地引用混用),需删除所有冲突引用并统一版本2确保工具…...

AI炼丹日志-27 - Anubis 通过 PoW工作量证明的反爬虫组件 上手指南 原理解析
点一下关注吧!!!非常感谢!!持续更新!!! Java篇: MyBatis 更新完毕目前开始更新 Spring,一起深入浅出! 大数据篇 300: Hadoop&…...

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

JavaScript极致性能优化全攻略
JavaScript性能优化深度指南 1 引言 JavaScript性能优化在现代Web开发中至关重要。随着Web应用日益复杂,性能直接影响用户体验、搜索引擎排名和业务转化率。研究表明,页面加载时间每增加1秒,转化率下降7%,跳出率增加32%。通过优化JavaScript性能,开发者可以: 提升用户满…...
批量大数据并发处理中的内存安全与高效调度设计(以Qt为例)
背景 在批量处理大型文件(如高分辨率图片、视频片段、科学数据块)时,开发者通常希望利用多核CPU并行计算以提升处理效率。然而,如果每个任务对象的数据量很大,直接批量并发处理极易导致系统内存被迅速耗尽,出现程序假死、崩溃,甚至系统级“死机”。 Qt自带的线程池(Q…...

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

Grafana-State timeline状态时间线
显示随时间推移的状态变化 状态区域:即状态时间线上的状态显示的条或带,区域长度表示状态持续时间或频率 数据格式要求(可视化效果最佳): 时间戳实体名称(即:正在监控的目标对应名称…...

解决CSDN等网站访问不了的问题
原文网址:解决CSDN等网站访问不了的问题-CSDN博客 简介 本文介绍解决CSDN等网站访问不了的方法。 问题描述 CSDN访问不了了,页面是空的。 问题解决 方案1:修改DNS 可能是dns的问题,需要重新配置。 国内常用的dns是&#x…...
【华为云Astro Zero】组装设备管理页面开发(图形拖拽 + 脚本绑定)
目录 🧠 一、核心原理概览(类比说明) 🛠 二、完整操作步骤(详细图形拖拽流程) 1. 创建项目页面骨架 2. 定义设备信息的数据模型 equipmentInstance 3. 定义服务模型(接口绑定机器人搬运逻辑) 4. 拖拽组件搭建界面结构 4.1 表格: 4.2 工具栏按钮(新增) 4.…...
PopupImageMenuItem 无响应
Popup Menu | GNOME JavaScript let menuItem new PopupMenu.PopupImageMenuItem(设置, settings, {}); 第三个参数 params (Object) — Additional item properties 写了个 {},我就以为是 function,我还改成了 () > {} ! 正常是通过 connect 响…...

C++ Vector算法精讲与底层探秘:从经典例题到性能优化全解析
前引:在C标准模板库(STL)中,vector作为动态数组的实现,既是算法题解的基石,也是性能优化的关键战场。其连续内存布局、动态扩容机制和丰富的成员函数,使其在面试高频题(如LeetCode、…...

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

系统思考:短期利益与长期系统影响
一个决策难题:一家公司接到了一个大订单,客户提出了10%的降价要求,而企业的产能还无法满足客户的需求。你会选择增加产能,接受这个订单,还是拒绝?从系统思考的角度来看,这个决策不仅仅是一个简单…...
大数据 ETL 工具 Sqoop 深度解析与实战指南
一、Sqoop 核心理论与应用场景 1.1 设计思想与技术定位 Sqoop 是 Apache 旗下的开源数据传输工具,核心设计基于MapReduce 分布式计算框架,通过并行化的 Map 任务实现高效的数据批量迁移。其特点包括: 批处理特性:基于 MapReduc…...
【学习记录】Django Channels + WebSocket 异步推流开发常用命令汇总
文章目录 📌 摘要🧰 虚拟环境管理✅ 创建虚拟环境✅ 删除虚拟环境✅ 激活/切换虚拟环境 🛠️ Django 项目管理✅ 查看 Django 版本✅ 创建 Django 项目✅ 创建 Django App 💬 Channels 常用操作✅ 查看 Channels 版本 ὐ…...
(四)动手实现多层感知机:深度学习中的非线性建模实战
1 多层感知机(MLP) 多层感知机(Multilayer Perceptron, MLP)是一种前馈神经网络,包含一个或多个隐藏层。它能够学习数据中的非线性关系,广泛应用于分类和回归任务。MLP的每个神经元对输入信号进行加权求和…...

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