- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
来自 AMI 的 Wowza Streaming Engine 4.0.4 可在此处获取
目前,我需要等待文件转码完成才能再次使用。
我正在查看日志,我看到了以下内容:
INFO session comment 1420436222 client connectionClosed [1420436222] pingtimeout
INFO server comment - onStreamDestroy: 1
INFO server comment - TranscodingSession.shutdown[recorder/_definst_/530d8aa855df0c2d269a5a5853a47a049c52c9d83a2d71d91412373547415]
INFO transcoder decoder-audio-stop 530d8aa855df0c2d269a5a5853a47a049c52c9d83a2d71d91412373547415 -
INFO transcoder encoder-audio-stop 530d8aa855df0c2d269a5a5853a47a049c52c9d83a2d71d91412373547415 {name: "aac"}
然后转码就完成了。并且 .tmp 文件被删除。
我假设“pingtimeout”是由于不活动而发生的自然事件。我不想让客户端坐在那里,直到它自然超时,然后我才能使用转码文件。
有什么方法可以强制关闭来自客户端或服务器的连接,而无需等待“pingtimeout”,以便我可以更快地使用此转码文件?
客户端应该能够告诉服务器“我完成了”,然后服务器应该完成所有转码操作。我可以这样做吗?
我已经从客户端调用了 NetStream.close()
和 NetStream.dispose()
,但这似乎没有帮助。
在客户端我调用NetStream.close()
然后,我调用自定义方法来访问保存文件的服务器端 API。
这是成功尝试的日志:
INFO server comment - LiveStreamPacketizerSanJose.endChunkTS[recorder/_definst_/530d8aa855df0c2d269a5a5853a47a049c52c9d83a2d71d81412696439395]: Add chunk: id:4 a/v/k:251/151/10 duration:10026
INFO server comment - TranscodingSession.close[recorder/_definst_/530d8aa855df0c2d269a5a5853a47a049c52c9d83a2d71d81412696439395]
INFO stream recordstop 530d8aa855df0c2d269a5a5853a47a049c52c9d83a2d71d81412696439395 -
INFO stream unpublish 530d8aa855df0c2d269a5a5853a47a049c52c9d83a2d71d81412696439395 -
INFO server comment - onStreamDestroy: 1
INFO stream destroy 530d8aa855df0c2d269a5a5853a47a049c52c9d83a2d71d81412696439395 -
INFO session disconnect 1958636839 -
INFO server comment - onDisconnect: 1958636839
INFO server comment - TranscodingSession.shutdown[recorder/_definst_/530d8aa855df0c2d269a5a5853a47a049c52c9d83a2d71d81412696439395]
INFO transcoder decoder-audio-stop 530d8aa855df0c2d269a5a5853a47a049c52c9d83a2d71d81412696439395 -
INFO transcoder encoder-audio-stop 530d8aa855df0c2d269a5a5853a47a049c52c9d83a2d71d81412696439395 {name: "aac"}
INFO stream unpublish 530d8aa855df0c2d269a5a5853a47a049c52c9d83a2d71d81412696439395_aac -
INFO server comment - onStreamDestroy: 2
INFO stream destroy 530d8aa855df0c2d269a5a5853a47a049c52c9d83a2d71d81412696439395_aac -
INFO session connect-pending 50.246.217.38 -
INFO server comment - onConnect: 553457279
INFO session connect 50.246.217.38 -
INFO server comment - onConnectAccept: 553457279
INFO server comment - onStreamCreate: 1
INFO stream create - -
INFO stream play 530d8aa855df0c2d269a5a5853a47a049c52c9d83a2d71d81412696439395 -
INFO stream seek 530d8aa855df0c2d269a5a5853a47a049c52c9d83a2d71d81412696439395 -
INFO server comment - Saving thumbnail
INFO server comment - AMFDataList:
[0] saveThumbnail
[1] 3.0
[2] null
[3] 530d8aa855df0c2d269a5a5853a47a049c52c9d83a2d71d81412696439395
[4] {Array: size: 19053, data: [largeblock]}
INFO server comment - Thumbnail saved /usr/local/WowzaStreamingEngine/content/recorder/thumb_530d8aa855df0c2d269a5a5853a47a049c52c9d83a2d71d81412696439395.jpg
INFO stream stop 530d8aa855df0c2d269a5a5853a47a049c52c9d83a2d71d81412696439395 -
INFO server comment - doSave hit
INFO server comment - AMFDataList:
[0] doSave
[1] 4.0
[2] null
[3] 530d8aa855df0c2d269a5a5853a47a049c52c9d83a2d71d81412696439395
INFO server comment - Starting upload
INFO server comment - getting credentials
INFO server comment - attempting to upload 530d8aa855df0c2d269a5a5853a47a049c52c9d83a2d71d81412696439395_aac.mp4 to xxxxxxxxxx
INFO server comment - mp4 upload complete xxxxxxxxxx 530d8aa855df0c2d269a5a5853a47a049c52c9d83a2d71d81412696439395_aac.mp4
INFO server comment - getting credentials
INFO server comment - attempting to upload thumb_530d8aa855df0c2d269a5a5853a47a049c52c9d83a2d71d81412696439395.jpg to xxxxxxxxxx
INFO server comment - thumb upload complete xxxxxxxxxx thumb_530d8aa855df0c2d269a5a5853a47a049c52c9d83a2d71d81412696439395.jpg
INFO server comment - sending info to client rtmp://xxxxxxxxxx.cloudfront.net/cfx/st/530d8aa855df0c2d269a5a58/53a47a049c52c9d83a2d71d8/1412696439395_aac.mp4
INFO server comment - deleting 530d8aa855df0c2d269a5a5853a47a049c52c9d83a2d71d81412696439395
INFO server comment - deleting thumbnail
INFO server comment - deleting mp4 video
INFO server comment - deleting mp4 AAC video
第一行表示一个流。
第二行是转码器关闭,当我停止录制和发布时发生,然后转码器关闭。现在转码后的文件就可以使用了。除非转码器关闭,否则我无法访问转码后的文件。
之后的所有行都是自定义模块内容。
这是失败尝试的日志:
INFO server comment - LiveStreamPacketizerSmoothStreaming.addFragment[recorder/_definst_/530d8aa855df0c2d269a5a5853a47a049c52c9d83a2d71d81412697135485]: Add chunk: type:video id:10 count:15 duration:1007
INFO server comment - TranscodingSession.close[recorder/_definst_/530d8aa855df0c2d269a5a5853a47a049c52c9d83a2d71d81412697135485]
INFO stream recordstop 530d8aa855df0c2d269a5a5853a47a049c52c9d83a2d71d81412697135485 -
INFO stream unpublish 530d8aa855df0c2d269a5a5853a47a049c52c9d83a2d71d81412697135485 -
INFO session connect-pending 50.246.217.38 -
INFO server comment - onConnect: 968481495
INFO session connect 50.246.217.38 -
INFO server comment - onConnectAccept: 968481495
INFO server comment - onStreamCreate: 1
INFO stream create - -
INFO stream play 530d8aa855df0c2d269a5a5853a47a049c52c9d83a2d71d81412697135485 -
INFO stream seek 530d8aa855df0c2d269a5a5853a47a049c52c9d83a2d71d81412697135485 -
INFO server comment - Saving thumbnail
INFO server comment - AMFDataList:
[0] saveThumbnail
[1] 3.0
[2] null
[3] 530d8aa855df0c2d269a5a5853a47a049c52c9d83a2d71d81412697135485
[4] {Array: size: 18915, data: [largeblock]}
INFO server comment - Thumbnail saved /usr/local/WowzaStreamingEngine/content/recorder/thumb_530d8aa855df0c2d269a5a5853a47a049c52c9d83a2d71d81412697135485.jpg
INFO server comment - LiveStreamPacketizerSmoothStreaming.addFragment[recorder/_definst_/530d8aa855df0c2d269a5a5853a47a049c52c9d83a2d71d81412697135485_aac]: Add chunk: type:video id:10 count:15 duration:1007
INFO stream stop 530d8aa855df0c2d269a5a5853a47a049c52c9d83a2d71d81412697135485 -
INFO server comment - doSave hit
INFO server comment - AMFDataList:
[0] doSave
[1] 4.0
[2] null
[3] 530d8aa855df0c2d269a5a5853a47a049c52c9d83a2d71d81412697135485
INFO server comment - Starting upload
INFO server comment - Tmp file exists, waiting
INFO server comment - Tmp file exists, waiting
INFO server comment - Tmp file exists, waiting
INFO server comment - Tmp file exists, waiting
INFO server comment - Tmp file exists, waiting
INFO server comment - Tmp file exists, waiting
INFO server comment - Tmp file exists, waiting
INFO server comment - Tmp file exists, waiting
INFO server comment - Tmp file exists, waiting
INFO server comment - Tmp file exists, waiting
INFO server comment - Tmp file exists, waiting
INFO server comment - Tmp file exists, waiting
INFO server comment - Tmp file exists, waiting
INFO server comment - Tmp file exists, waiting
INFO server comment - Tmp file exists, waiting
INFO server comment - Tmp file exists, waiting
INFO server comment - Tmp file exists, waiting
INFO server comment - Tmp file exists, waiting
INFO server comment - Tmp file exists, waiting
INFO server comment - Tmp file exists, waiting
INFO server comment - Tmp file exists, waiting
INFO server comment - Tmp file exists, waiting
INFO server comment - Tmp file exists, waiting
INFO server comment - Tmp file exists, waiting
INFO server comment - Tmp file exists, waiting
INFO server comment - Tmp file exists, waiting
INFO server comment - LiveStreamPacketizerSmoothStreaming.addFragment[recorder/_definst_/530d8aa855df0c2d269a5a5853a47a049c52c9d83a2d71d81412697135485]: Add chunk: type:video id:10 count:15 duration:1007
INFO server comment - TranscodingSession.close[recorder/_definst_/530d8aa855df0c2d269a5a5853a47a049c52c9d83a2d71d81412697135485]
INFO stream recordstop 530d8aa855df0c2d269a5a5853a47a049c52c9d83a2d71d81412697135485 -
INFO stream unpublish 530d8aa855df0c2d269a5a5853a47a049c52c9d83a2d71d81412697135485 -
INFO server comment - Tmp file exists, waiting
INFO session comment 404091380 client connectionClosed [404091380] pingtimeout
INFO server comment - onStreamDestroy: 1
INFO stream destroy 530d8aa855df0c2d269a5a5853a47a049c52c9d83a2d71d81412697135485 -
INFO server comment - TranscodingSession.shutdown[recorder/_definst_/530d8aa855df0c2d269a5a5853a47a049c52c9d83a2d71d81412697135485]
INFO transcoder decoder-audio-stop 530d8aa855df0c2d269a5a5853a47a049c52c9d83a2d71d81412697135485 -
INFO transcoder encoder-audio-stop 530d8aa855df0c2d269a5a5853a47a049c52c9d83a2d71d81412697135485 {name: "aac"}
INFO session disconnect 404091380 -
INFO server comment - onDisconnect: 404091380
INFO stream unpublish 530d8aa855df0c2d269a5a5853a47a049c52c9d83a2d71d81412697135485_aac -
INFO server comment - onStreamDestroy: 1
INFO stream destroy 530d8aa855df0c2d269a5a5853a47a049c52c9d83a2d71d81412697135485_aac -
INFO server comment - Tmp file exists, waiting
INFO server comment - getting credentials
INFO server comment - attempting to upload 530d8aa855df0c2d269a5a5853a47a049c52c9d83a2d71d81412697135485_aac.mp4 to xxxxxxxxxx
INFO server comment - mp4 upload complete xxxxxxxxxx 530d8aa855df0c2d269a5a5853a47a049c52c9d83a2d71d81412697135485_aac.mp4
INFO server comment - getting credentials
INFO server comment - attempting to upload thumb_530d8aa855df0c2d269a5a5853a47a049c52c9d83a2d71d81412697135485.jpg to xxxxxxxxxx
INFO server comment - thumb upload complete xxxxxxxxxx thumb_530d8aa855df0c2d269a5a5853a47a049c52c9d83a2d71d81412697135485.jpg
INFO server comment - sending info to client rtmp://xxxxxxxxxx.cloudfront.net/cfx/st/530d8aa855df0c2d269a5a58/53a47a049c52c9d83a2d71d8/1412697135485_aac.mp4
INFO server comment - deleting 530d8aa855df0c2d269a5a5853a47a049c52c9d83a2d71d81412697135485
INFO server comment - deleting thumbnail
INFO server comment - deleting mp4 video
INFO server comment - deleting mp4 AAC video
对于这个,你可以看到转码 session 关闭了两次,然后只有当客户端超时时,转码 session 才会关闭
我刚刚在禁用自定义模块的情况下尝试了此操作。同样的事情发生了:这是日志的复制/粘贴:
INFO server comment - LiveStreamPacketizerSmoothStreaming.addFragment[recorder/_definst_/530d8aa855df0c2d269a5a5853a47a049c52c9d83a2d71d81412700435117_aac]: Add chunk: type:audio id:0 count:32 duration:2053
INFO server comment - TranscodingSession.close[recorder/_definst_/530d8aa855df0c2d269a5a5853a47a049c52c9d83a2d71d81412700435117]
INFO stream recordstop 530d8aa855df0c2d269a5a5853a47a049c52c9d83a2d71d81412700435117 -
INFO stream unpublish 530d8aa855df0c2d269a5a5853a47a049c52c9d83a2d71d81412700435117 -
INFO server comment - MediaCasterStreamValidator.init[player/_definst_]: Started
INFO server comment - ServerListenerEC2Variables#ApplicationInstanceNotify.onApplicationInstanceCreate[player/_definst_]: Auto-set application RTSP addresses: internal[bind]:10.213.146.195 external[origin,connection]:54.188.88.9
INFO application app-start _definst_ player/_definst_
INFO session connect-pending 50.246.217.38 -
INFO session connect 50.246.217.38 -
INFO stream create - -
INFO stream play 530d8aa855df0c2d269a5a5853a47a049c52c9d83a2d71d81412700435117 -
INFO stream seek 530d8aa855df0c2d269a5a5853a47a049c52c9d83a2d71d81412700435117 -
WARN server comment - Missing function: saveThumbnail
INFO stream stop 530d8aa855df0c2d269a5a5853a47a049c52c9d83a2d71d81412700435117 -
INFO session comment 1588047012 client connectionClosed [1588047012] pingtimeout
INFO server comment - TranscodingSession.shutdown[recorder/_definst_/530d8aa855df0c2d269a5a5853a47a049c52c9d83a2d71d81412700435117]
INFO transcoder decoder-audio-stop 530d8aa855df0c2d269a5a5853a47a049c52c9d83a2d71d81412700435117 -
INFO transcoder encoder-audio-stop 530d8aa855df0c2d269a5a5853a47a049c52c9d83a2d71d81412700435117 {name: "aac"}
INFO stream destroy 530d8aa855df0c2d269a5a5853a47a049c52c9d83a2d71d81412700435117 -
INFO session disconnect 1588047012 -
INFO stream unpublish 530d8aa855df0c2d269a5a5853a47a049c52c9d83a2d71d81412700435117_aac -
INFO stream destroy 530d8aa855df0c2d269a5a5853a47a049c52c9d83a2d71d81412700435117_aac -
您可以在转码 session 关闭之前看到 ping 超时。
最佳答案
我在 NetStream.publish("null")
和 NetStream.close()
之后添加了 NetConnection.close()
,这修复了问题。
关于java - 转码只有在客户端超时后才完成?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26187645/
从 Redis 获取消息时,onDone:(){print('done')} 从未起作用。 import 'package:dartis/dartis.dart' as redis show PubS
昨天我玩了一些vim脚本,并设法通过循环来对当前输入的内容进行状态栏预测(请参见屏幕截图(灰色+黄色栏))。 问题是,我不记得我是怎么得到的,也找不到我用于该vim魔术的代码片段(我记得它很简单):它
我尝试加载 bash_completion在我的 bash (3.2.25) 中,它不起作用。没有消息等。我在我的 .bashrc 中使用了以下内容 if [ -f ~/.bash_completio
我正在尝试构建一个 bash 完成例程,它将建议命令行标志和合适的标志值。例如在下面 fstcompose 命令我想比赛套路先建议 compose_filter= 标志,然后建议来自 [alt_seq
当我尝试在重定向符号后完成路径时,bash 完成的行为就好像它仍在尝试在重定向之前完成命令的参数一样。 例如: dpkg -l > /med标签 通过在 /med 之后点击 Tab我希望它完成通往 /
我的类中有几个 CAKeyframeAnimation 对象。 他们都以 self 为代表。 在我的animationDidStop函数中,我如何知道调用来自哪里? 是否有任何变量可以传递给 CAKe
我有一个带有 NSDateFormatter 的 NSTextField。格式化程序接受“mm/dd/yy”。 可以自动补全日期吗?因此,用户可以输入“mm”,格式化程序将完成当前月份和年份。 最佳答
有一个解决方案可以使用以下方法完成 NSTextField : - (NSArray *)control:(NSControl *)control textView:(NSTextView *)tex
我正在阅读 Passport 的文档,我注意到 serialize()和 deserialize() done()被调用而不被返回。 但是,当使用 passport.use() 设置新策略时在回调函数
在 ubuntu 11.10 上的 Firefox 8.0 中,尽管 img.complete 为 false,但仍会调用 onload 函数 draw。我设法用 setTimeout hack 解决
假设我有两个与两个并行执行的计算相对应的 future 。我如何等到第一个 future 准备好?理想情况下,我正在寻找类似于Python asyncio's wait且参数为return_when=
我正在寻找一种 Java 7 数据结构,其行为类似于 java.util.Queue,并且还具有“最终项目已被删除”的概念。 例如,应可以表达如下概念: while(!endingQueue.isFi
这是一个简单的问题。 if ($('.dataTablePageList')) { 我想做的是执行一个 if 语句,该语句表示如果具有 dataTablesPageList 类的对象也具有 menu
我用replaceWith批量替换了许多div中的html。替换后,我使用 jTruncate 来截断文本。然而它不起作用,因为在执行时,replaceWith 还没有完成。 我尝试了回调技巧 ( H
有没有办法调用 javascript 表单 submit() 函数或 JQuery $.submit() 函数并确保它完成提交过程?具体来说,在一个表单中,我试图在一个 IFrame 中提交一个表单。
我有以下方法: function animatePortfolio(fadeElement) { fadeElement.children('article').each(function(i
我刚刚开始使用 AndEngine, 我正在像这样移动 Sprite : if(pValueY < 0 && !jumping) { jumping =
我正在使用 asynctask 来执行冗长的操作,例如数据库读取。我想开始一个新 Activity 并在所有异步任务完成后呈现其内容。实现这一目标的最佳方法是什么? 我知道 onPostExecute
我有一个脚本需要命令名称和该命令的参数作为参数。 所以我想编写一个完成函数来完成命令的名称并完成该命令的参数。 所以我可以这样完成命令的名称 if [[ "$COMP_CWORD" == 1 ]];
我的应用程序有一个相当奇怪的行为。我在 BOOT_COMPLETE 之后启动我的应用程序,因此在我启动设备后它是可见的。 GUI 响应迅速,一切正常,直到我调用 finish(),按下按钮时,什么都没
我是一名优秀的程序员,十分优秀!