1
0
Fork 0
mirror of https://github.com/ossrs/srs.git synced 2025-02-15 04:42:04 +00:00
srs/trunk/src/app/srs_app_server.cpp

760 lines
19 KiB
C++
Raw Normal View History

2013-11-23 03:36:07 +00:00
/*
The MIT License (MIT)
Copyright (c) 2013-2014 winlin
2013-11-23 03:36:07 +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.
*/
#include <srs_app_server.hpp>
2013-11-23 03:36:07 +00:00
#include <sys/types.h>
#include <sys/socket.h>
#include <arpa/inet.h>
#include <signal.h>
2014-03-21 07:45:34 +00:00
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
2013-11-23 03:36:07 +00:00
#include <algorithm>
#include <srs_kernel_log.hpp>
#include <srs_kernel_error.hpp>
2014-03-27 04:14:04 +00:00
#include <srs_app_rtmp_conn.hpp>
#include <srs_app_config.hpp>
#include <srs_kernel_utility.hpp>
#include <srs_app_http_api.hpp>
#include <srs_app_http_conn.hpp>
2014-04-02 10:07:34 +00:00
#include <srs_app_http.hpp>
#ifdef SRS_AUTO_INGEST
2014-04-07 01:07:12 +00:00
#include <srs_app_ingest.hpp>
#endif
2013-11-23 03:36:07 +00:00
#define SERVER_LISTEN_BACKLOG 512
2014-04-19 13:23:34 +00:00
// system interval
#define SRS_SYS_CYCLE_INTERVAL 100
// update time interval:
// SRS_SYS_CYCLE_INTERVAL * SRS_SYS_TIME_RESOLUTION_MS_TIMES
#define SRS_SYS_TIME_RESOLUTION_MS_TIMES 3
// update rusage interval:
// SRS_SYS_CYCLE_INTERVAL * SRS_SYS_RUSAGE_RESOLUTION_TIMES
#define SRS_SYS_RUSAGE_RESOLUTION_TIMES 15
// update rusage interval:
// SRS_SYS_CYCLE_INTERVAL * SRS_SYS_CPU_STAT_RESOLUTION_TIMES
#define SRS_SYS_CPU_STAT_RESOLUTION_TIMES 15
2013-11-23 03:36:07 +00:00
2014-04-12 14:16:39 +00:00
SrsListener::SrsListener(SrsServer* server, SrsListenerType type)
2013-11-23 03:36:07 +00:00
{
2014-03-18 03:32:58 +00:00
fd = -1;
stfd = NULL;
2014-04-12 14:16:39 +00:00
_port = 0;
_server = server;
_type = type;
2014-03-18 03:32:58 +00:00
pthread = new SrsThread(this, 0);
2013-11-23 03:36:07 +00:00
}
SrsListener::~SrsListener()
{
2014-03-18 03:32:58 +00:00
srs_close_stfd(stfd);
pthread->stop();
srs_freep(pthread);
// st does not close it sometimes,
// close it manually.
close(fd);
2013-11-23 03:36:07 +00:00
}
2014-04-12 14:16:39 +00:00
SrsListenerType SrsListener::type()
{
return _type;
}
int SrsListener::listen(int port)
2013-11-23 03:36:07 +00:00
{
2014-03-18 03:32:58 +00:00
int ret = ERROR_SUCCESS;
2014-04-12 14:16:39 +00:00
_port = port;
2014-03-18 03:32:58 +00:00
if ((fd = socket(AF_INET, SOCK_STREAM, 0)) == -1) {
2013-11-23 03:36:07 +00:00
ret = ERROR_SOCKET_CREATE;
srs_error("create linux socket error. ret=%d", ret);
return ret;
2014-03-18 03:32:58 +00:00
}
srs_verbose("create linux socket success. fd=%d", fd);
2013-11-23 03:36:07 +00:00
int reuse_socket = 1;
if (setsockopt(fd, SOL_SOCKET, SO_REUSEADDR, &reuse_socket, sizeof(int)) == -1) {
ret = ERROR_SOCKET_SETREUSE;
srs_error("setsockopt reuse-addr error. ret=%d", ret);
return ret;
}
srs_verbose("setsockopt reuse-addr success. fd=%d", fd);
sockaddr_in addr;
addr.sin_family = AF_INET;
2014-04-12 14:16:39 +00:00
addr.sin_port = htons(_port);
2013-11-23 03:36:07 +00:00
addr.sin_addr.s_addr = INADDR_ANY;
if (bind(fd, (const sockaddr*)&addr, sizeof(sockaddr_in)) == -1) {
ret = ERROR_SOCKET_BIND;
srs_error("bind socket error. ret=%d", ret);
return ret;
}
srs_verbose("bind socket success. fd=%d", fd);
if (::listen(fd, SERVER_LISTEN_BACKLOG) == -1) {
ret = ERROR_SOCKET_LISTEN;
srs_error("listen socket error. ret=%d", ret);
return ret;
}
srs_verbose("listen socket success. fd=%d", fd);
if ((stfd = st_netfd_open_socket(fd)) == NULL){
ret = ERROR_ST_OPEN_SOCKET;
srs_error("st_netfd_open_socket open socket failed. ret=%d", ret);
return ret;
}
srs_verbose("st open socket success. fd=%d", fd);
if ((ret = pthread->start()) != ERROR_SUCCESS) {
2013-11-23 03:36:07 +00:00
srs_error("st_thread_create listen thread error. ret=%d", ret);
return ret;
}
srs_verbose("create st listen thread success.");
2014-04-16 08:58:54 +00:00
srs_trace("listen thread cid=%d, current_cid=%d, "
"listen at port=%d, type=%d, fd=%d started success",
pthread->cid(), _srs_context->get_id(), _port, _type, fd);
2014-03-18 03:32:58 +00:00
return ret;
2013-11-23 03:36:07 +00:00
}
2014-04-04 04:18:05 +00:00
void SrsListener::on_thread_start()
2013-11-23 03:36:07 +00:00
{
2014-04-12 14:16:39 +00:00
srs_trace("listen cycle start, port=%d, type=%d, fd=%d", _port, _type, fd);
2013-11-23 03:36:07 +00:00
}
int SrsListener::cycle()
2013-11-23 03:36:07 +00:00
{
2014-03-18 03:32:58 +00:00
int ret = ERROR_SUCCESS;
st_netfd_t client_stfd = st_accept(stfd, NULL, NULL, ST_UTIME_NO_TIMEOUT);
if(client_stfd == NULL){
// ignore error.
srs_warn("ignore accept thread stoppped for accept client error");
return ret;
}
srs_verbose("get a client. fd=%d", st_netfd_fileno(client_stfd));
2014-03-18 03:32:58 +00:00
2014-04-12 14:16:39 +00:00
if ((ret = _server->accept_client(_type, client_stfd)) != ERROR_SUCCESS) {
2014-03-18 03:32:58 +00:00
srs_warn("accept client error. ret=%d", ret);
return ret;
}
return ret;
2013-11-23 03:36:07 +00:00
}
SrsServer::SrsServer()
{
2014-03-18 03:32:58 +00:00
signal_reload = false;
signal_gmc_stop = false;
2014-04-12 12:46:32 +00:00
pid_fd = -1;
2014-03-18 03:32:58 +00:00
// donot new object in constructor,
// for some global instance is not ready now,
// new these objects in initialize instead.
#ifdef SRS_AUTO_HTTP_API
2014-04-07 06:20:03 +00:00
http_api_handler = NULL;
2014-04-02 10:07:34 +00:00
#endif
#ifdef SRS_AUTO_HTTP_SERVER
2014-04-07 06:20:03 +00:00
http_stream_handler = NULL;
2014-04-02 10:07:34 +00:00
#endif
#ifdef SRS_AUTO_INGEST
2014-04-07 06:20:03 +00:00
ingester = NULL;
#endif
2013-11-23 03:36:07 +00:00
}
SrsServer::~SrsServer()
{
2014-03-18 03:32:58 +00:00
_srs_config->unsubscribe(this);
if (true) {
std::vector<SrsConnection*>::iterator it;
for (it = conns.begin(); it != conns.end(); ++it) {
SrsConnection* conn = *it;
srs_freep(conn);
}
conns.clear();
}
2014-04-12 14:16:39 +00:00
close_listeners(SrsListenerRtmpStream);
close_listeners(SrsListenerHttpApi);
close_listeners(SrsListenerHttpStream);
2014-04-02 10:07:34 +00:00
2014-04-12 12:46:32 +00:00
if (pid_fd > 0) {
::close(pid_fd);
pid_fd = -1;
}
#ifdef SRS_AUTO_HTTP_API
2014-04-02 10:07:34 +00:00
srs_freep(http_api_handler);
#endif
#ifdef SRS_AUTO_HTTP_SERVER
2014-04-02 10:07:34 +00:00
srs_freep(http_stream_handler);
#endif
#ifdef SRS_AUTO_INGEST
srs_freep(ingester);
#endif
2013-11-23 03:36:07 +00:00
}
int SrsServer::initialize()
{
2014-03-18 03:32:58 +00:00
int ret = ERROR_SUCCESS;
2014-04-02 10:07:34 +00:00
2014-04-12 12:37:16 +00:00
// for the main objects(server, config, log, context),
// never subscribe handler in constructor,
// instead, subscribe handler in initialize method.
srs_assert(_srs_config);
_srs_config->subscribe(this);
#ifdef SRS_AUTO_HTTP_API
2014-04-07 06:20:03 +00:00
srs_assert(!http_api_handler);
http_api_handler = SrsHttpHandler::create_http_api();
#endif
#ifdef SRS_AUTO_HTTP_SERVER
2014-04-07 06:20:03 +00:00
srs_assert(!http_stream_handler);
http_stream_handler = SrsHttpHandler::create_http_stream();
#endif
#ifdef SRS_AUTO_INGEST
2014-04-07 06:20:03 +00:00
srs_assert(!ingester);
ingester = new SrsIngester();
#endif
#ifdef SRS_AUTO_HTTP_API
2014-04-02 10:07:34 +00:00
if ((ret = http_api_handler->initialize()) != ERROR_SUCCESS) {
return ret;
}
#endif
#ifdef SRS_AUTO_HTTP_SERVER
2014-04-02 10:07:34 +00:00
if ((ret = http_stream_handler->initialize()) != ERROR_SUCCESS) {
return ret;
}
#endif
2014-03-18 03:32:58 +00:00
return ret;
2013-11-23 03:36:07 +00:00
}
2014-03-21 07:45:34 +00:00
int SrsServer::acquire_pid_file()
{
int ret = ERROR_SUCCESS;
std::string pid_file = _srs_config->get_pid_file();
// -rw-r--r--
// 644
int mode = S_IRUSR | S_IWUSR | S_IRGRP | S_IROTH;
int fd;
// open pid file
if ((fd = ::open(pid_file.c_str(), O_WRONLY | O_CREAT, mode)) < 0) {
ret = ERROR_SYSTEM_PID_ACQUIRE;
srs_error("open pid file %s error, ret=%#x", pid_file.c_str(), ret);
return ret;
}
// require write lock
flock lock;
lock.l_type = F_WRLCK; // F_RDLCK, F_WRLCK, F_UNLCK
lock.l_start = 0; // type offset, relative to l_whence
lock.l_whence = SEEK_SET; // SEEK_SET, SEEK_CUR, SEEK_END
lock.l_len = 0;
if (fcntl(fd, F_SETLK, &lock) < 0) {
if(errno == EACCES || errno == EAGAIN) {
ret = ERROR_SYSTEM_PID_ALREADY_RUNNING;
srs_error("srs is already running! ret=%#x", ret);
return ret;
}
ret = ERROR_SYSTEM_PID_LOCK;
srs_error("require lock for file %s error! ret=%#x", pid_file.c_str(), ret);
return ret;
}
// truncate file
if (ftruncate(fd, 0) < 0) {
ret = ERROR_SYSTEM_PID_TRUNCATE_FILE;
srs_error("truncate pid file %s error! ret=%#x", pid_file.c_str(), ret);
return ret;
}
int pid = (int)getpid();
// write the pid
char buf[512];
snprintf(buf, sizeof(buf), "%d", pid);
if (write(fd, buf, strlen(buf)) != (int)strlen(buf)) {
ret = ERROR_SYSTEM_PID_WRITE_FILE;
srs_error("write our pid error! pid=%d file=%s ret=%#x", pid, pid_file.c_str(), ret);
return ret;
}
// auto close when fork child process.
int val;
if ((val = fcntl(fd, F_GETFD, 0)) < 0) {
ret = ERROR_SYSTEM_PID_GET_FILE_INFO;
srs_error("fnctl F_GETFD error! file=%s ret=%#x", pid_file.c_str(), ret);
return ret;
}
val |= FD_CLOEXEC;
if (fcntl(fd, F_SETFD, val) < 0) {
ret = ERROR_SYSTEM_PID_SET_FILE_INFO;
srs_error("fcntl F_SETFD error! file=%s ret=%#x", pid_file.c_str(), ret);
return ret;
}
srs_trace("write pid=%d to %s success!", pid, pid_file.c_str());
2014-04-12 12:46:32 +00:00
pid_fd = fd;
2014-03-21 07:45:34 +00:00
return ret;
}
int SrsServer::initialize_st()
{
int ret = ERROR_SUCCESS;
// use linux epoll.
if (st_set_eventsys(ST_EVENTSYS_ALT) == -1) {
ret = ERROR_ST_SET_EPOLL;
srs_error("st_set_eventsys use linux epoll failed. ret=%d", ret);
return ret;
}
srs_verbose("st_set_eventsys use linux epoll success");
if(st_init() != 0){
ret = ERROR_ST_INITIALIZE;
srs_error("st_init failed. ret=%d", ret);
return ret;
}
srs_verbose("st_init success");
// set current log id.
_srs_context->generate_id();
2014-04-16 08:58:54 +00:00
srs_trace("server main cid=%d", _srs_context->get_id());
return ret;
}
2013-11-23 03:36:07 +00:00
int SrsServer::listen()
{
2014-03-18 03:32:58 +00:00
int ret = ERROR_SUCCESS;
2014-04-12 14:16:39 +00:00
if ((ret = listen_rtmp()) != ERROR_SUCCESS) {
return ret;
2014-03-27 04:14:04 +00:00
}
2014-04-12 14:16:39 +00:00
if ((ret = listen_http_api()) != ERROR_SUCCESS) {
return ret;
2014-03-27 04:14:04 +00:00
}
2014-04-12 14:16:39 +00:00
if ((ret = listen_http_stream()) != ERROR_SUCCESS) {
return ret;
2014-03-18 03:32:58 +00:00
}
return ret;
2013-11-23 03:36:07 +00:00
}
2014-04-07 05:13:57 +00:00
int SrsServer::ingest()
2013-11-23 03:36:07 +00:00
{
2014-03-18 03:32:58 +00:00
int ret = ERROR_SUCCESS;
#ifdef SRS_AUTO_INGEST
if ((ret = ingester->start()) != ERROR_SUCCESS) {
srs_error("start ingest streams failed. ret=%d", ret);
2014-04-07 00:41:32 +00:00
return ret;
}
#endif
2014-04-07 05:13:57 +00:00
return ret;
}
int SrsServer::cycle()
{
int ret = ERROR_SUCCESS;
2014-04-07 00:41:32 +00:00
2014-04-19 13:23:34 +00:00
// find the max loop
int max = srs_max(0, SRS_SYS_TIME_RESOLUTION_MS_TIMES);
max = srs_max(max, SRS_SYS_RUSAGE_RESOLUTION_TIMES);
max = srs_max(max, SRS_SYS_CPU_STAT_RESOLUTION_TIMES);
2014-03-18 03:32:58 +00:00
// the deamon thread, update the time cache
while (true) {
2014-04-19 13:23:34 +00:00
for (int i = 1; i < max + 1; i++) {
st_usleep(SRS_SYS_CYCLE_INTERVAL * 1000);
2014-03-18 03:32:58 +00:00
// for gperf heap checker,
// @see: research/gperftools/heap-checker/heap_checker.cc
// if user interrupt the program, exit to check mem leak.
2014-03-07 04:24:47 +00:00
// but, if gperf, use reload to ensure main return normally,
// because directly exit will cause core-dump.
#ifdef SRS_AUTO_GPERF_MC
2014-04-19 13:23:34 +00:00
if (signal_gmc_stop) {
break;
}
#endif
2014-03-18 03:32:58 +00:00
2014-04-19 13:23:34 +00:00
if (signal_reload) {
signal_reload = false;
srs_info("get signal reload, to reload the config.");
if ((ret = _srs_config->reload()) != ERROR_SUCCESS) {
srs_error("reload config failed. ret=%d", ret);
return ret;
}
srs_trace("reload config success.");
}
2014-03-18 03:32:58 +00:00
2014-04-19 13:23:34 +00:00
// update the cache time or rusage.
if (i == SRS_SYS_TIME_RESOLUTION_MS_TIMES) {
srs_update_system_time_ms();
}
if (i == SRS_SYS_RUSAGE_RESOLUTION_TIMES) {
srs_update_system_rusage();
}
if (i == SRS_SYS_CPU_STAT_RESOLUTION_TIMES) {
srs_update_system_cpu_stat();
2014-03-18 03:32:58 +00:00
}
}
}
#ifdef SRS_AUTO_INGEST
ingester->stop();
#endif
2014-03-18 03:32:58 +00:00
return ret;
2013-11-23 03:36:07 +00:00
}
void SrsServer::remove(SrsConnection* conn)
{
2014-03-18 03:32:58 +00:00
std::vector<SrsConnection*>::iterator it = std::find(conns.begin(), conns.end(), conn);
if (it != conns.end()) {
conns.erase(it);
}
srs_info("conn removed. conns=%d", (int)conns.size());
// all connections are created by server,
// so we free it here.
srs_freep(conn);
2013-11-23 03:36:07 +00:00
}
void SrsServer::on_signal(int signo)
{
2014-03-18 03:32:58 +00:00
if (signo == SIGNAL_RELOAD) {
signal_reload = true;
return;
}
if (signo == SIGINT) {
#ifdef SRS_AUTO_GPERF_MC
2014-03-18 03:32:58 +00:00
srs_trace("gmc is on, main cycle will terminate normally.");
signal_gmc_stop = true;
2014-03-07 07:40:55 +00:00
#else
2014-03-18 03:32:58 +00:00
srs_trace("user terminate program");
exit(0);
2014-03-07 07:40:55 +00:00
#endif
2014-03-18 03:32:58 +00:00
return;
}
if (signo == SIGTERM) {
srs_trace("user terminate program");
exit(0);
return;
}
2013-11-23 03:36:07 +00:00
}
2014-04-12 14:16:39 +00:00
int SrsServer::listen_rtmp()
{
int ret = ERROR_SUCCESS;
// stream service port.
SrsConfDirective* conf = _srs_config->get_listen();
srs_assert(conf);
close_listeners(SrsListenerRtmpStream);
for (int i = 0; i < (int)conf->args.size(); i++) {
SrsListener* listener = new SrsListener(this, SrsListenerRtmpStream);
listeners.push_back(listener);
int port = ::atoi(conf->args.at(i).c_str());
if ((ret = listener->listen(port)) != ERROR_SUCCESS) {
srs_error("RTMP stream listen at port %d failed. ret=%d", port, ret);
return ret;
}
}
return ret;
}
int SrsServer::listen_http_api()
{
int ret = ERROR_SUCCESS;
#ifdef SRS_AUTO_HTTP_API
2014-04-12 14:16:39 +00:00
close_listeners(SrsListenerHttpApi);
if (_srs_config->get_http_api_enabled()) {
SrsListener* listener = new SrsListener(this, SrsListenerHttpApi);
listeners.push_back(listener);
int port = _srs_config->get_http_api_listen();
if ((ret = listener->listen(port)) != ERROR_SUCCESS) {
srs_error("HTTP api listen at port %d failed. ret=%d", port, ret);
return ret;
}
}
#endif
return ret;
}
int SrsServer::listen_http_stream()
{
int ret = ERROR_SUCCESS;
#ifdef SRS_AUTO_HTTP_SERVER
2014-04-12 14:16:39 +00:00
close_listeners(SrsListenerHttpStream);
if (_srs_config->get_http_stream_enabled()) {
SrsListener* listener = new SrsListener(this, SrsListenerHttpStream);
listeners.push_back(listener);
int port = _srs_config->get_http_stream_listen();
if ((ret = listener->listen(port)) != ERROR_SUCCESS) {
srs_error("HTTP stream listen at port %d failed. ret=%d", port, ret);
return ret;
}
}
#endif
return ret;
}
void SrsServer::close_listeners(SrsListenerType type)
2013-11-23 03:36:07 +00:00
{
2014-03-18 03:32:58 +00:00
std::vector<SrsListener*>::iterator it;
2014-04-12 14:16:39 +00:00
for (it = listeners.begin(); it != listeners.end();) {
2014-03-18 03:32:58 +00:00
SrsListener* listener = *it;
2014-04-12 14:16:39 +00:00
if (listener->type() != type) {
++it;
continue;
}
2014-03-18 03:32:58 +00:00
srs_freep(listener);
2014-04-12 14:16:39 +00:00
it = listeners.erase(it);
2014-03-18 03:32:58 +00:00
}
2013-11-23 03:36:07 +00:00
}
int SrsServer::accept_client(SrsListenerType type, st_netfd_t client_stfd)
{
2014-03-18 03:32:58 +00:00
int ret = ERROR_SUCCESS;
int max_connections = _srs_config->get_max_connections();
if ((int)conns.size() >= max_connections) {
int fd = st_netfd_fileno(client_stfd);
srs_error("exceed the max connections, drop client: "
"clients=%d, max=%d, fd=%d", (int)conns.size(), max_connections, fd);
srs_close_stfd(client_stfd);
return ret;
}
SrsConnection* conn = NULL;
2014-03-27 04:27:47 +00:00
if (type == SrsListenerRtmpStream) {
conn = new SrsRtmpConn(this, client_stfd);
2014-03-27 04:14:04 +00:00
} else if (type == SrsListenerHttpApi) {
#ifdef SRS_AUTO_HTTP_API
2014-04-02 10:07:34 +00:00
conn = new SrsHttpApi(this, client_stfd, http_api_handler);
2014-04-01 08:06:32 +00:00
#else
srs_warn("close http client for server not support http-api");
srs_close_stfd(client_stfd);
return ret;
#endif
2014-03-27 04:14:04 +00:00
} else if (type == SrsListenerHttpStream) {
#ifdef SRS_AUTO_HTTP_SERVER
2014-04-02 10:07:34 +00:00
conn = new SrsHttpConn(this, client_stfd, http_stream_handler);
2014-04-01 07:42:27 +00:00
#else
srs_warn("close http client for server not support http-server");
srs_close_stfd(client_stfd);
return ret;
#endif
2014-03-18 03:32:58 +00:00
} else {
// TODO: FIXME: handler others
2014-03-18 03:32:58 +00:00
}
srs_assert(conn);
// directly enqueue, the cycle thread will remove the client.
conns.push_back(conn);
srs_verbose("add conn to vector.");
2014-03-18 03:32:58 +00:00
// cycle will start process thread and when finished remove the client.
if ((ret = conn->start()) != ERROR_SUCCESS) {
return ret;
}
srs_verbose("conn started success .");
srs_verbose("accept client finished. conns=%d, ret=%d", (int)conns.size(), ret);
2014-03-18 03:32:58 +00:00
return ret;
2013-11-23 03:36:07 +00:00
}
int SrsServer::on_reload_listen()
{
2014-03-18 03:32:58 +00:00
return listen();
2013-11-23 03:36:07 +00:00
}
2014-04-12 12:46:32 +00:00
int SrsServer::on_reload_pid()
{
if (pid_fd > 0) {
::close(pid_fd);
pid_fd = -1;
}
return acquire_pid_file();
}
2014-04-13 05:08:10 +00:00
2014-04-13 05:27:51 +00:00
int SrsServer::on_reload_vhost_added(std::string vhost)
{
int ret = ERROR_SUCCESS;
#ifdef SRS_AUTO_HTTP_SERVER
2014-04-13 05:27:51 +00:00
if (!_srs_config->get_vhost_http_enabled(vhost)) {
return ret;
}
if ((ret = on_reload_vhost_http_updated()) != ERROR_SUCCESS) {
return ret;
}
#endif
return ret;
}
int SrsServer::on_reload_vhost_removed(std::string vhost)
{
int ret = ERROR_SUCCESS;
#ifdef SRS_AUTO_HTTP_SERVER
2014-04-13 05:27:51 +00:00
if ((ret = on_reload_vhost_http_updated()) != ERROR_SUCCESS) {
return ret;
}
#endif
return ret;
}
int SrsServer::on_reload_vhost_http_updated()
{
int ret = ERROR_SUCCESS;
#ifdef SRS_AUTO_HTTP_SERVER
2014-04-13 05:27:51 +00:00
srs_freep(http_stream_handler);
http_stream_handler = SrsHttpHandler::create_http_stream();
if ((ret = http_stream_handler->initialize()) != ERROR_SUCCESS) {
return ret;
}
#endif
return ret;
}
2014-04-13 05:08:10 +00:00
int SrsServer::on_reload_http_api_enabled()
{
2014-04-13 05:27:51 +00:00
int ret = ERROR_SUCCESS;
#ifdef SRS_AUTO_HTTP_API
2014-04-13 05:27:51 +00:00
ret = listen_http_api();
#endif
return ret;
2014-04-13 05:08:10 +00:00
}
int SrsServer::on_reload_http_api_disabled()
{
int ret = ERROR_SUCCESS;
#ifdef SRS_AUTO_HTTP_API
2014-04-13 05:08:10 +00:00
close_listeners(SrsListenerHttpApi);
2014-04-13 05:27:51 +00:00
#endif
return ret;
}
int SrsServer::on_reload_http_stream_enabled()
{
int ret = ERROR_SUCCESS;
#ifdef SRS_AUTO_HTTP_SERVER
2014-04-13 05:27:51 +00:00
ret = listen_http_stream();
#endif
return ret;
}
int SrsServer::on_reload_http_stream_disabled()
{
int ret = ERROR_SUCCESS;
#ifdef SRS_AUTO_HTTP_SERVER
2014-04-13 05:27:51 +00:00
close_listeners(SrsListenerHttpStream);
#endif
return ret;
}
int SrsServer::on_reload_http_stream_updated()
{
int ret = ERROR_SUCCESS;
#ifdef SRS_AUTO_HTTP_SERVER
2014-04-13 05:27:51 +00:00
if ((ret = on_reload_http_stream_enabled()) != ERROR_SUCCESS) {
return ret;
}
if ((ret = on_reload_vhost_http_updated()) != ERROR_SUCCESS) {
return ret;
}
#endif
2014-04-13 05:08:10 +00:00
return ret;
}