【发布时间】:2019-03-22 13:36:16
【问题描述】:
我已逐步按照下面的教程进行操作,但是,我创建的模块似乎没有加载或执行,因为我没有看到任何与 Wowza 流引擎中的 getLogger 调用相关的日志条目。更具体地说,我创建了一个包含新模块的新 Wowza 项目(参见下面的代码)。然后 Eclipse 在安装目录的 lib 文件夹中创建了一个 jar 文件。我已将该模块添加到流服务器上的实时应用程序中。我还编辑了 Application.xml 文件以包含新模块。
为了希望运行我编写的模块,我正在使用 ffmpeg(根据文档 here)将 mp4 文件流式传输到流式引擎(通过实时应用程序),我可以在测试播放器中看到。我的理解是,这将触发模块中的至少一个事件侦听器。但是,日志中似乎没有出现任何内容。我可以看到的与流相关的唯一条目如下所示。
一段时间以来,我一直在尝试调试出了什么问题,所以如果有任何可以解决问题的建议,我将不胜感激。
https://www.wowza.com/docs/How-to-extend-Wowza-Streaming-Engine-using-Java
public class GCStreamModule extends ModuleBase {
public void onAppStart(IApplicationInstance appInstance) {
String fullname = appInstance.getApplication().getName() + "/" + appInstance.getName();
getLogger().info("onAppStart: " + fullname);
}
public void onAppStop(IApplicationInstance appInstance) {
String fullname = appInstance.getApplication().getName() + "/" + appInstance.getName();
getLogger().info("onAppStop: " + fullname);
}
public void onConnect(IClient client, RequestFunction function, AMFDataList params) {
getLogger().info("onConnect: " + client.getClientId());
}
public void onConnectAccept(IClient client) {
getLogger().info("onConnectAccept: " + client.getClientId());
}
public void onConnectReject(IClient client) {
getLogger().info("onConnectReject: " + client.getClientId());
}
public void onDisconnect(IClient client) {
getLogger().info("onDisconnect: " + client.getClientId());
}
public void onStreamCreate(IMediaStream stream) {
getLogger().info("onStreamConnect");
}
public void onMediaStreamCreate(IMediaStream stream){
getLogger().info("onMediaStreamCreate: " + stream.getSrc());
}
}
【问题讨论】:
标签: java ffmpeg video-streaming rtmp wowza