2014-11-22 09:58:02 +00:00
|
|
|
/*
|
|
|
|
The MIT License (MIT)
|
|
|
|
|
|
|
|
Copyright (c) 2013-2014 winlin
|
|
|
|
|
|
|
|
Permission is hereby granted, free of charge, to any person obtaining a copy of
|
|
|
|
this software and associated documentation files (the "Software"), to deal in
|
|
|
|
the Software without restriction, including without limitation the rights to
|
|
|
|
use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
|
|
|
|
the Software, and to permit persons to whom the Software is furnished to do so,
|
|
|
|
subject to the following conditions:
|
|
|
|
|
|
|
|
The above copyright notice and this permission notice shall be included in all
|
|
|
|
copies or substantial portions of the Software.
|
|
|
|
|
|
|
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
|
|
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
|
|
|
|
FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
|
|
|
|
COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
|
|
|
|
IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
|
|
|
CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef SRS_APP_RECV_THREAD_HPP
|
|
|
|
#define SRS_APP_RECV_THREAD_HPP
|
|
|
|
|
|
|
|
/*
|
|
|
|
#include <srs_app_recv_thread.hpp>
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <srs_core.hpp>
|
|
|
|
|
|
|
|
#include <vector>
|
|
|
|
|
|
|
|
#include <srs_app_thread.hpp>
|
2014-12-03 11:27:27 +00:00
|
|
|
#include <srs_protocol_buffer.hpp>
|
2014-12-04 05:43:55 +00:00
|
|
|
#include <srs_core_performance.hpp>
|
2014-12-04 10:21:04 +00:00
|
|
|
#include <srs_app_reload.hpp>
|
2014-11-22 09:58:02 +00:00
|
|
|
|
|
|
|
class SrsRtmpServer;
|
2014-12-05 15:03:52 +00:00
|
|
|
class SrsCommonMessage;
|
2014-12-01 15:38:51 +00:00
|
|
|
class SrsRtmpConn;
|
|
|
|
class SrsSource;
|
2014-12-04 10:21:04 +00:00
|
|
|
class SrsRequest;
|
2014-11-22 09:58:02 +00:00
|
|
|
|
2014-12-01 14:39:22 +00:00
|
|
|
/**
|
|
|
|
* for the recv thread to handle the message.
|
|
|
|
*/
|
|
|
|
class ISrsMessageHandler
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
ISrsMessageHandler();
|
|
|
|
virtual ~ISrsMessageHandler();
|
|
|
|
public:
|
|
|
|
/**
|
2014-12-02 07:21:08 +00:00
|
|
|
* whether the handler can handle,
|
|
|
|
* for example, when queue recv handler got an message,
|
|
|
|
* it wait the user to process it, then the recv thread
|
|
|
|
* never recv message util the handler is ok.
|
|
|
|
*/
|
2014-12-01 14:39:22 +00:00
|
|
|
virtual bool can_handle() = 0;
|
|
|
|
/**
|
2014-12-02 07:21:08 +00:00
|
|
|
* process the received message.
|
|
|
|
*/
|
2014-12-05 15:03:52 +00:00
|
|
|
virtual int handle(SrsCommonMessage* msg) = 0;
|
2014-12-02 07:21:08 +00:00
|
|
|
/**
|
|
|
|
* when recv message error.
|
|
|
|
*/
|
|
|
|
virtual void on_recv_error(int ret) = 0;
|
2014-12-02 09:16:20 +00:00
|
|
|
/**
|
|
|
|
* when thread start or stop,
|
|
|
|
* for example, the message handler can set whether auto response.
|
|
|
|
*/
|
|
|
|
virtual void on_thread_start() = 0;
|
|
|
|
virtual void on_thread_stop() = 0;
|
2014-12-01 14:39:22 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* the recv thread, use message handler to handle each received message.
|
|
|
|
*/
|
|
|
|
class SrsRecvThread : public ISrsThreadHandler
|
|
|
|
{
|
|
|
|
protected:
|
|
|
|
SrsThread* trd;
|
|
|
|
ISrsMessageHandler* handler;
|
|
|
|
SrsRtmpServer* rtmp;
|
2014-12-01 14:45:45 +00:00
|
|
|
int timeout;
|
2014-12-01 14:39:22 +00:00
|
|
|
public:
|
2014-12-01 14:45:45 +00:00
|
|
|
SrsRecvThread(ISrsMessageHandler* msg_handler, SrsRtmpServer* rtmp_sdk, int timeout_ms);
|
2014-12-01 14:39:22 +00:00
|
|
|
virtual ~SrsRecvThread();
|
|
|
|
public:
|
|
|
|
virtual int start();
|
|
|
|
virtual void stop();
|
|
|
|
virtual int cycle();
|
2014-12-01 15:38:51 +00:00
|
|
|
virtual void stop_loop();
|
2014-12-01 14:39:22 +00:00
|
|
|
public:
|
|
|
|
virtual void on_thread_start();
|
|
|
|
virtual void on_thread_stop();
|
|
|
|
};
|
|
|
|
|
2014-11-22 09:58:02 +00:00
|
|
|
/**
|
|
|
|
* the recv thread used to replace the timeout recv,
|
|
|
|
* which hurt performance for the epoll_ctrl is frequently used.
|
|
|
|
* @see: SrsRtmpConn::playing
|
|
|
|
* @see: https://github.com/winlinvip/simple-rtmp-server/issues/217
|
|
|
|
*/
|
2014-12-01 15:38:51 +00:00
|
|
|
class SrsQueueRecvThread : public ISrsMessageHandler
|
2014-11-22 09:58:02 +00:00
|
|
|
{
|
|
|
|
private:
|
2014-12-05 15:03:52 +00:00
|
|
|
std::vector<SrsCommonMessage*> queue;
|
2014-12-01 14:53:03 +00:00
|
|
|
SrsRecvThread trd;
|
2014-12-02 09:16:20 +00:00
|
|
|
SrsRtmpServer* rtmp;
|
2014-12-02 07:21:08 +00:00
|
|
|
// the recv thread error code.
|
|
|
|
int recv_error_code;
|
2014-11-22 09:58:02 +00:00
|
|
|
public:
|
2014-12-01 14:45:45 +00:00
|
|
|
SrsQueueRecvThread(SrsRtmpServer* rtmp_sdk, int timeout_ms);
|
2014-12-01 14:23:05 +00:00
|
|
|
virtual ~SrsQueueRecvThread();
|
2014-12-01 14:53:03 +00:00
|
|
|
public:
|
|
|
|
virtual int start();
|
|
|
|
virtual void stop();
|
2014-11-22 09:58:02 +00:00
|
|
|
public:
|
|
|
|
virtual bool empty();
|
2014-11-22 11:15:40 +00:00
|
|
|
virtual int size();
|
2014-12-05 15:03:52 +00:00
|
|
|
virtual SrsCommonMessage* pump();
|
2014-12-02 07:21:08 +00:00
|
|
|
virtual int error_code();
|
2014-11-22 09:58:02 +00:00
|
|
|
public:
|
2014-12-01 14:39:22 +00:00
|
|
|
virtual bool can_handle();
|
2014-12-05 15:03:52 +00:00
|
|
|
virtual int handle(SrsCommonMessage* msg);
|
2014-12-02 07:21:08 +00:00
|
|
|
virtual void on_recv_error(int ret);
|
2014-12-02 09:16:20 +00:00
|
|
|
public:
|
|
|
|
virtual void on_thread_start();
|
|
|
|
virtual void on_thread_stop();
|
2014-11-22 09:58:02 +00:00
|
|
|
};
|
|
|
|
|
2014-12-01 15:38:51 +00:00
|
|
|
/**
|
2014-12-02 11:22:06 +00:00
|
|
|
* the publish recv thread got message and callback the source method to process message.
|
2014-12-01 15:38:51 +00:00
|
|
|
* @see: https://github.com/winlinvip/simple-rtmp-server/issues/237
|
2014-12-02 11:22:06 +00:00
|
|
|
*/
|
2014-12-04 05:43:55 +00:00
|
|
|
class SrsPublishRecvThread : virtual public ISrsMessageHandler
|
|
|
|
#ifdef SRS_PERF_MERGED_READ
|
|
|
|
, virtual public IMergeReadHandler
|
|
|
|
#endif
|
2014-12-04 10:21:04 +00:00
|
|
|
, virtual public ISrsReloadHandler
|
2014-12-01 15:38:51 +00:00
|
|
|
{
|
|
|
|
private:
|
|
|
|
SrsRecvThread trd;
|
2014-12-02 09:16:20 +00:00
|
|
|
SrsRtmpServer* rtmp;
|
2014-12-04 10:21:04 +00:00
|
|
|
SrsRequest* req;
|
2014-12-01 15:38:51 +00:00
|
|
|
// the msgs already got.
|
|
|
|
int64_t _nb_msgs;
|
2014-12-03 14:39:25 +00:00
|
|
|
// for mr(merged read),
|
|
|
|
// @see https://github.com/winlinvip/simple-rtmp-server/issues/241
|
2014-12-04 10:21:04 +00:00
|
|
|
bool mr;
|
2014-12-03 14:39:25 +00:00
|
|
|
int mr_fd;
|
2014-12-04 10:21:04 +00:00
|
|
|
int mr_sleep;
|
2014-12-01 15:38:51 +00:00
|
|
|
// the recv thread error code.
|
|
|
|
int recv_error_code;
|
|
|
|
SrsRtmpConn* _conn;
|
2014-12-03 04:08:29 +00:00
|
|
|
// the params for conn callback.
|
2014-12-01 15:38:51 +00:00
|
|
|
SrsSource* _source;
|
|
|
|
bool _is_fmle;
|
|
|
|
bool _is_edge;
|
2014-12-03 04:08:29 +00:00
|
|
|
// the error timeout cond
|
|
|
|
// @see https://github.com/winlinvip/simple-rtmp-server/issues/244
|
|
|
|
st_cond_t error;
|
2014-12-01 15:38:51 +00:00
|
|
|
public:
|
2014-12-04 10:21:04 +00:00
|
|
|
SrsPublishRecvThread(SrsRtmpServer* rtmp_sdk,
|
|
|
|
SrsRequest* _req, int mr_sock_fd, int timeout_ms,
|
2014-12-01 15:38:51 +00:00
|
|
|
SrsRtmpConn* conn, SrsSource* source, bool is_fmle, bool is_edge);
|
|
|
|
virtual ~SrsPublishRecvThread();
|
|
|
|
public:
|
2014-12-03 04:08:29 +00:00
|
|
|
/**
|
|
|
|
* wait for error for some timeout.
|
|
|
|
*/
|
|
|
|
virtual int wait(int timeout_ms);
|
2014-12-01 15:38:51 +00:00
|
|
|
virtual int64_t nb_msgs();
|
|
|
|
virtual int error_code();
|
|
|
|
public:
|
|
|
|
virtual int start();
|
|
|
|
virtual void stop();
|
2014-12-03 11:27:27 +00:00
|
|
|
virtual void on_thread_start();
|
|
|
|
virtual void on_thread_stop();
|
|
|
|
// interface ISrsMessageHandler
|
2014-12-01 15:38:51 +00:00
|
|
|
public:
|
|
|
|
virtual bool can_handle();
|
2014-12-05 15:03:52 +00:00
|
|
|
virtual int handle(SrsCommonMessage* msg);
|
2014-12-02 07:21:08 +00:00
|
|
|
virtual void on_recv_error(int ret);
|
2014-12-03 11:27:27 +00:00
|
|
|
// interface IMergeReadHandler
|
2014-12-02 09:16:20 +00:00
|
|
|
public:
|
2014-12-04 05:43:55 +00:00
|
|
|
#ifdef SRS_PERF_MERGED_READ
|
2014-12-03 14:39:25 +00:00
|
|
|
virtual void on_read(ssize_t nread);
|
2014-12-04 05:43:55 +00:00
|
|
|
#endif
|
2014-12-04 10:21:04 +00:00
|
|
|
// interface ISrsReloadHandler
|
|
|
|
public:
|
|
|
|
virtual int on_reload_vhost_mr(std::string vhost);
|
|
|
|
private:
|
2014-12-04 13:50:23 +00:00
|
|
|
virtual void set_socket_buffer(int sleep_ms);
|
2014-12-01 15:38:51 +00:00
|
|
|
};
|
|
|
|
|
2014-11-22 09:58:02 +00:00
|
|
|
#endif
|
|
|
|
|