1
0
Fork 0
mirror of https://github.com/ossrs/srs.git synced 2025-02-14 20:31:56 +00:00

For #464, support config for origin cluster.

This commit is contained in:
winlin 2018-02-14 21:52:40 +08:00
parent db6b8cf914
commit d0fbf44d18
6 changed files with 140 additions and 40 deletions

View file

@ -329,20 +329,21 @@ vhost removed.srs.com {
# vhost for stream cluster for RTMP/FLV
vhost cluster.srs.com {
# stream RTMP/FLV cluster config.
# The config for cluster.
cluster {
# the mode of vhost, local or remote.
# local: vhost is origin vhost, which provides stream source.
# remote: vhost is edge vhost, which pull/push to origin.
# The cluster mode, local or remote.
# local: It's an origin server, serve streams itself.
# remote: It's an edge server, fetch or push stream to origin server.
# default: local
mode remote;
# for edge(remote mode), user must specifies the origin server
# For edge(mode remote), user must specifies the origin server
# format as: <server_name|ip>[:port]
# @remark user can specifies multiple origin for error backup, by space,
# for example, 192.168.1.100:1935 192.168.1.101:1935 192.168.1.102:1935
origin 127.0.0.1:1935 localhost:1935;
# for edge, whether open the token traverse mode,
# For edge(mode remote), whether open the token traverse mode,
# if token traverse on, all connections of edge will forward to origin to check(auth),
# it's very important for the edge to do the token auth.
# the better way is use http callback to do the token auth by the edge,
@ -350,19 +351,24 @@ vhost cluster.srs.com {
# default: off
token_traverse off;
# the vhost to transform for edge,
# For edge(mode remote), the vhost to transform for edge,
# to fetch from the specified vhost at origin,
# if not specified, use the current vhost of edge in origin, the variable [vhost].
# default: [vhost]
vhost same.edge.srs.com;
# when upnode(forward to, edge push to, edge pull from) is srs,
# For edge(mode remote), when upnode(forward to, edge push to, edge pull from) is srs,
# it's strongly recommend to open the debug_srs_upnode,
# when connect to upnode, it will take the debug info,
# for example, the id, source id, pid.
# please see: https://github.com/ossrs/srs/wiki/v1_CN_SrsLog
# default: on
debug_srs_upnode on;
# For origin (mode local) cluster, the co-worker's HTTP APIs.
# This origin will connect to co-workers and communicate with them.
# please read: https://github.com/ossrs/srs/wiki/v3_EN_OriginCluster
coworkers 127.0.0.1:9091 127.0.0.1:9092;
}
}
@ -1782,3 +1788,28 @@ vhost stream.transcode.srs.com {
}
}
}
#############################################################################################
# The origin cluster section
#############################################################################################
http_api {
enabled on;
listen 9090;
}
vhost a.origin.cluster.srs.com {
cluster {
mode local;
coworkers 127.0.0.1:9091;
}
}
http_api {
enabled on;
listen 9091;
}
vhost b.origin.cluster.srs.com {
cluster {
mode local;
coworkers 127.0.0.1:9090;
}
}

View file

@ -0,0 +1,19 @@
# the config for srs origin-origin cluster
# @see https://github.com/ossrs/srs/wiki/v3_EN_OriginCluster
# @see full.conf for detail config.
listen 19350;
max_connections 1000;
daemon off;
srs_log_tank console;
pid ./objs/origin.cluster.serverA.pid;
http_api {
enabled on;
listen 9090;
}
vhost __defaultVhost__ {
cluster {
mode local;
coworkers 127.0.0.1:9091;
}
}

View file

@ -0,0 +1,19 @@
# the config for srs origin-origin cluster
# @see https://github.com/ossrs/srs/wiki/v3_EN_OriginCluster
# @see full.conf for detail config.
listen 19351;
max_connections 1000;
daemon off;
srs_log_tank console;
pid ./objs/origin.cluster.serverB.pid;
http_api {
enabled on;
listen 9091;
}
vhost __defaultVhost__ {
cluster {
mode local;
coworkers 127.0.0.1:9090;
}
}

View file

@ -3726,7 +3726,7 @@ srs_error_t SrsConfig::check_normal_config()
} else if (n == "cluster") {
for (int j = 0; j < (int)conf->directives.size(); j++) {
string m = conf->at(j)->name;
if (m != "mode" && m != "origin" && m != "token_traverse" && m != "vhost" && m != "debug_srs_upnode") {
if (m != "mode" && m != "origin" && m != "token_traverse" && m != "vhost" && m != "debug_srs_upnode" && m != "coworkers") {
return srs_error_new(ERROR_SYSTEM_CONFIG_INVALID, "illegal vhost.cluster.%s of %s", m.c_str(), vhost->arg0().c_str());
}
}
@ -5157,6 +5157,33 @@ string SrsConfig::get_vhost_edge_transform_vhost(string vhost)
return conf->arg0();
}
vector<string> SrsConfig::get_vhost_coworkers(string vhost)
{
vector<string> coworkers;
SrsConfDirective* conf = get_vhost(vhost);
if (!conf) {
return coworkers;
}
conf = conf->get("cluster");
if (!conf) {
return coworkers;
}
conf = conf->get("coworkers");
for (int i = 0; i < (int)conf->directives.size(); i++) {
SrsConfDirective* option = conf->directives[i];
if (!option) {
continue;
}
coworkers.push_back(option->arg0());
}
return coworkers;
}
bool SrsConfig::get_security_enabled(string vhost)
{
static bool DEFAULT = false;

View file

@ -190,7 +190,7 @@ public:
virtual SrsConfDirective* copy();
// @param except the name of sub directive.
virtual SrsConfDirective* copy(std::string except);
// args
// args
public:
/**
* get the args0,1,2, if user want to get more args,
@ -200,7 +200,7 @@ public:
virtual std::string arg1();
virtual std::string arg2();
virtual std::string arg3();
// directives
// directives
public:
/**
* get the directive by index.
@ -224,7 +224,7 @@ public:
* remove the v from sub directives, user must free the v.
*/
virtual void remove(SrsConfDirective* v);
// help utilities
// help utilities
public:
/**
* whether current directive is vhost.
@ -234,7 +234,7 @@ public:
* whether current directive is stream_caster.
*/
virtual bool is_stream_caster();
// parse utilities
// parse utilities
public:
/**
* parse config directive from file buffer.
@ -256,7 +256,7 @@ public:
virtual SrsJsonAny* dumps_arg0_to_integer();
virtual SrsJsonAny* dumps_arg0_to_number();
virtual SrsJsonAny* dumps_arg0_to_boolean();
// private parse.
// private parse.
private:
/**
* the directive parsing type.
@ -297,7 +297,7 @@ private:
*/
class SrsConfig
{
// user command
// user command
private:
/**
* whether srs is run in dolphin mode.
@ -322,7 +322,7 @@ private:
* whether show SRS signature and exit.
*/
bool show_signature;
// global env variables.
// global env variables.
private:
/**
* the user parameters, the argc and argv.
@ -345,7 +345,7 @@ protected:
* the directive root.
*/
SrsConfDirective* root;
// reload section
// reload section
private:
/**
* the reload subscribers, when reload, callback all handlers.
@ -362,7 +362,7 @@ public:
virtual bool is_dolphin();
private:
virtual void set_config_directive(SrsConfDirective* parent, std::string dir, std::string value);
// reload
// reload
public:
/**
* for reload handler to register itself,
@ -564,7 +564,7 @@ public:
* get the cli, the main(argc,argv), program start command.
*/
virtual std::string argv();
// global section
// global section
public:
/**
* get the directive root, corresponding to the config file.
@ -619,7 +619,7 @@ public:
virtual std::string get_work_dir();
// whether use asprocess mode.
virtual bool get_asprocess();
// stream_caster section
// stream_caster section
public:
/**
* get all stream_caster in config file.
@ -649,7 +649,7 @@ public:
* get the max udp port for rtp of stream caster rtsp.
*/
virtual int get_stream_caster_rtp_port_max(SrsConfDirective* conf);
// kafka section.
// kafka section.
public:
/**
* whether the kafka enabled.
@ -663,7 +663,7 @@ public:
* get the kafka topic to use for srs.
*/
virtual std::string get_kafka_topic();
// vhost specified section
// vhost specified section
public:
/**
* get the vhost directive by vhost name.
@ -826,7 +826,7 @@ public:
* get the forward directive of vhost.
*/
virtual SrsConfDirective* get_forwards(std::string vhost);
// http_hooks section
// http_hooks section
private:
/**
* get the http_hooks directive of vhost.
@ -883,7 +883,7 @@ public:
* @return the on_hls_notify callback directive, the args is the url to callback.
*/
virtual SrsConfDirective* get_vhost_on_hls_notify(std::string vhost);
// bwct(bandwidth check tool) section
// bwct(bandwidth check tool) section
public:
/**
* whether bw check enabled for vhost.
@ -908,7 +908,7 @@ public:
* @remark this is used to protect the service bandwidth.
*/
virtual int get_bw_check_limit_kbps(std::string vhost);
// vhost cluster section
// vhost cluster section
public:
/**
* whether vhost is edge mode.
@ -939,7 +939,12 @@ public:
* @see https://github.com/ossrs/srs/issues/372
*/
virtual std::string get_vhost_edge_transform_vhost(std::string vhost);
// vhost security section
/**
* Get the co-workers of origin cluster.
* @see https://github.com/ossrs/srs/wiki/v3_EN_OriginCluster
*/
virtual std::vector<std::string> get_vhost_coworkers(std::string vhost);
// vhost security section
public:
/**
* whether the secrity of vhost enabled.
@ -949,7 +954,7 @@ public:
* get the security rules.
*/
virtual SrsConfDirective* get_security_rules(std::string vhost);
// vhost transcode section
// vhost transcode section
public:
/**
* get the transcode directive of vhost in specified scope.
@ -1070,7 +1075,7 @@ public:
* @remark, we will use some variable, for instance, [vhost] to substitude with vhost.
*/
virtual std::string get_engine_output(SrsConfDirective* conf);
// vhost exec secion
// vhost exec secion
private:
/**
* get the exec directive of vhost.
@ -1111,7 +1116,7 @@ public:
* get the ingest input url.
*/
virtual std::string get_ingest_input_url(SrsConfDirective* conf);
// log section
// log section
public:
/**
* whether log to file.
@ -1134,7 +1139,7 @@ public:
* @remark, /dev/null to disable it.
*/
virtual std::string get_ffmpeg_log_dir();
// The MPEG-DASH section.
// The MPEG-DASH section.
private:
virtual SrsConfDirective* get_dash(std::string vhost);
public:
@ -1150,7 +1155,7 @@ public:
virtual std::string get_dash_path(std::string vhost);
// Get the path for DASH MPD, to generate the MPD file.
virtual std::string get_dash_mpd_file(std::string vhost);
// hls section
// hls section
private:
/**
* get the hls directive of vhost.
@ -1231,7 +1236,7 @@ public:
* that is, to read max bytes of the bytes from the callback, or timeout or error.
*/
virtual int get_vhost_hls_nb_notify(std::string vhost);
// hds section
// hds section
private:
/**
* get the hds directive of vhost.
@ -1255,8 +1260,7 @@ public:
* a window is a set of hds fragments.
*/
virtual double get_hds_window(const std::string &vhost);
// dvr section
// dvr section
private:
/**
* get the dvr directive.
@ -1292,7 +1296,7 @@ public:
* get the time_jitter algorithm for dvr.
*/
virtual int get_dvr_time_jitter(std::string vhost);
// http api section
// http api section
private:
/**
* whether http api enabled
@ -1327,7 +1331,7 @@ public:
* whether allow rpc update.
*/
virtual bool get_raw_api_allow_update();
// http stream section
// http stream section
private:
/**
* whether http stream enabled.
@ -1366,7 +1370,7 @@ public:
* the path on disk for mount root of http vhost.
*/
virtual std::string get_vhost_http_dir(std::string vhost);
// flv live streaming section
// flv live streaming section
public:
/**
* get whether vhost enabled http flv live stream
@ -1381,7 +1385,7 @@ public:
* used to generate the flv stream mount path.
*/
virtual std::string get_vhost_http_remux_mount(std::string vhost);
// http heartbeart section
// http heartbeart section
private:
/**
* get the heartbeat directive.
@ -1408,7 +1412,7 @@ public:
* whether report with summaries of http api: /api/v1/summaries.
*/
virtual bool get_heartbeat_summaries();
// stats section
// stats section
private:
/**
* get the stats directive.

View file

@ -43,7 +43,7 @@
#define RTMP_SIG_SRS_ROLE "cluster"
#define RTMP_SIG_SRS_URL "https://github.com/ossrs/srs"
#define RTMP_SIG_SRS_LICENSE "The MIT License (MIT)"
#define RTMP_SIG_SRS_COPYRIGHT "Copyright (c) 2013-2017 " RTMP_SIG_SRS_KEY "(" RTMP_SIG_SRS_AUTHROS ")"
#define RTMP_SIG_SRS_COPYRIGHT "Copyright (c) 2013-2018 " RTMP_SIG_SRS_KEY "(" RTMP_SIG_SRS_AUTHROS ")"
#define RTMP_SIG_SRS_PRIMARY RTMP_SIG_SRS_KEY "/" VERSION_STABLE_BRANCH
#define RTMP_SIG_SRS_HANDSHAKE RTMP_SIG_SRS_KEY "(" RTMP_SIG_SRS_VERSION ")"
#define RTMP_SIG_SRS_VERSION SRS_XSTR(VERSION_MAJOR) "." SRS_XSTR(VERSION_MINOR) "." SRS_XSTR(VERSION_REVISION)