mirror of
https://github.com/ZLMediaKit/ZLMediaKit.git
synced 2024-11-22 19:00:01 +08:00
完善addStreamPusherProxy相关功能并修复自动删除相关的bug
This commit is contained in:
parent
aa39680c69
commit
752590f804
@ -616,6 +616,11 @@ void installWebApi() {
|
|||||||
float timeout_sec,
|
float timeout_sec,
|
||||||
const function<void(const SockException &ex, const string &key)> &cb) {
|
const function<void(const SockException &ex, const string &key)> &cb) {
|
||||||
auto key = getPusherKey(schema, vhost, app, stream, url);
|
auto key = getPusherKey(schema, vhost, app, stream, url);
|
||||||
|
auto src = MediaSource::find(schema, vhost, app, stream);
|
||||||
|
if (!src) {
|
||||||
|
cb(SockException(Err_other, "can not find the source stream"), key);
|
||||||
|
return;
|
||||||
|
}
|
||||||
lock_guard<recursive_mutex> lck(s_proxyPusherMapMtx);
|
lock_guard<recursive_mutex> lck(s_proxyPusherMapMtx);
|
||||||
if (s_proxyPusherMap.find(key) != s_proxyPusherMap.end()) {
|
if (s_proxyPusherMap.find(key) != s_proxyPusherMap.end()) {
|
||||||
//已经在推流了
|
//已经在推流了
|
||||||
@ -624,7 +629,7 @@ void installWebApi() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
//添加推流代理
|
//添加推流代理
|
||||||
PusherProxy::Ptr pusher(new PusherProxy(schema, vhost, app, stream, retry_count ? retry_count : -1));
|
PusherProxy::Ptr pusher(new PusherProxy(src, retry_count ? retry_count : -1));
|
||||||
s_proxyPusherMap[key] = pusher;
|
s_proxyPusherMap[key] = pusher;
|
||||||
|
|
||||||
//指定RTP over TCP(播放rtsp时有效)
|
//指定RTP over TCP(播放rtsp时有效)
|
||||||
@ -638,18 +643,18 @@ void installWebApi() {
|
|||||||
//开始推流,如果推流失败或者推流中止,将会自动重试若干次,默认一直重试
|
//开始推流,如果推流失败或者推流中止,将会自动重试若干次,默认一直重试
|
||||||
pusher->setPushCallbackOnce([cb, key, url](const SockException &ex) {
|
pusher->setPushCallbackOnce([cb, key, url](const SockException &ex) {
|
||||||
if (ex) {
|
if (ex) {
|
||||||
InfoL << "key: " << key << ", " << "addStreamPusherProxy pusher callback error: " << ex.what();
|
WarnL << "Push " << url << " failed, key: " << key << ", err: " << ex.what();
|
||||||
lock_guard<recursive_mutex> lck(s_proxyMapMtx);
|
lock_guard<recursive_mutex> lck(s_proxyPusherMapMtx);
|
||||||
s_proxyMap.erase(key);
|
s_proxyPusherMap.erase(key);
|
||||||
}
|
}
|
||||||
cb(ex, key);
|
cb(ex, key);
|
||||||
});
|
});
|
||||||
|
|
||||||
//被主动关闭推流
|
//被主动关闭推流
|
||||||
pusher->setOnClose([key, url](const SockException &ex) {
|
pusher->setOnClose([key, url](const SockException &ex) {
|
||||||
InfoL << "key: " << key << ", " << "addStreamPusherProxy close callback error: " << ex.what();
|
WarnL << "Push " << url << " failed, key: " << key << ", err: " << ex.what();
|
||||||
lock_guard<recursive_mutex> lck(s_proxyMapMtx);
|
lock_guard<recursive_mutex> lck(s_proxyPusherMapMtx);
|
||||||
s_proxyMap.erase(key);
|
s_proxyPusherMap.erase(key);
|
||||||
});
|
});
|
||||||
pusher->publish(url);
|
pusher->publish(url);
|
||||||
};
|
};
|
||||||
@ -659,23 +664,7 @@ void installWebApi() {
|
|||||||
api_regist("/index/api/addStreamPusherProxy", [](API_ARGS_MAP_ASYNC) {
|
api_regist("/index/api/addStreamPusherProxy", [](API_ARGS_MAP_ASYNC) {
|
||||||
CHECK_SECRET();
|
CHECK_SECRET();
|
||||||
CHECK_ARGS("schema", "vhost", "app", "stream", "dst_url");
|
CHECK_ARGS("schema", "vhost", "app", "stream", "dst_url");
|
||||||
|
|
||||||
auto dst_url = allArgs["dst_url"];
|
auto dst_url = allArgs["dst_url"];
|
||||||
auto src_url = allArgs["schema"] + "/" + allArgs["vhost"] + "/" + allArgs["app"] + "/" + allArgs["stream"];
|
|
||||||
auto src = MediaSource::find(allArgs["schema"],
|
|
||||||
allArgs["vhost"],
|
|
||||||
allArgs["app"],
|
|
||||||
allArgs["stream"]);
|
|
||||||
if (!src) {
|
|
||||||
WarnL << "addStreamPusherProxy, can not find source stream:" << src_url;
|
|
||||||
val["code"] = API::NotFound;
|
|
||||||
val["msg"] = "can not find the source stream";
|
|
||||||
invoker(200, headerOut, val.toStyledString());
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
InfoL << "addStreamPusherProxy, find stream: " << src_url << ", push dst url: " << dst_url;
|
|
||||||
|
|
||||||
addStreamPusherProxy(allArgs["schema"],
|
addStreamPusherProxy(allArgs["schema"],
|
||||||
allArgs["vhost"],
|
allArgs["vhost"],
|
||||||
allArgs["app"],
|
allArgs["app"],
|
||||||
@ -688,7 +677,6 @@ void installWebApi() {
|
|||||||
if (ex) {
|
if (ex) {
|
||||||
val["code"] = API::OtherFailed;
|
val["code"] = API::OtherFailed;
|
||||||
val["msg"] = ex.what();
|
val["msg"] = ex.what();
|
||||||
WarnL << "Publish stream failed, dst url is: " << dst_url;
|
|
||||||
} else {
|
} else {
|
||||||
val["data"]["key"] = key;
|
val["data"]["key"] = key;
|
||||||
InfoL << "Publish success, please play with player:" << dst_url;
|
InfoL << "Publish success, please play with player:" << dst_url;
|
||||||
|
@ -14,13 +14,8 @@ using namespace toolkit;
|
|||||||
|
|
||||||
namespace mediakit {
|
namespace mediakit {
|
||||||
|
|
||||||
PusherProxy::PusherProxy(const string& schema, const string &vhost, const string &app, const string &stream,
|
PusherProxy::PusherProxy(const MediaSource::Ptr &src, int retry_count, const EventPoller::Ptr &poller)
|
||||||
int retry_count, const EventPoller::Ptr &poller)
|
: MediaPusher(src, poller){
|
||||||
: MediaPusher(schema,vhost, app, stream, poller){
|
|
||||||
_schema = schema;
|
|
||||||
_vhost = vhost;
|
|
||||||
_app = app;
|
|
||||||
_stream_id = stream;
|
|
||||||
_retry_count = retry_count;
|
_retry_count = retry_count;
|
||||||
_on_close = [](const SockException &) {};
|
_on_close = [](const SockException &) {};
|
||||||
}
|
}
|
||||||
@ -53,7 +48,7 @@ void PusherProxy::publish(const string& dstUrl) {
|
|||||||
if (!err) {
|
if (!err) {
|
||||||
// 推流成功
|
// 推流成功
|
||||||
*piFailedCnt = 0;
|
*piFailedCnt = 0;
|
||||||
InfoL << "pusher publish " << dstUrl << " success";
|
InfoL << "Publish " << dstUrl << " success";
|
||||||
} else if (*piFailedCnt < strongSelf->_retry_count || strongSelf->_retry_count < 0) {
|
} else if (*piFailedCnt < strongSelf->_retry_count || strongSelf->_retry_count < 0) {
|
||||||
// 推流失败,延时重试推送
|
// 推流失败,延时重试推送
|
||||||
strongSelf->rePublish(dstUrl, (*piFailedCnt)++);
|
strongSelf->rePublish(dstUrl, (*piFailedCnt)++);
|
||||||
@ -77,7 +72,6 @@ void PusherProxy::publish(const string& dstUrl) {
|
|||||||
});
|
});
|
||||||
|
|
||||||
MediaPusher::publish(dstUrl);
|
MediaPusher::publish(dstUrl);
|
||||||
_publish_url = dstUrl;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void PusherProxy::rePublish(const string &dstUrl, int iFailedCnt) {
|
void PusherProxy::rePublish(const string &dstUrl, int iFailedCnt) {
|
||||||
|
@ -24,10 +24,8 @@ public:
|
|||||||
typedef std::shared_ptr<PusherProxy> Ptr;
|
typedef std::shared_ptr<PusherProxy> Ptr;
|
||||||
|
|
||||||
// 如果retry_count<0,则一直重试播放;否则重试retry_count次数
|
// 如果retry_count<0,则一直重试播放;否则重试retry_count次数
|
||||||
// 默认一直重试,创建此对象时候,需要外部保证mediaSource存在
|
// 默认一直重试,创建此对象时候,需要外部保证MediaSource存在
|
||||||
PusherProxy(const string& schema, const string &vhost, const string &app, const string &stream,
|
PusherProxy(const MediaSource::Ptr &src, int retry_count = -1, const EventPoller::Ptr &poller = nullptr);
|
||||||
int retry_count = -1, const EventPoller::Ptr &poller = nullptr);
|
|
||||||
|
|
||||||
~PusherProxy() override;
|
~PusherProxy() override;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -54,11 +52,6 @@ private:
|
|||||||
|
|
||||||
private:
|
private:
|
||||||
int _retry_count;
|
int _retry_count;
|
||||||
std::string _schema;
|
|
||||||
string _vhost;
|
|
||||||
string _app;
|
|
||||||
string _stream_id;
|
|
||||||
std::string _publish_url;
|
|
||||||
Timer::Ptr _timer;
|
Timer::Ptr _timer;
|
||||||
|
|
||||||
function<void(const SockException &ex)> _on_close;
|
function<void(const SockException &ex)> _on_close;
|
||||||
|
Loading…
Reference in New Issue
Block a user