《网络协议》07. 其他协议


title: 《网络协议》07. 其他协议
date: 2022-10-07 18:24:02
updated: 2023-11-15 08:00:52
categories: 学习记录:网络协议
excerpt: IPv6、WebSocket、WebService(SOAP,WSDL)、HTTPDNS、FTP、邮件(SMTP,POP,IMAP)、即时通信(XMPP,MQTT)、流媒体。
comments: false
tags:
top_image: /images/backimg/SunsetClimbing.png


网络协议

  • 1:IPv6
    • 1.1:地址格式
    • 1.2:首部格式
  • 2:WebSocket
    • 2.1:建立连接
  • 3:WebService
    • 3.1:SOAP
    • 3.2:WSDL
  • 4:HTTPDNS
  • 5:FTP
    • 5.1:主动模式
    • 5.2:被动模式
  • 6:邮件
    • 6.1:相关协议
    • 6.1:邮件收发过程
    • 6.2:POP vs IMAP
  • 7:即时通信
    • 7.1:XMPP
    • 7.2:MQTT
  • 8:流媒体
    • 8.1:常见协议


网络协议从入门到底层原理。

1:IPv6

IPv6(Internet Protocol version 6),网际协议第 6 版。

  • 用它来取代 IPv4 主要是为了解决 IPv4 地址枯竭问题,同时它也在其他方面对于 IPv4 有许多改进
  • IPv6 采用 128 位地址,而 IPv4 使用的是 32 位
  • 支持 2^128(约 3.4 ∗ 10^38)个地址。以地球人口 70 亿人计算,每人平均可分得约 4.86 ∗ 10^28 个 IPv6 地址
  • 然而长期以来 IPv4 在互联网流量中仍占据主要地位,IPv6 的使用增长缓慢
  • 因为 IPv6 需要设备、操作系统内核升级,以支持 IPv6。不像 HTTP 升级到 HTTP2 一样方便

在 2019 年 12 月,通过 IPv6 使用 Google 服务的用户百分率首次超过 30%

1.1:地址格式

  • IPv6 地址为 128 bit,每 16 bit 一组,共 8 组
  • 每组以冒号【:】隔开,每组以 4 位十六进制方式表示
    • 例如 2001:0db8:86a3:08d3:1319:8a2e:0370:7344
  • 类似于 IPv4 的点分十进制,IPv6 同样也存在点分十六进制的写法
    • 2.0.0.1.0.d.b.8.8.5.a.3.0.8.d.3.1.3.1.9.8.a.2.e.0.3.7.0.7.3.4.4
  • 每组前面连续的 0 可以省略。下列 IPv6 地址是等价的:
    • 2001:0db8:02de:0000:0000:0000:0000:0e13
    • 2001:db8:2de:0:0:0:0:e13
  • 可以用双冒号【::】表示一组 0 或多组连续的 0。但只能出现一次。下列 IPv6 地址等价:
    • 2001:db8:2de:0:0:0:0:e13
    • 2001:db8:2de::e13
  • 2001::25de::cade 是非法的,因为双冒号出现了两次,会造成歧义:
    • 2001:0000:0000:0000:0000:25de:0000:cade
    • 2001:0000:25de:0000:0000:0000:0000:cade
  • ::1 是本地环回地址:0:0:0:0:0:0:0:1
    • ping ::1 可以 ping 通本机

1.2:首部格式

IPv6 有 40 字节的固定首部。

在这里插入图片描述

在这里插入图片描述

  • Version(占 4 bit,0110):版本号
  • Traffic Class(占 8 bit):交通类别
    • 指示数据包的类别或优先级,可以帮助路由器根据数据包的优先级处理流量
    • 如果路由器发生拥塞,则优先级最低的数据包将被丢弃
  • Payload Length(占 16 bit):有效负载长度
    • 最大值 65535 字节
    • 包括了扩展头部、上层(传输层)数据的长度首部格式
  • Hop Limit(占 8 bit):跳数限制
    • 与 IPv4 数据包中的 TTL 相同
  • Source Address(占 128 bit):源 IPv6 地址
  • Destination Address(占 128 bit):目的 IPv6 地址
  • Flow Label(占 20 bit):流标签
    • 指示数据包属于哪个特定序列(流)
    • 用数据包的源地址、目的地址、流标签标识一个流
  • Next Header(占 8 bit):下一个头部
    • 指示扩展头部(如果存在)的类型、上层数据包的协议类型(例如 TCP、UDP、ICMPv6)

扩展头部示意图如下。

在这里插入图片描述

在这里插入图片描述

2:WebSocket

Socket 是一套网络编程 API,利用它可以建立网络连接,一般都是操作系统底层实现的。
WebSocket 是一个网络协议。

HTTP 请求的特点:通信只能由客户端发起。所以,早期很多网站为了实现推送技术,所用的技术都是轮询。

轮询:由浏览器每隔一段时间(如每秒)向服务器发出 HTTP 请求,然后服务器返回最新的数据给客户端。

为了能更好的节省服务器资源和带宽,并且能够更实时地进行通讯,HTML5 规范中出现了 WebSocket 协议。

在这里插入图片描述

WebSocket,是基于 TCP 的支持全双工通信的应用层协议。客户端、服务器,任何一方都可以主动发消息给对方。

在 2011 年由 IETF 标准化为 RFC 6455,后由 RFC 7936 补充规范。

WebSocket 的应用场景很多:社交订阅、股票基金报价、体育实况更新、多媒体聊天、多玩家游戏等。

其实 TCP 本身就是支持全双工通信的(客户端、服务器均可主动发消息给对方),只是 HTTP 的 “ 请求-应答模式 ” 限制了 TCP 的能力。

  • WebSocket 和 HTTP 属于平级关系,都是应用层的协议。
  • WebSocket 使用 80(ws://)、443(wss://)端口,可以绕过大多数防火墙的限制。
    • ws://example.com/wsapi
    • wss://secure.example.com/wsapi
  • 与 HTTP 不同的是,WebSocket 需要先建立连接。
    • 这就使得 WebSocket 成为一种有状态的协议,之后通信时可以省略部分状态信息
    • 而 HTTP 请求可能需要在每个请求都额外携带状态信息(如身份认证等)

2.1:建立连接

WebSocket 需要借助 HTTP 协议来建立连接(也叫作 Handshake,握手)。

由客户端(浏览器)主动发出握手请求。

在这里插入图片描述

在这里插入图片描述

GUID:https://tools.ietf.org/html/rfc4122
SHA-1 摘要计算:http://encode.chahuo.com
Hex To Base64编码:https://base64.guru/converter/encode/hex

3:WebService

WebService(Web 服务),是一种跨编程语言和跨操作系统的远程调用技术标准。

WebService 使用场景举例:

  • 天气预报、手机归属地查询、航班信息查询、物流信息查询等
  • 比如天气预报,是气象局把自己的服务以 WebService 形式暴露出来,让第三方程序可以调用这些服务功能
  • http://www.webxml.com.cn/zh_cn/index.aspx

事实上,WebService 完全可以用普通的 Web API 取代(比如 HTTP + JSON )

现在很多企业的开放平台都是直接采用 Web API。

3.1:SOAP

SOAP(Simple Object Access Protocol,简单对象访问协议)。

  • 很多时候,SOAP = HTTP + XML
  • WebService 使用 SOAP 协议封装传递数据

在这里插入图片描述

3.2:WSDL

WSDL(Web Services Description Language,Web 服务描述语言)。

  • 一个 XML 文档,用以描述 WebService 接口的细节(比如参数、返回值等)
  • 一般在 WebService 的 URL 后面跟上 ?wsdl 获取 WSDL 信息。

http://ws.webxml.com.cn/WebServices/WeatherWS.asmx?wsdl

4:HTTPDNS

HTTPDNS:基于 HTTP 协议向 DNS 服务器发送域名解析请求。

  • 替代了基于 DNS 协议向运营商 Local DNS 发起解析请求的传统方式
  • 可以避免 Local DNS 造成的域名劫持和跨网访问问题
  • 常用在移动互联网中(比如在 Android、iOS 开发中)

在这里插入图片描述

HTTPDNS 的使用

  • 市面上已经有现成的解决方案
    腾讯云:https://cloud.tencent.com/product/httpdns

  • 移动端集成相关的 SDK 即可使用 HTTPDNS 服务

5:FTP

FTP(File Transport Protocol),文件传输协议。RFC 959 定义了此规范,是基于 TCP 的应用层协议

RFC 1738 中有定义,FTP 的 URL 格式为:ftp://user:password@host:port/url-path

在这里插入图片描述

连接模式

FTP 有 2 种连接模式:主动(Active)和被动(Passive)。

不管是哪种模式,都需要客户端和服务器建立 2 个连接:

  • 控制连接:用于传输状态信息(命令,command)
  • 数据连接:用于传输文件和目录信息(data)

在这里插入图片描述

5.1:主动模式

在这里插入图片描述

5.2:被动模式

在这里插入图片描述

6:邮件

6.1:相关协议

  • SMTP(Simple Mail Transfer Protocol),简单邮件传输协议

    • 发邮件使用的协议
    • 基于 TCP,标准参考 RFC 5321
    • 服务器默认使用 25 端口,SSL/TLS 使用 465 端口
  • POP(Post Office Protocol),邮局协议

    • 收邮件使用的协议
    • 基于 TCP,最新版是 POP3,标准参考 RFC 1939
    • 服务器默认使用 110 端口,SSL/TLS 使用 995 端口
  • IMAP(Internet Message Access Protocol),因特网信息访问协议

    • 基于 TCP,最新版是 IMAP4,标准参考 RFC 3501
    • 服务器默认使用 143 端口,SSL/TLS 使用 993 端口

6.1:邮件收发过程

在这里插入图片描述

6.2:POP vs IMAP

在这里插入图片描述

POP 的特点

  • 客户端连接服务器时,将会从服务器下载所有邮件
  • 可以设置下载完后,立即或一段时间后删除服务器邮件
  • 客户端的操作(比如删除邮件、移动到文件夹)不会跟服务器同步
  • 每个客户端都是独立的,都可以获得其自己的电子邮件副本

IMAP 的特点

  • 客户端连接服务器时,获取的是服务器上邮件的基本信息(如列表),并不会下载邮件
  • 等打开邮件时,才开始下载邮件
  • 客户端的操作(比如删除邮件、移动到文件夹)会跟服务器同步
  • 所有客户端始终会看到相同的邮件和相同的文件夹

7:即时通信

即时通信(Instant Messaging,IM),平时用的 QQ、微信,都属于典型的 IM 应用。

国内的 IM 开发者社区:http://www.52im.net/

IM 云服务:网易云信、腾讯云、环信等

常用协议:XMPP、MQTT、自定义协议。

7.1:XMPP

XMPP(Extensible Messaging and Presence Protocol),可扩展消息与存在协议。

  • 前身是 Jabber
  • 基于 TCP,默认端口 5222、5269

特点

  • 使用 XML 格式进行传输,体积较大
  • 专为 IM 而开发的、比较成熟的 IM 协议,开发者接入方便

7.2:MQTT

MQTT(Message Queuing Telemetry Transport),消息队列遥测传输。

  • 基于 TCP,默认端口 1883、8883(带 SSL/TLS)

特点

  • 开销很小,以降低网络流量,信息冗余远小于 XMPP
  • 不是专门为 IM 设计的协议,很多功能需要自己实现
  • 很多人认为 MQTT 是最适合物联网(Internet of Things,IoT)的网络协议

在这里插入图片描述

8:流媒体

流媒体(Streaming Media),又叫流式媒体,指将一连串的多媒体数据压缩后,经过互联网分段发送数据,在互联网上即时传输影音以供观赏的一种技术。

此技术使得资料数据包得以像流水一样发送,不使用此技术,就必须在使用前下载整个媒体文件。

8.1:常见协议

RTP(Real-Time Transport Protocol),实时传输协议

  • 基于 UDP
  • 参考:RFC 3550、RFC 3551

RTCP(Real-Time Transport Control Protocol),实时传输控制协议

  • 基于 UDP,使用 RTP 的下一个端口
  • 参考:RFC 3550

RTSP(Real-Time Streaming Protocol),实时流协议

  • 基于 TCP、UDP 的 554 端口
  • 参考:RFC 7820

RTMP(Real-Time Messaging Protocol),实时消息传输协议

  • 默认基于 TCP 的 1935 端口
  • 由 Adobe 公司出品

HLS(HTTP Live Streaming)

  • 基于 HTTP 的流媒体网络传输协议
  • 苹果公司出品,参考:RFC 821

人生自是有情痴,此恨不关风与月。

——《玉楼春》(宋)欧阳修

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

PostgreSQL基本操作

目录 1.源码安装PostgreSQL 1.1.前置条件(root下操作) 1.1.1.卸载yum安装的postgresql 1.1.2.创建postgres用户 1.1.3.安装部分依赖 1.1.4.源码安装uuid 1.2.安装PostgreSQL 1.2.1.使用postgres用户管理PostgreSQL 1.2.2.下载解压postgres12源码…

SUMO道路封闭车辆绕行仿真实验【TraCI】

本文将介绍如何在 SUMO 交通模拟中动态选择车辆绕行指定道路。 绕道是城市驾驶中的常见现象,造成原因有很多,包括建筑和交通事故等。 无论出于何种原因,并非所有车辆都会选择避开这些道路; 有些人可能会毫不犹豫地直接开车过去&a…

Linux信号量以及基于环形队列的生产者消费者模型

文章目录 信号量信号量的接口初始化销毁等待信号量发布信号量 环形队列结合信号量设计模型 实现基于环形队列的生产者消费者模型Task.hppRingQueue.hppmain.cc效果对于多生产多消费的情况 信号量 信号量的本质是一个计数器 首先一份公共资源在实际情况中可能存在不同的线程可…

spring 整合 JUnit

大家好,本篇博客我们通过spring来整合JUnitt单元测试框架。 在之前篇章的测试方法中,几乎都能看到以下的两行代码: ApplicationContext context new ClassPathXmlApplicationContext("xxx.xml"); Xxxx xxx context.getBean(Xxx…

ctyunos 与 openeuler

ctyunos-2.0.1-220311-aarch64-dvd ctyunos-2.0.1-220329-everything-aarch64-dvd glibc python3 对应openEuler 20.03 LTS SP1

μC/OS-II---互斥信号量管理2(os_mutex.c)

目录 背景:优先级反转问题互斥信号量管理互斥信号量发出(释放)互斥信号量获取/无等待互斥信号量状态查询 背景:优先级反转问题 在高优先级任务等待低优先级任务释放资源时,第三个中等优先级任务抢占了低优先级任务。阻…

【京东API】商品详情+搜索商品列表接口

利用电商API获取数据的步骤 1.申请API接口:首先要在相应电商平台上注册账号并申请API接口。 2.获取授权:在账号注册成功后,需要获取相应的授权才能访问电商API。 3.调用API:根据电商API提供的请求格式,通过编程实现…

8.GC基本原理

目录 概述垃圾回收引用计数法 (Reference Counting)根可达分析算法 (GCRooting Tracing)对象引用类型强引用软引用弱引用 清除垃圾1.标记-清除算法 (Mark-Sweep)2.复制算法 (Copying)3.标记-整理算法 (Mark-Compact)分代回收 (Generational Collection) 垃圾回收器GC-串行收集器…

力扣每日一题-K个元素的最大和-2023.11.15

力扣每日一题:K个元素的最大和 题目链接:2656.K个元素的最大和 题目描述 代码思路 题目看完直接笑嘻了,还有这么容易的题。由题可知,第一次要找出最大值m,那由于把m1放回去,那第二次找的就是m1,以此类推…

DGL如何表征一张图

有关于DGL中图的构建 DGL 将有向图表示为一个 DGL 图对象。图中的节点编号连续,从0开始。我们一般通过指定图中的节点数,以及源节点和目标节点的列表,来构建这么一个图。 下面的代码构造了一个图,这个图有五个叶子节点。中心节点…

python 多线程池 CPU拉满

前言: 关于多线程的博客先前的博客如下: python线程join方法_python 线程join-CSDN博客 【精选】Python GIL锁_python gil 锁-CSDN博客 python函数运行加速_python os.listdir速度慢_两只蜡笔的小新的博客-CSDN博客 只需下面的模版即可: from multi…

CNCC 2023收官,Milvus Cloud与行业大咖共话向量数据库系统

近期,CNCC 2023 在沈阳圆满结束,紧凑、前沿的 129 场技术论坛让人印象深刻。据悉,这 129 场技术论坛涵盖人工智能、安全、计算+、软件工程、教育、网络、芯片、云计算等 30 余个方向。Zilliz 受邀参与【智能时代的大数据系统】技术论坛。 智能时代的到来,无疑给社会经济和日…

前端 vue 面试题 (一)

文章目录 v-if,v-show差别v-for和v-if虚拟dom解决什么问题vue的data为什么返回函数不返回对象比较vue,reactvue双向绑定原理vue虚拟dom 的diff算法vue 虚拟dom的diff算法的时间复杂度vue2与vue3的区别vue数据缓存,避免重复计算单页应用怎么跨页面传参vue…

基于springboot实现学生选课平台管理系统项目【项目源码】

系统开发平台 在该地方废物回收机构管理系统中,Eclipse能给用户提供更多的方便,其特点一是方便学习,方便快捷;二是有非常大的信息储存量,主要功能是用在对数据库中查询和编程。其功能有比较灵活的数据应用&#xff0c…

队列与堆栈:原理、区别、算法效率和应用场景的探究

队列与堆栈:原理、区别、算法效率和应用场景的探究 前言原理与应用场景队列原理应用场景: 堆栈原理应用场景递归原理和堆栈在其中的作用递归原理堆栈作用 队列与堆栈区别队列堆栈算法效率 前言 本文主要讲解数据结构中队列和堆栈的原理、区别以及相关的…

解析数据洁净之道:BI中数据清理对见解的深远影响

本文由葡萄城技术团队发布。转载请注明出处:葡萄城官网,葡萄城为开发者提供专业的开发工具、解决方案和服务,赋能开发者。 前言 随着数字化和信息化进程的不断发展,数据已经成为企业的一项不可或缺的重要资源。然而,这…

0基础学习VR全景平台篇第121篇:认识视频剪辑软件Premiere

上课!全体起立~ 大家好,欢迎观看蛙色官方系列全景摄影课程! 大家好,这节课是带领大家认识认识我们的剪辑软件Premiere,一般简称是PR。 (PR界面) 我们首先打开PR,第一步就是要创建…

滚雪球学Java(64):LinkedHashSet原理及实现解析

咦咦咦,各位小可爱,我是你们的好伙伴——bug菌,今天又来给大家普及Java SE相关知识点了,别躲起来啊,听我讲干货还不快点赞,赞多了我就有动力讲得更嗨啦!所以呀,养成先点赞后阅读的好…

【数据结构】堆(Heap):堆的实现、堆排序、TOP-K问题

目录 堆的概念及结构 ​编辑 堆的实现 实现堆的接口 堆的初始化 堆的打印 堆的销毁 获取最顶的根数据 交换 堆的插入(插入最后) 向上调整(这次用的是小堆) 堆的删除(删除根) 向下调整(这次用的…

dgl 的cuda 版本 环境配置(dgl cuda 版本库无法使用问题解决)

1. 如果你同时有dgl dglcu-XX.XX 那么,应该只会运行dgl (DGL的CPU版本),因此,你需要把dgl(CPU)版本给卸载了 但是我只卸载CPU版本还不够,我GPU 版本的dglcu依旧不好使,因此吧GPU版本的也得卸载…