mirror of
https://github.com/ossrs/srs.git
synced 2025-03-09 15:49:59 +00:00
fix ffmpeg log fd leak, always close log_fd. 0.9.94
This commit is contained in:
parent
74e6e28993
commit
7004510cc7
3 changed files with 134 additions and 139 deletions
|
@ -64,8 +64,6 @@ SrsFFMPEG::SrsFFMPEG(std::string ffmpeg_bin)
|
||||||
abitrate = 0;
|
abitrate = 0;
|
||||||
asample_rate = 0;
|
asample_rate = 0;
|
||||||
achannels = 0;
|
achannels = 0;
|
||||||
|
|
||||||
log_fd = -1;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
SrsFFMPEG::~SrsFFMPEG()
|
SrsFFMPEG::~SrsFFMPEG()
|
||||||
|
@ -375,6 +373,7 @@ int SrsFFMPEG::start()
|
||||||
// child process: ffmpeg encoder engine.
|
// child process: ffmpeg encoder engine.
|
||||||
if (pid == 0) {
|
if (pid == 0) {
|
||||||
// redirect logs to file.
|
// redirect logs to file.
|
||||||
|
int log_fd = -1;
|
||||||
int flags = O_CREAT|O_WRONLY|O_APPEND;
|
int flags = O_CREAT|O_WRONLY|O_APPEND;
|
||||||
mode_t mode = S_IRUSR|S_IWUSR|S_IRGRP|S_IWGRP|S_IROTH;
|
mode_t mode = S_IRUSR|S_IWUSR|S_IRGRP|S_IWGRP|S_IROTH;
|
||||||
if ((log_fd = ::open(log_file.c_str(), flags, mode)) < 0) {
|
if ((log_fd = ::open(log_file.c_str(), flags, mode)) < 0) {
|
||||||
|
@ -392,6 +391,8 @@ int SrsFFMPEG::start()
|
||||||
srs_error("dup2 encoder file failed. ret=%d", ret);
|
srs_error("dup2 encoder file failed. ret=%d", ret);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
// close log fd
|
||||||
|
::close(log_fd);
|
||||||
// close other fds
|
// close other fds
|
||||||
// TODO: do in right way.
|
// TODO: do in right way.
|
||||||
for (int i = 3; i < 1024; i++) {
|
for (int i = 3; i < 1024; i++) {
|
||||||
|
@ -456,11 +457,6 @@ int SrsFFMPEG::cycle()
|
||||||
|
|
||||||
void SrsFFMPEG::stop()
|
void SrsFFMPEG::stop()
|
||||||
{
|
{
|
||||||
if (log_fd > 0) {
|
|
||||||
::close(log_fd);
|
|
||||||
log_fd = -1;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!started) {
|
if (!started) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
|
@ -48,7 +48,6 @@ private:
|
||||||
pid_t pid;
|
pid_t pid;
|
||||||
private:
|
private:
|
||||||
std::string log_file;
|
std::string log_file;
|
||||||
int log_fd;
|
|
||||||
private:
|
private:
|
||||||
std::string ffmpeg;
|
std::string ffmpeg;
|
||||||
std::string _iparams;
|
std::string _iparams;
|
||||||
|
|
262
trunk/src/core/srs_core.hpp
Normal file → Executable file
262
trunk/src/core/srs_core.hpp
Normal file → Executable file
|
@ -1,131 +1,131 @@
|
||||||
/*
|
/*
|
||||||
The MIT License (MIT)
|
The MIT License (MIT)
|
||||||
|
|
||||||
Copyright (c) 2013-2014 winlin
|
Copyright (c) 2013-2014 winlin
|
||||||
|
|
||||||
Permission is hereby granted, free of charge, to any person obtaining a copy of
|
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
|
this software and associated documentation files (the "Software"), to deal in
|
||||||
the Software without restriction, including without limitation the rights to
|
the Software without restriction, including without limitation the rights to
|
||||||
use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
|
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,
|
the Software, and to permit persons to whom the Software is furnished to do so,
|
||||||
subject to the following conditions:
|
subject to the following conditions:
|
||||||
|
|
||||||
The above copyright notice and this permission notice shall be included in all
|
The above copyright notice and this permission notice shall be included in all
|
||||||
copies or substantial portions of the Software.
|
copies or substantial portions of the Software.
|
||||||
|
|
||||||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||||
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
|
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
|
||||||
FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
|
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
|
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
|
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.
|
CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef SRS_CORE_HPP
|
#ifndef SRS_CORE_HPP
|
||||||
#define SRS_CORE_HPP
|
#define SRS_CORE_HPP
|
||||||
|
|
||||||
/*
|
/*
|
||||||
#include <srs_core.hpp>
|
#include <srs_core.hpp>
|
||||||
*/
|
*/
|
||||||
|
|
||||||
// current release version
|
// current release version
|
||||||
#define VERSION_MAJOR "0"
|
#define VERSION_MAJOR "0"
|
||||||
#define VERSION_MINOR "9"
|
#define VERSION_MINOR "9"
|
||||||
#define VERSION_REVISION "93"
|
#define VERSION_REVISION "94"
|
||||||
#define RTMP_SIG_SRS_VERSION VERSION_MAJOR"."VERSION_MINOR"."VERSION_REVISION
|
#define RTMP_SIG_SRS_VERSION VERSION_MAJOR"."VERSION_MINOR"."VERSION_REVISION
|
||||||
// server info.
|
// server info.
|
||||||
#define RTMP_SIG_SRS_KEY "srs"
|
#define RTMP_SIG_SRS_KEY "srs"
|
||||||
#define RTMP_SIG_SRS_ROLE "origin/edge server"
|
#define RTMP_SIG_SRS_ROLE "origin/edge server"
|
||||||
#define RTMP_SIG_SRS_NAME RTMP_SIG_SRS_KEY"(simple rtmp server)"
|
#define RTMP_SIG_SRS_NAME RTMP_SIG_SRS_KEY"(simple rtmp server)"
|
||||||
#define RTMP_SIG_SRS_URL_SHORT "github.com/winlinvip/simple-rtmp-server"
|
#define RTMP_SIG_SRS_URL_SHORT "github.com/winlinvip/simple-rtmp-server"
|
||||||
#define RTMP_SIG_SRS_URL "https://"RTMP_SIG_SRS_URL_SHORT
|
#define RTMP_SIG_SRS_URL "https://"RTMP_SIG_SRS_URL_SHORT
|
||||||
#define RTMP_SIG_SRS_WEB "http://blog.csdn.net/win_lin"
|
#define RTMP_SIG_SRS_WEB "http://blog.csdn.net/win_lin"
|
||||||
#define RTMP_SIG_SRS_EMAIL "winlin@vip.126.com"
|
#define RTMP_SIG_SRS_EMAIL "winlin@vip.126.com"
|
||||||
#define RTMP_SIG_SRS_LICENSE "The MIT License (MIT)"
|
#define RTMP_SIG_SRS_LICENSE "The MIT License (MIT)"
|
||||||
#define RTMP_SIG_SRS_COPYRIGHT "Copyright (c) 2013-2014 winlin"
|
#define RTMP_SIG_SRS_COPYRIGHT "Copyright (c) 2013-2014 winlin"
|
||||||
#define RTMP_SIG_SRS_PRIMARY_AUTHROS "winlin,wenjie.zhao"
|
#define RTMP_SIG_SRS_PRIMARY_AUTHROS "winlin,wenjie.zhao"
|
||||||
#define RTMP_SIG_SRS_CONTRIBUTORS_URL RTMP_SIG_SRS_URL"/blob/master/AUTHORS.txt"
|
#define RTMP_SIG_SRS_CONTRIBUTORS_URL RTMP_SIG_SRS_URL"/blob/master/AUTHORS.txt"
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* the core provides the common defined macros, utilities,
|
* the core provides the common defined macros, utilities,
|
||||||
* user must include the srs_core.hpp before any header, or maybe
|
* user must include the srs_core.hpp before any header, or maybe
|
||||||
* build failed.
|
* build failed.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
// for 32bit os, 2G big file limit for unistd io,
|
// for 32bit os, 2G big file limit for unistd io,
|
||||||
// ie. read/write/lseek to use 64bits size for huge file.
|
// ie. read/write/lseek to use 64bits size for huge file.
|
||||||
#ifndef _FILE_OFFSET_BITS
|
#ifndef _FILE_OFFSET_BITS
|
||||||
#define _FILE_OFFSET_BITS 64
|
#define _FILE_OFFSET_BITS 64
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// for int64_t print using PRId64 format.
|
// for int64_t print using PRId64 format.
|
||||||
#ifndef __STDC_FORMAT_MACROS
|
#ifndef __STDC_FORMAT_MACROS
|
||||||
#define __STDC_FORMAT_MACROS
|
#define __STDC_FORMAT_MACROS
|
||||||
#endif
|
#endif
|
||||||
#include <inttypes.h>
|
#include <inttypes.h>
|
||||||
|
|
||||||
#include <assert.h>
|
#include <assert.h>
|
||||||
#define srs_assert(expression) assert(expression)
|
#define srs_assert(expression) assert(expression)
|
||||||
|
|
||||||
#include <stddef.h>
|
#include <stddef.h>
|
||||||
#include <sys/types.h>
|
#include <sys/types.h>
|
||||||
|
|
||||||
// generated by configure.
|
// generated by configure.
|
||||||
#include <srs_auto_headers.hpp>
|
#include <srs_auto_headers.hpp>
|
||||||
|
|
||||||
// free the p and set to NULL.
|
// free the p and set to NULL.
|
||||||
// p must be a T*.
|
// p must be a T*.
|
||||||
#define srs_freep(p) \
|
#define srs_freep(p) \
|
||||||
if (p) { \
|
if (p) { \
|
||||||
delete p; \
|
delete p; \
|
||||||
p = NULL; \
|
p = NULL; \
|
||||||
} \
|
} \
|
||||||
(void)0
|
(void)0
|
||||||
// free the p which represents a array
|
// free the p which represents a array
|
||||||
#define srs_freepa(p) \
|
#define srs_freepa(p) \
|
||||||
if (p) { \
|
if (p) { \
|
||||||
delete[] p; \
|
delete[] p; \
|
||||||
p = NULL; \
|
p = NULL; \
|
||||||
} \
|
} \
|
||||||
(void)0
|
(void)0
|
||||||
|
|
||||||
// compare
|
// compare
|
||||||
#define srs_min(a, b) (((a) < (b))? (a) : (b))
|
#define srs_min(a, b) (((a) < (b))? (a) : (b))
|
||||||
#define srs_max(a, b) (((a) < (b))? (b) : (a))
|
#define srs_max(a, b) (((a) < (b))? (b) : (a))
|
||||||
|
|
||||||
// signal defines.
|
// signal defines.
|
||||||
#define SIGNAL_RELOAD SIGHUP
|
#define SIGNAL_RELOAD SIGHUP
|
||||||
|
|
||||||
#include <string>
|
#include <string>
|
||||||
// replace old_str to new_str of str
|
// replace old_str to new_str of str
|
||||||
extern std::string srs_string_replace(std::string str, std::string old_str, std::string new_str);
|
extern std::string srs_string_replace(std::string str, std::string old_str, std::string new_str);
|
||||||
// trim char in trim_chars of str
|
// trim char in trim_chars of str
|
||||||
extern std::string srs_string_trim_end(std::string str, std::string trim_chars);
|
extern std::string srs_string_trim_end(std::string str, std::string trim_chars);
|
||||||
// trim char in trim_chars of str
|
// trim char in trim_chars of str
|
||||||
extern std::string srs_string_trim_start(std::string str, std::string trim_chars);
|
extern std::string srs_string_trim_start(std::string str, std::string trim_chars);
|
||||||
// remove char in remove_chars of str
|
// remove char in remove_chars of str
|
||||||
extern std::string srs_string_remove(std::string str, std::string remove_chars);
|
extern std::string srs_string_remove(std::string str, std::string remove_chars);
|
||||||
// whether string end with
|
// whether string end with
|
||||||
extern bool srs_string_ends_with(std::string str, std::string flag);
|
extern bool srs_string_ends_with(std::string str, std::string flag);
|
||||||
|
|
||||||
// dns resolve utility, return the resolved ip address.
|
// dns resolve utility, return the resolved ip address.
|
||||||
extern std::string srs_dns_resolve(std::string host);
|
extern std::string srs_dns_resolve(std::string host);
|
||||||
// whether system is little endian
|
// whether system is little endian
|
||||||
extern bool srs_is_little_endian();
|
extern bool srs_is_little_endian();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* disable copy constructor of class
|
* disable copy constructor of class
|
||||||
*/
|
*/
|
||||||
#define disable_default_copy(className)\
|
#define disable_default_copy(className)\
|
||||||
private:\
|
private:\
|
||||||
/** \
|
/** \
|
||||||
* disable the copy constructor and operator=, donot allow directly copy. \
|
* disable the copy constructor and operator=, donot allow directly copy. \
|
||||||
*/ \
|
*/ \
|
||||||
className(const className&); \
|
className(const className&); \
|
||||||
className& operator= (const className&)
|
className& operator= (const className&)
|
||||||
|
|
||||||
// const time for st to convert to us
|
// const time for st to convert to us
|
||||||
#define SRS_TIME_MILLISECONDS 1000
|
#define SRS_TIME_MILLISECONDS 1000
|
||||||
#define SRS_TIME_SECONDS 1000000
|
#define SRS_TIME_SECONDS 1000000
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue