WebRTC视频可与其他托管网站一起使用,但不适用于Heroku

如何解决WebRTC视频可与其他托管网站一起使用,但不适用于Heroku

美好的一天!

我有一个带有Socket.io的WebRTC应用程序用于发信号。我有一个通过测试https://test.webrtc.org/

的STUN / TURN配置

到目前为止,我的应用程序的WebRTC部分已在以下位置进行了多次测试:

  • 本地主机,同一台计算机,多个标签页:一切正常,视频和音频
  • 局域网:一切正常,视频和音频
  • Firebase,不同的公共IP地址:一切正常,视频和音频
  • Heroku,不同的公共IP地址: ICE失败,或TURN错误

确切的错误消息是:

“ ICE失败,您的TURN服务器似乎已损坏”

在其他平台上,它可以工作,不需要TURN服务器,但是在完全失败的Heroku上就不能使用。

这是为什么? Heroku是否在做一些干扰WebRTC连接初始化的事情? Socket.io正常运行,并且服务器上没有错误,因此问题最有可能是建立对等连接。

更新:

这是来自WebRTC连接失败的日志。如您所见,它提供了一个报价,一个答案以及候选对象,但我不知道为什么仍然存在“ ICE连接失败”错误

"2020-10-07T10:15:52.024Z create":"([{"iceServers":[{"urls":"stun:stun.l.google.com:19302"},{"urls":"stun:global.stun.twilio.com:3478"},{"urls":"stun:stun1.l.google.com:19302"}],"sdpSemantics":"unified-plan"}])"
"2020-10-07T10:15:52.025Z - get _peerConnectionId":"{}"
"2020-10-07T10:15:52.029Z onnegotiationneeded":"({})"
"2020-10-07T10:15:52.066Z onsignalingstatechange":"("have-local-offer")"
"2020-10-07T10:15:52.067Z - get signalingState":""have-local-offer""
"2020-10-07T10:15:52.068Z - get signalingState":""have-local-offer""
"2020-10-07T10:15:52.068Z - get signalingState (1)":""have-local-offer""
"2020-10-07T10:15:52.083Z onicegatheringstatechange":"("gathering")"
"2020-10-07T10:15:52.083Z - get iceConnectionState":""new""
"2020-10-07T10:15:52.083Z - get iceGatheringState":""gathering""
"2020-10-07T10:15:52.083Z onicecandidate":"({"candidate":"candidate:0 1 UDP 2122187007 192.168.254.103 48433 typ host","sdpMid":"0","sdpMLineIndex":0,"usernameFragment":"b5a93693"})"
"2020-10-07T10:15:52.084Z onicecandidate":"({"candidate":"candidate:4 1 UDP 2122252543 2001:fd8:3292:7e8a:372b:ff13:dcc:d459 52481 typ host","usernameFragment":"b5a93693"})"
"2020-10-07T10:15:52.084Z onicecandidate (1)":"({"candidate":"candidate:8 1 TCP 2105458943 192.168.254.103 9 typ host tcptype active","usernameFragment":"b5a93693"})"
"2020-10-07T10:15:52.084Z onicecandidate (2)":"({"candidate":"candidate:9 1 TCP 2105524479 2001:fd8:3292:7e8a:372b:ff13:dcc:d459 9 typ host tcptype active","usernameFragment":"b5a93693"})"
"2020-10-07T10:15:52.125Z onicecandidate":"({"candidate":"candidate:1 1 UDP 1685987327 180.190.42.104 58922 typ srflx raddr 192.168.254.103 rport 48433","usernameFragment":"b5a93693"})"
"2020-10-07T10:15:52.157Z onicecandidate":"({"candidate":"candidate:2 1 UDP 1685987071 180.190.42.104 58923 typ srflx raddr 192.168.254.103 rport 48433","usernameFragment":"b5a93693"})"
"2020-10-07T10:15:52.270Z onicecandidate":"({"candidate":"candidate:3 1 UDP 1685986815 180.190.42.104 58924 typ srflx raddr 192.168.254.103 rport 48433","usernameFragment":"b5a93693"})"
"2020-10-07T10:15:52.405Z onicecandidate":"({"candidate":"","usernameFragment":"b5a93693"})"
"2020-10-07T10:15:52.406Z onicegatheringstatechange":"("complete")"
"2020-10-07T10:15:52.406Z - get iceConnectionState":""new""
"2020-10-07T10:15:52.407Z - get iceGatheringState":""complete""
"2020-10-07T10:15:52.407Z onicecandidate":"({})"
"2020-10-07T10:15:52.410Z - get localDescription":"{"type":"offer","sdp":"v=0\r\no=mozilla...THIS_IS_SDPARTA-81.0.1 6937478949161186100 0 IN IP4 0.0.0.0\r\ns=-\r\nt=0 0\r\na=sendrecv\r\na=fingerprint:sha-256 10:C8:69:1A:90:BA:59:81:85:97:53:D1:DD:9C:3A:85:E5:EC:F5:99:05:C7:39:B4:5F:1F:0C:FD:BD:A3:5C:F2\r\na=group:BUNDLE 0\r\na=msid-semantic:WMS *\r\nm=application 58922 UDP/DTLS/SCTP webrtc-datachannel\r\nc=IN IP4 180.190.42.104\r\na=candidate:0 1 UDP 2122187007 192.168.254.103 48433 typ host\r\na=candidate:4 1 UDP 2122252543 2001:fd8:3292:7e8a:372b:ff13:dcc:d459 52481 typ host\r\na=candidate:8 1 TCP 2105458943 192.168.254.103 9 typ host tcptype active\r\na=candidate:9 1 TCP 2105524479 2001:fd8:3292:7e8a:372b:ff13:dcc:d459 9 typ host tcptype active\r\na=candidate:1 1 UDP 1685987327 180.190.42.104 58922 typ srflx raddr 192.168.254.103 rport 48433\r\na=candidate:2 1 UDP 1685987071 180.190.42.104 58923 typ srflx raddr 192.168.254.103 rport 48433\r\na=candidate:3 1 UDP 1685986815 180.190.42.104 58924 typ srflx raddr 192.168.254.103 rport 48433\r\na=sendrecv\r\na=end-of-candidates\r\na=ice-pwd:421e15dcbf777c9168d76225d6b88a25\r\na=ice-ufrag:b5a93693\r\na=mid:0\r\na=setup:actpass\r\na=sctp-port:5000\r\na=max-message-size:1073741823\r\n"}"
"2020-10-07T10:15:59.806Z onsignalingstatechange":"("stable")"
"2020-10-07T10:15:59.807Z - get signalingState":""stable""
"2020-10-07T10:15:59.807Z - get signalingState (1)":""stable""
"2020-10-07T10:15:59.808Z - get signalingState":""stable""
"2020-10-07T10:15:59.809Z - get remoteDescription":"{"type":"answer","sdp":"v=0\r\no=- 808825067375462440 2 IN IP4 127.0.0.1\r\ns=-\r\nt=0 0\r\na=sendrecv\r\na=group:BUNDLE 0\r\na=msid-semantic:WMS\r\nm=application 60687 UDP/DTLS/SCTP webrtc-datachannel\r\nc=IN IP4 130.105.206.24\r\nb=AS:30\r\na=candidate:1434301788 1 udp 2122260223 192.168.0.10 60687 typ host generation 0 network-id 1 network-cost 10\r\na=candidate:2741881992 1 udp 1686052607 130.105.206.24 60687 typ srflx raddr 192.168.0.10 rport 60687 generation 0 network-id 1 network-cost 10\r\na=candidate:469649836 1 tcp 1518280447 192.168.0.10 9 typ host tcptype active generation 0 network-id 1 network-cost 10\r\na=sendrecv\r\na=fingerprint:sha-256 9D:92:A5:1E:AA:7B:B2:4C:E0:5E:05:1B:18:E4:07:49:24:99:DE:8A:68:B1:F9:D3:99:81:53:AB:E3:C4:D5:18\r\na=ice-pwd:gLoMECMjqHsVB5mjiA75kWBq\r\na=ice-ufrag:6Doj\r\na=mid:0\r\na=setup:active\r\na=sctp-port:5000\r\na=max-message-size:262144\r\n"}"
"2020-10-07T10:15:59.811Z oniceconnectionstatechange":"("checking")"
"2020-10-07T10:15:59.811Z - get iceConnectionState":""checking""
"2020-10-07T10:15:59.811Z - get iceGatheringState":""complete""
"2020-10-07T10:16:10.928Z oniceconnectionstatechange":"("failed")"
"2020-10-07T10:16:10.928Z - get iceConnectionState":""failed""
"2020-10-07T10:16:10.929Z - get iceGatheringState":""complete""
}

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


使用本地python环境可以成功执行 import pandas as pd import matplotlib.pyplot as plt # 设置字体 plt.rcParams['font.sans-serif'] = ['SimHei'] # 能正确显示负号 p
错误1:Request method ‘DELETE‘ not supported 错误还原:controller层有一个接口,访问该接口时报错:Request method ‘DELETE‘ not supported 错误原因:没有接收到前端传入的参数,修改为如下 参考 错误2:cannot r
错误1:启动docker镜像时报错:Error response from daemon: driver failed programming external connectivity on endpoint quirky_allen 解决方法:重启docker -> systemctl r
错误1:private field ‘xxx‘ is never assigned 按Altʾnter快捷键,选择第2项 参考:https://blog.csdn.net/shi_hong_fei_hei/article/details/88814070 错误2:启动时报错,不能找到主启动类 #
报错如下,通过源不能下载,最后警告pip需升级版本 Requirement already satisfied: pip in c:\users\ychen\appdata\local\programs\python\python310\lib\site-packages (22.0.4) Coll
错误1:maven打包报错 错误还原:使用maven打包项目时报错如下 [ERROR] Failed to execute goal org.apache.maven.plugins:maven-resources-plugin:3.2.0:resources (default-resources)
错误1:服务调用时报错 服务消费者模块assess通过openFeign调用服务提供者模块hires 如下为服务提供者模块hires的控制层接口 @RestController @RequestMapping("/hires") public class FeignControl
错误1:运行项目后报如下错误 解决方案 报错2:Failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:3.8.1:compile (default-compile) on project sb 解决方案:在pom.
参考 错误原因 过滤器或拦截器在生效时,redisTemplate还没有注入 解决方案:在注入容器时就生效 @Component //项目运行时就注入Spring容器 public class RedisBean { @Resource private RedisTemplate<String
使用vite构建项目报错 C:\Users\ychen\work>npm init @vitejs/app @vitejs/create-app is deprecated, use npm init vite instead C:\Users\ychen\AppData\Local\npm-
参考1 参考2 解决方案 # 点击安装源 协议选择 http:// 路径填写 mirrors.aliyun.com/centos/8.3.2011/BaseOS/x86_64/os URL类型 软件库URL 其他路径 # 版本 7 mirrors.aliyun.com/centos/7/os/x86
报错1 [root@slave1 data_mocker]# kafka-console-consumer.sh --bootstrap-server slave1:9092 --topic topic_db [2023-12-19 18:31:12,770] WARN [Consumer clie
错误1 # 重写数据 hive (edu)> insert overwrite table dwd_trade_cart_add_inc > select data.id, > data.user_id, > data.course_id, > date_format(
错误1 hive (edu)> insert into huanhuan values(1,'haoge'); Query ID = root_20240110071417_fe1517ad-3607-41f4-bdcf-d00b98ac443e Total jobs = 1
报错1:执行到如下就不执行了,没有显示Successfully registered new MBean. [root@slave1 bin]# /usr/local/software/flume-1.9.0/bin/flume-ng agent -n a1 -c /usr/local/softwa
虚拟及没有启动任何服务器查看jps会显示jps,如果没有显示任何东西 [root@slave2 ~]# jps 9647 Jps 解决方案 # 进入/tmp查看 [root@slave1 dfs]# cd /tmp [root@slave1 tmp]# ll 总用量 48 drwxr-xr-x. 2
报错1 hive> show databases; OK Failed with exception java.io.IOException:java.lang.RuntimeException: Error in configuring object Time taken: 0.474 se
报错1 [root@localhost ~]# vim -bash: vim: 未找到命令 安装vim yum -y install vim* # 查看是否安装成功 [root@hadoop01 hadoop]# rpm -qa |grep vim vim-X11-7.4.629-8.el7_9.x
修改hadoop配置 vi /usr/local/software/hadoop-2.9.2/etc/hadoop/yarn-site.xml # 添加如下 <configuration> <property> <name>yarn.nodemanager.res