RTSP之公网花屏分析

分析结果
1、丢包发生时机:在SendData到tcpdump捕获之间
注:SendData调用sendto发送,sendto未出现返回值小于等于0的情况
2、用tcpdump在设备端捕获eth0、ppp0的结果,发送时从eth0就已经丢包
注:发送时,数据包先到eth0,再通过ppp0发送出去
3、非PPPOE拨号环境,不丢包
4、PPPOE拨号环境,TCP不丢包,UDP丢包
5、TVT的海思、联咏IPC均在发送端时丢包,海康未见明显花屏

综上:在PPPOE拨号环境下,使用UDP协议,数据包发送到网络之前,存在丢包情况,导致花屏。

丢包截图(RTP包的Sequence number不连续,应用层发送Seq是连续的):
在这里插入图片描述

1、TCP模式正常
2、UDP模式花屏
是否丢包:
视频信息:2688*1520 6144 P帧30009,I帧
分片发送时数据包大小:1460(1500 - 20 - 8 -12(RTP头))

封包太大,传送时出现错误的机会大增。
而在Internet上,早期默认的MTU大小是576字节,随着网络的发展,已经变成了1500字节
以太网(Ethernet)是一种局域网技术,使用的默认MTU大小是1500字节;
互联网上的默认MTU大小也是1500字节,与以太网保持一致
由于PPPoE在以太网上多了额外的封装头部,占用了8个字节的空间,因此PPP负载的最大大小被限制在1492字节

丢包分析步骤
接收端丢包
发送端丢包
网卡丢包
应用丢包

1492
实际测试:
ping百度,mtu是1464,原因是使用ping -l 1465 -f www.baidu.com无法ping 通,-f代表不分片
在RTSP UDP中 1464-20-8-12 = 1424
如果576,我们是576-40=534

在这里插入图片描述

$ipRange = '183.15.178.1-255'
$port = 8088

$ipAddresses = 1..255 | ForEach-Object {
    $ip = "183.15.178.$_"
    Test-NetConnection -ComputerName $ip -Port $port -InformationLevel Quiet |
        Where-Object { $_.TcpTestSucceeded } |
        Select-Object -ExpandProperty RemoteAddress
}

$ipAddresses













$ipRange = '183.15.178.190-200'
$port = 8088
$timeout = 1000  # 1(以毫秒为单位)

$ipAddresses = 190..200 | ForEach-Object {
    $ip = "183.15.178.$_"
    $pingResult = Test-NetConnection -ComputerName $ip -InformationLevel Quiet -ErrorAction SilentlyContinue

    if ($pingResult.PingSucceeded) {
        $tcpResult = Test-NetConnection -ComputerName $ip -Port $port -InformationLevel Quiet -ErrorAction SilentlyContinue

        if ($tcpResult -ne $null -and $tcpResult.TcpTestSucceeded) {
            $ip
        }
    }
}

$ipAddresses
  • 14
    点赞
  • 20
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
使用webrtc-streamer实现rtsp公网访问视频的步骤如下: 1. 首先,确保你的服务端已经安装了webrtc-streamer。如果没有安装,你可以请服务端同事帮忙安装,或者自己尝试安装。你可以从webrtc-streamer的git仓库下载压缩包,并解压提取出libs/adapter.min.js和webrtcstreamer.js两个文件。 2. 将adapter.min.js和webrtcstreamer.js文件拷贝到你的项目中。你可以将它们放在public文件夹下,并在index.html中引入这两个文件。 3. 在前端代码中,你需要使用webrtc-streamer提供的API来实现rtsp公网访问视频。具体的实现步骤如下: - 首先,创建一个video元素,用于显示视频流。你可以在HTML中添加一个video标签,并为其指定一个id,例如: ```html <video id="videoElement" autoplay></video> ``` - 在JavaScript代码中,使用webrtc-streamer的API来获取视频流并将其显示在video元素中。你可以使用webrtcstreamer.js中提供的`WebRTCStreamer`对象来实现这一功能。具体的代码如下: ```javascript const videoElement = document.getElementById('videoElement'); const streamer = new WebRTCStreamer(); // 设置视频流的URL,替换成你的rtsp流的URL const streamUrl = 'your_rtsp_stream_url'; streamer.setStreamUrl(streamUrl); // 将视频流绑定到video元素 streamer.attachToElement(videoElement); // 开始播放视频流 streamer.play(); ``` - 替换`your_rtsp_stream_url`为你的rtsp流的URL。确保URL的格式正确,并且可以在公网中访问到。 4. 保存并运行你的前端代码。视频流应该会在video元素中显示出来,并可以在公网中访问到。 请注意,使用webrtc-streamer实现rtsp公网访问视频需要在服务端和前端都进行相应的配置和代码编写。以上步骤仅涉及前端部分的实现,你还需要确保服务端的配置和网络环境的支持。 #### 引用[.reference_title] - *1* *2* *3* [记浏览器使用webrtc-streamer 播放rtsp 流](https://blog.csdn.net/weixin_41838201/article/details/125783057)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值