2013-12-22 09:45:08 +00:00
|
|
|
/*
|
|
|
|
The MIT License (MIT)
|
|
|
|
|
2014-01-01 02:37:12 +00:00
|
|
|
Copyright (c) 2013-2014 wenjiegit
|
2014-07-13 04:09:26 +00:00
|
|
|
Copyright (c) 2013-2014 winlin
|
2013-12-22 09:45:08 +00:00
|
|
|
|
|
|
|
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.
|
|
|
|
*/
|
|
|
|
|
2014-03-02 13:49:09 +00:00
|
|
|
#ifndef SRS_APP_BANDWIDTH_HPP
|
|
|
|
#define SRS_APP_BANDWIDTH_HPP
|
2013-12-22 09:45:08 +00:00
|
|
|
|
|
|
|
/*
|
2014-03-02 13:49:09 +00:00
|
|
|
#include <srs_app_bandwidth.hpp>
|
2013-12-22 09:45:08 +00:00
|
|
|
*/
|
|
|
|
#include <srs_core.hpp>
|
|
|
|
|
2014-07-12 07:55:39 +00:00
|
|
|
#include <string>
|
|
|
|
|
2014-03-02 13:49:09 +00:00
|
|
|
#include <srs_app_st.hpp>
|
2014-03-01 02:14:25 +00:00
|
|
|
|
2013-12-22 09:45:08 +00:00
|
|
|
class SrsRequest;
|
2014-03-02 05:54:40 +00:00
|
|
|
class SrsRtmpServer;
|
2014-07-13 02:33:18 +00:00
|
|
|
class SrsKbpsLimit;
|
|
|
|
class ISrsProtocolStatistic;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* bandwidth check/test sample.
|
|
|
|
*/
|
|
|
|
class SrsBandwidthSample
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
/**
|
|
|
|
* the plan, how long to do the test, in ms,
|
|
|
|
* if exceed the duration, abort the test.
|
|
|
|
*/
|
|
|
|
int duration_ms;
|
|
|
|
/**
|
|
|
|
* the plan, interval for each check/test packet, in ms
|
|
|
|
*/
|
|
|
|
int interval_ms;
|
2014-07-13 02:59:26 +00:00
|
|
|
public:
|
2014-07-13 02:33:18 +00:00
|
|
|
/**
|
|
|
|
* the actual test duration, in ms.
|
|
|
|
*/
|
|
|
|
int actual_duration_ms;
|
|
|
|
/**
|
|
|
|
* the actual test bytes
|
|
|
|
*/
|
|
|
|
int bytes;
|
2014-07-13 02:47:27 +00:00
|
|
|
/**
|
|
|
|
* the actual test kbps
|
|
|
|
*/
|
|
|
|
int kbps;
|
2014-07-13 02:33:18 +00:00
|
|
|
public:
|
|
|
|
SrsBandwidthSample();
|
|
|
|
virtual ~SrsBandwidthSample();
|
2014-07-13 02:47:27 +00:00
|
|
|
public:
|
|
|
|
/**
|
2014-07-13 02:59:26 +00:00
|
|
|
* update the bytes and actual duration, then calc the kbps.
|
|
|
|
* @param _bytes update the sample bytes.
|
|
|
|
* @param _duration update the actual duration, in ms.
|
2014-07-13 02:47:27 +00:00
|
|
|
*/
|
2014-07-13 02:59:26 +00:00
|
|
|
virtual void calc_kbps(int _bytes, int _duration);
|
2014-07-13 02:33:18 +00:00
|
|
|
};
|
2013-12-22 09:45:08 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* bandwidth test agent which provides the interfaces for bandwidth check.
|
|
|
|
* 1. if vhost disabled bandwidth check, ignore.
|
|
|
|
* 2. otherwise, check the key, error if verify failed.
|
|
|
|
* 3. check the interval limit, error if bandwidth in the interval window.
|
|
|
|
* 4. check the bandwidth under the max kbps.
|
|
|
|
* 5. send the bandwidth data to client.
|
|
|
|
* bandwidth workflow:
|
|
|
|
* +------------+ +----------+
|
|
|
|
* | Client | | Server |
|
|
|
|
* +-----+------+ +-----+----+
|
|
|
|
* | |
|
|
|
|
* | connect vhost------> | if vhost enable bandwidth,
|
|
|
|
* | <-----result(success) | do bandwidth check.
|
|
|
|
* | |
|
|
|
|
* | <----call(start play) | onSrsBandCheckStartPlayBytes
|
|
|
|
* | result(playing)-----> | onSrsBandCheckStartingPlayBytes
|
|
|
|
* | <-------data(playing) | onSrsBandCheckStartingPlayBytes
|
|
|
|
* | <-----call(stop play) | onSrsBandCheckStopPlayBytes
|
|
|
|
* | result(stopped)-----> | onSrsBandCheckStoppedPlayBytes
|
|
|
|
* | |
|
|
|
|
* | <-call(start publish) | onSrsBandCheckStartPublishBytes
|
|
|
|
* | result(publishing)--> | onSrsBandCheckStartingPublishBytes
|
2014-07-13 11:16:18 +00:00
|
|
|
* | data(publishing)(3)-> | onSrsBandCheckStartingPublishBytes
|
2013-12-22 09:45:08 +00:00
|
|
|
* | <--call(stop publish) | onSrsBandCheckStopPublishBytes
|
|
|
|
* | result(stopped)(1)--> | onSrsBandCheckStoppedPublishBytes
|
|
|
|
* | |
|
|
|
|
* | <--------------report |
|
|
|
|
* | final(2)------------> | finalClientPacket
|
|
|
|
* | <END> |
|
|
|
|
*
|
2014-07-12 12:48:03 +00:00
|
|
|
* 1. when flash client, server never wait the stop publish response,
|
|
|
|
* for the flash client queue is fullfill with other packets.
|
|
|
|
* 2. when flash client, server never wait the final packet,
|
|
|
|
* for the flash client directly close when got report packet.
|
2014-07-13 11:16:18 +00:00
|
|
|
* 3. for linux client, it will send the publish data then send a stop publish,
|
|
|
|
* for the linux client donot know when to stop the publish.
|
|
|
|
* when server got publishing and stop publish, stop publish.
|
2013-12-22 09:45:08 +00:00
|
|
|
*/
|
|
|
|
class SrsBandwidth
|
|
|
|
{
|
|
|
|
private:
|
2014-07-12 07:55:39 +00:00
|
|
|
SrsRequest* _req;
|
|
|
|
SrsRtmpServer* _rtmp;
|
2013-12-22 09:45:08 +00:00
|
|
|
public:
|
|
|
|
SrsBandwidth();
|
|
|
|
virtual ~SrsBandwidth();
|
|
|
|
public:
|
|
|
|
/**
|
2014-07-12 07:55:39 +00:00
|
|
|
* do the bandwidth check.
|
|
|
|
* @param rtmp, server RTMP protocol object, send/recv RTMP packet to/from client.
|
2014-07-13 02:33:18 +00:00
|
|
|
* @param io_stat, the underlayer io statistic, provides send/recv bytes count.
|
2014-07-12 07:55:39 +00:00
|
|
|
* @param req, client request object, specifies the request info from client.
|
|
|
|
* @param local_ip, the ip of server which client connected at
|
2013-12-22 09:45:08 +00:00
|
|
|
*/
|
2014-07-13 02:33:18 +00:00
|
|
|
virtual int bandwidth_check(SrsRtmpServer* rtmp, ISrsProtocolStatistic* io_stat, SrsRequest* req, std::string local_ip);
|
2013-12-22 09:45:08 +00:00
|
|
|
private:
|
|
|
|
/**
|
|
|
|
* used to process band width check from client.
|
2014-07-13 02:33:18 +00:00
|
|
|
* @param limit, the bandwidth limit object, to slowdown if exceed the kbps.
|
2013-12-22 09:45:08 +00:00
|
|
|
*/
|
2014-07-13 02:33:18 +00:00
|
|
|
virtual int do_bandwidth_check(SrsKbpsLimit* limit);
|
2014-07-16 02:19:50 +00:00
|
|
|
// play check/test, downloading bandwidth kbps.
|
|
|
|
private:
|
2014-07-13 02:47:27 +00:00
|
|
|
/**
|
2014-07-16 02:19:50 +00:00
|
|
|
* start play/download bandwidth check/test,
|
|
|
|
* send start-play command to client, client must response starting-play
|
|
|
|
* to start the test.
|
2014-07-13 02:47:27 +00:00
|
|
|
*/
|
2014-07-13 04:06:24 +00:00
|
|
|
virtual int play_start(SrsBandwidthSample* sample, SrsKbpsLimit* limit);
|
2014-07-16 02:19:50 +00:00
|
|
|
/**
|
|
|
|
* do play/download bandwidth check/test,
|
|
|
|
* server send call messages to client in specified time,
|
|
|
|
* calc the time and bytes sent, then we got the kbps.
|
|
|
|
*/
|
2014-07-13 04:06:24 +00:00
|
|
|
virtual int play_checking(SrsBandwidthSample* sample, SrsKbpsLimit* limit);
|
2014-07-16 02:19:50 +00:00
|
|
|
/**
|
|
|
|
* stop play/download bandwidth check/test,
|
|
|
|
* send stop-play command to client, client must response stopped-play
|
|
|
|
* to stop the test.
|
|
|
|
*/
|
2014-07-13 04:06:24 +00:00
|
|
|
virtual int play_stop(SrsBandwidthSample* sample, SrsKbpsLimit* limit);
|
2014-07-16 02:19:50 +00:00
|
|
|
// publish check/test, publishing bandwidth kbps.
|
|
|
|
private:
|
2014-07-13 02:47:27 +00:00
|
|
|
/**
|
2014-07-16 02:19:50 +00:00
|
|
|
* start publish/upload bandwidth check/test,
|
|
|
|
* send start-publish command to client, client must response starting-publish
|
|
|
|
* to start the test.
|
2014-07-13 02:47:27 +00:00
|
|
|
*/
|
2014-07-13 04:06:24 +00:00
|
|
|
virtual int publish_start(SrsBandwidthSample* sample, SrsKbpsLimit* limit);
|
2014-07-16 02:19:50 +00:00
|
|
|
/**
|
|
|
|
* do publish/upload bandwidth check/test,
|
|
|
|
* client send call messages to client in specified time,
|
|
|
|
* server calc the time and bytes received, then we got the kbps.
|
|
|
|
* @remark, for linux client, it will send a stop publish client, server will stop publishing.
|
|
|
|
* then enter the publish-stop stage with client.
|
|
|
|
* @remark, for flash client, it will send many many call messages, that is,
|
|
|
|
* the send queue is fullfill with call messages, so we should never expect the
|
|
|
|
* response message in the publish-stop stage.
|
|
|
|
*/
|
2014-07-13 04:06:24 +00:00
|
|
|
virtual int publish_checking(SrsBandwidthSample* sample, SrsKbpsLimit* limit);
|
2014-07-16 02:19:50 +00:00
|
|
|
/**
|
|
|
|
* stop publish/upload bandwidth check/test,
|
|
|
|
* send stop-publish command to client,
|
|
|
|
* for linux client, always expect a stopped-publish response from client,
|
|
|
|
* for flash client, the sent queue is fullfill with publishing call messages,
|
|
|
|
* so server never expect the stopped-publish from it.
|
|
|
|
*/
|
2014-07-13 04:06:24 +00:00
|
|
|
virtual int publish_stop(SrsBandwidthSample* sample, SrsKbpsLimit* limit);
|
2014-07-16 02:19:50 +00:00
|
|
|
private:
|
2014-07-13 04:06:24 +00:00
|
|
|
/**
|
|
|
|
* report and final packet
|
2014-07-16 02:19:50 +00:00
|
|
|
* report a finish packet, with the bytes/time/kbps bandwidth check/test result,
|
|
|
|
* for linux client, server always expect a final packet from client,
|
|
|
|
* for flash client, the sent queue is fullfill with publishing call messages,
|
|
|
|
* so server never expect the final packet from it.
|
2014-07-13 04:06:24 +00:00
|
|
|
*/
|
|
|
|
virtual int finial(SrsBandwidthSample& play_sample, SrsBandwidthSample& publish_sample, int64_t start_time, int64_t& end_time);
|
2013-12-22 09:45:08 +00:00
|
|
|
};
|
|
|
|
|
2014-08-02 14:18:39 +00:00
|
|
|
#endif
|