我有1台运行Red5的服务器和大约5-6台运行icecast2的其他服务器作为频道 现在我想使用Red5从icecast2重新流式传输
当用户请求内容时,Red5将知道该内容属于哪个icecast2服务器,并且它将连接到更正的服务器以获取媒体并重新流式传输给用户
我的问题是,通常情况下,Red5会传输静态内容,但在我的情况下,我必须使用指定的速度和带宽从icecast2重新流式传输动态内容吗?那可能吗? 我有什么例子可以看到这个想法吗?
答案 0 :(得分:1)
要将一台服务器重新唤醒到另一台服务器,请使用StreamingProxy
import java.util.HashMap;
import java.util.Map;
import org.red5.server.adapter.MultiThreadedApplicationAdapter;
import org.red5.server.api.IBasicScope;
import org.red5.server.api.IConnection;
import org.red5.server.api.IScope;
import org.red5.server.api.stream.IBroadcastStream;
import org.red5.server.stream.IBroadcastScope;
import org.red5.server.stream.StreamingProxy;
public class Application extends MultiThreadedApplicationAdapter implements IStreamListener {
private Map<String, StreamingProxy> streamingProxyMap = new HashMap<String, StreamingProxy>();
public IBroadcastScope getBroadcastScope(IScope scope, String name) {
IBasicScope basicScope = scope.getBasicScope(IBroadcastScope.TYPE,
name);
if (!(basicScope instanceof IBroadcastScope)) {
return null;
} else {
return (IBroadcastScope) basicScope;
}
}
/** {@inheritDoc} */
@Override
public boolean connect(IConnection conn, IScope scope, Object[] params) {
return true;
}
public void streamBroadcastStart(IBroadcastStream stream)
{
IScope scope = stream.getScope();
IBroadcastScope bsScope = getBroadcastScope(scope, stream.getPublishedName());
StreamingProxy proxy = new StreamingProxy();
proxy.setHost("live.justin.tv");
proxy.setApp("app");
proxy.setPort(1935);
proxy.init();
bsScope.subscribe(proxy, null);
proxy.start("MY_STRING", StreamingProxy.LIVE, null);
streamingProxyMap.put(stream.getPublishedName(), proxy);
stream.addStreamListener(this);
}
public void packetReceived(IBroadcastStream stream, IStreamPacket packet)
{
RTMPMessage m = RTMPMessage.build((IRTMPEvent) packet,packet.getTimestamp());
streamer.pushMessage(null, m);
}
synchronized public void streamBroadcastClose(IBroadcastStream stream) {
StreamingProxy proxy =
streamingProxyMap.get(stream.getPublishedName());
if (proxy != null) {
proxy.stop();
IScope scope = stream.getScope();
IBroadcastScope bsScope = getBroadcastScope(scope, stream.getPublishedName());
if (bsScope != null) {
bsScope.unsubscribe(proxy);
}
}
}
/** {@inheritDoc} */
@Override
public void disconnect(IConnection conn, IScope scope) {
super.disconnect(conn, scope);
}
}