为什么过滤 rtmpt 而不是 rtmp?

😄作者简介: 小曾同学.com,一个致力于测试开发的博主⛽️,主要职责:测试开发、CI/CD

如果文章知识点有错误的地方,还请大家指正,让我们一起学习,一起进步。

😊 座右铭:不想当开发的测试,不是一个好测试✌️。

如果感觉博主的文章还不错的话,还请点赞、收藏哦!👍

文章目录

  • [一 背景](#一 背景)
  • [二 rtmpt](#二 rtmpt)
    • [2.1 含义](#2.1 含义)
    • [2.2 工作原理](#2.2 工作原理)
    • [2.3 数据包特征](#2.3 数据包特征)
  • [三 为什么过滤 rtmpt 而不是 rtmp?](#三 为什么过滤 rtmpt 而不是 rtmp?)
    • [3.1 Wireshark 如何工作](#3.1 Wireshark 如何工作)
  • 小结

一 背景

在 rtmp 推流时,有时需要通过 wireshark 工具抓包,而在过滤搜索中会搜索 rtmpt,那么 rtmpt 是什么含义,和 rtmp 又有什么关系?

二 rtmpt

2.1 含义

rtmpt 全称 RTMP over HTTP Tunneling(Tunneling 中文隧道技术)是一种封装技术,是 RTMP 协议的一种传输方式,允许将原始的 RTMP 数据流嵌套在 HTTP 请求和响应中进行传输。核心目的是绕过防火墙或代理的限制。

2.2 工作原理

有些网络环境可能会阻止非标准端口的流量,比如 rtmp 默认的 1935 端口,但通常会允许 HTTP 端口(80)或 HTTPS(443)流量通过,而 RTMP 正是利用这一特点。客户端会与服务器建立一个 HTTP 连接,然后将原本要通过 TCP 端口 1935 发送的 RTMP 数据包作为 HTTP 请求的载荷(Payload) 发送出去。服务器端接收到这个 HTTP 请求后,会解封装出里面的 RTMP 数据包进行处理,并将响应再以 HTTP 响应的形式封装起来发回给客户端。

2.3 数据包特征

在 Wireshark 抓包时,在没有过滤的情况下外层是标准的 HTTP 协议,内层也就是 HTTP 载荷部分才是真实的 RTMP 二进制数据,Wireshark 能够智能地解析这种封装,并显示出 rtmpt 协议。

三 为什么过滤 rtmpt 而不是 rtmp?

如果过滤 RTMP, 窗口不会显示任何内容或者只会匹配那些最内层、真正的 RTMP 协议数据包,如果一个 RTMP 数据流是通过纯 TCP(端口 1935)传输的,过滤 rtmp 会抓到它们。但如果它是通过 HTTP 隧道(rtmpt)传输的,这些内层的 RTMP 数据包被外层的 HTTP 包裹着,直接过滤 rtmp 可能会错过建立隧道本身的初始握手和控制包,或者显示不完整。而过滤 rtmpt,则会显示所有的 RTMP 协议内容,会匹配所有被标识为"使用 HTTP 隧道传输"的 RTMP 流量。这包括了建立隧道的 HTTP 请求/响应以及隧道内的所有 RTMP 数据。它抓住了整个通信的"通道"。

这也涉及到 Wireshark 的解析和显示过滤器的逻辑。刚才说到,当流量通过 rtmp 传输时,网络上传输的实际是 HTTP 数据包,而 Wireshark 的协议解析器(Dissector) 非常强大。当它遇到一个 HTTP 数据包,并且其内容看起来像是 RTMP 流量时,它会进行"深度解析"。

3.1 Wireshark 如何工作

  1. 数据包首先被其识别为 http。

  2. 然后它检查 HTTP 的载荷(Payload),发现里面是 RTMP 数据。

  3. 它会在协议栈中额外添加一层 rtmpt 协议,来表示"这个 HTTP 载荷里封装了 RTMP"。这只是一个标签,用于告诉我们封装方式。

  4. 最后,它会继续解析载荷中最内层的实际 RTMP 数据,并为它打上 rtmp 协议的标签。

在 wireshark 过滤 rtmpt 后,点击一条数据,可以看到协议栈

go 复制代码
Frame (物理层帧)
Ethernet II (数据链路层)
Internet Protocol Version 4 (网络层 IP)
Transmission Control Protocol (传输层 TCP)
Real Time Messaging Protocol  <- 实时消息协议
可以看到 RTMP 的 Header 和 Body

小结

在本篇文章中,了解到 RTMPT 是一种封装技术,是 RTMP 协议的一种传输方式,当抓包 RTMP 流时,过滤 RTMPT 展示的 RTMP 信息更加全面。

相关推荐
Johnstons1 天前
Wireshark ExpertInfo是什么?一文讲透异常分级、适用场景、和传统抓包阅读的区别与排查标准
网络·测试工具·wireshark·es
郭源潮12 天前
从8k嘈杂到16k清晰,我是如何使用RNNoise+libresample构建音频降噪管道的?
c++·音视频·实时音视频
YWamy2 天前
音视频SDK赋能智能硬件:实时RTC技术的应用难点与落地实践
音视频·实时音视频·智能硬件
独角鲸网络安全实验室2 天前
2026微信小程序抓包全解析:从实操落地到合规风控,解锁前端调试新范式
前端·微信小程序·小程序·抓包·系统代理绕过·https证书严格校验·进程隔离
ZEGO即构5 天前
AI教育重构教与学:RTC+AI如何赋能全学段教学场景?
人工智能·实时音视频·ai教育
metaRTC5 天前
metaRTC8 成功适配 RTOS:开启 MCU/嵌入式实时音视频新时代
单片机·嵌入式硬件·webrtc·实时音视频·rtos
Filwaod5 天前
Charles的配置
抓包·charles·andorid
LlNingyu6 天前
简单流量分析,串通Wireshark基本使用
网络·wireshark·流量分析
Johnstons6 天前
网络故障定位工具怎么搭配:Wireshark、tcpdump、监控平台各自该在什么时候上场?
数据分析·wireshark·php·es·tcpdump·网络故障定位工具搭配与选型
byte轻骑兵7 天前
【LE Audio】BASS精讲[3]: 从服务声明到行为逻辑 解锁广播音频接收核心
音视频·实时音视频·le audio·低功耗音频·蓝牙通话