mirror of
https://github.com/ossrs/srs.git
synced 2025-03-09 15:49:59 +00:00
update readme
This commit is contained in:
parent
bf18a3ac96
commit
18028ad4cb
3 changed files with 934 additions and 930 deletions
|
@ -36,7 +36,8 @@ FMS URL: rtmp://127.0.0.1:1935/live
|
||||||
Stream: livestream
|
Stream: livestream
|
||||||
For example, use ffmpeg to publish:
|
For example, use ffmpeg to publish:
|
||||||
for((;;)); do \
|
for((;;)); do \
|
||||||
./objs/ffmpeg/bin/ffmpeg -re -i ./doc/source.200kbps.768x320.flv -vcodec copy -acodec copy \
|
./objs/ffmpeg/bin/ffmpeg -re -i ./doc/source.200kbps.768x320.flv \
|
||||||
|
-vcodec copy -acodec copy \
|
||||||
-f flv -y rtmp://127.0.0.1:1935/live/livestream; \
|
-f flv -y rtmp://127.0.0.1:1935/live/livestream; \
|
||||||
sleep 1; \
|
sleep 1; \
|
||||||
done
|
done
|
||||||
|
|
1157
trunk/src/core/srs_core_encoder.cpp
Normal file → Executable file
1157
trunk/src/core/srs_core_encoder.cpp
Normal file → Executable file
File diff suppressed because it is too large
Load diff
704
trunk/src/core/srs_core_forward.cpp
Normal file → Executable file
704
trunk/src/core/srs_core_forward.cpp
Normal file → Executable file
|
@ -1,351 +1,353 @@
|
||||||
/*
|
/*
|
||||||
The MIT License (MIT)
|
The MIT License (MIT)
|
||||||
|
|
||||||
Copyright (c) 2013 winlin
|
Copyright (c) 2013 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.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include <srs_core_forward.hpp>
|
#include <srs_core_forward.hpp>
|
||||||
|
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <sys/socket.h>
|
#include <sys/socket.h>
|
||||||
#include <netinet/in.h>
|
#include <netinet/in.h>
|
||||||
#include <arpa/inet.h>
|
#include <arpa/inet.h>
|
||||||
#include <netdb.h>
|
#include <netdb.h>
|
||||||
|
|
||||||
#include <srs_core_error.hpp>
|
#include <srs_core_error.hpp>
|
||||||
#include <srs_core_rtmp.hpp>
|
#include <srs_core_rtmp.hpp>
|
||||||
#include <srs_core_log.hpp>
|
#include <srs_core_log.hpp>
|
||||||
#include <srs_core_protocol.hpp>
|
#include <srs_core_protocol.hpp>
|
||||||
#include <srs_core_pithy_print.hpp>
|
#include <srs_core_pithy_print.hpp>
|
||||||
|
|
||||||
#define SRS_PULSE_TIMEOUT_MS 100
|
#define SRS_PULSE_TIMEOUT_MS 100
|
||||||
#define SRS_FORWARDER_SLEEP_MS 2000
|
#define SRS_FORWARDER_SLEEP_MS 2000
|
||||||
#define SRS_SEND_TIMEOUT_US 3000000L
|
#define SRS_SEND_TIMEOUT_US 3000000L
|
||||||
#define SRS_RECV_TIMEOUT_US SRS_SEND_TIMEOUT_US
|
#define SRS_RECV_TIMEOUT_US SRS_SEND_TIMEOUT_US
|
||||||
|
|
||||||
SrsForwarder::SrsForwarder()
|
SrsForwarder::SrsForwarder()
|
||||||
{
|
{
|
||||||
client = NULL;
|
client = NULL;
|
||||||
stfd = NULL;
|
stfd = NULL;
|
||||||
stream_id = 0;
|
stream_id = 0;
|
||||||
|
|
||||||
tid = NULL;
|
tid = NULL;
|
||||||
loop = false;
|
loop = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
SrsForwarder::~SrsForwarder()
|
SrsForwarder::~SrsForwarder()
|
||||||
{
|
{
|
||||||
on_unpublish();
|
on_unpublish();
|
||||||
|
|
||||||
std::vector<SrsSharedPtrMessage*>::iterator it;
|
std::vector<SrsSharedPtrMessage*>::iterator it;
|
||||||
for (it = msgs.begin(); it != msgs.end(); ++it) {
|
for (it = msgs.begin(); it != msgs.end(); ++it) {
|
||||||
SrsSharedPtrMessage* msg = *it;
|
SrsSharedPtrMessage* msg = *it;
|
||||||
srs_freep(msg);
|
srs_freep(msg);
|
||||||
}
|
}
|
||||||
msgs.clear();
|
msgs.clear();
|
||||||
}
|
}
|
||||||
|
|
||||||
int SrsForwarder::on_publish(std::string vhost, std::string _app, std::string stream, std::string forward_server)
|
int SrsForwarder::on_publish(std::string vhost, std::string _app, std::string stream, std::string forward_server)
|
||||||
{
|
{
|
||||||
int ret = ERROR_SUCCESS;
|
int ret = ERROR_SUCCESS;
|
||||||
|
|
||||||
app = _app;
|
app = _app;
|
||||||
|
|
||||||
tc_url = "rtmp://";
|
tc_url = "rtmp://";
|
||||||
tc_url += vhost;
|
tc_url += vhost;
|
||||||
tc_url += "/";
|
tc_url += "/";
|
||||||
tc_url += app;
|
tc_url += app;
|
||||||
|
|
||||||
stream_name = stream;
|
stream_name = stream;
|
||||||
server = forward_server;
|
server = forward_server;
|
||||||
port = 1935;
|
port = 1935;
|
||||||
|
|
||||||
size_t pos = forward_server.find(":");
|
// TODO: dead loop check.
|
||||||
if (pos != std::string::npos) {
|
|
||||||
port = ::atoi(forward_server.substr(pos + 1).c_str());
|
size_t pos = forward_server.find(":");
|
||||||
server = forward_server.substr(0, pos);
|
if (pos != std::string::npos) {
|
||||||
}
|
port = ::atoi(forward_server.substr(pos + 1).c_str());
|
||||||
|
server = forward_server.substr(0, pos);
|
||||||
if ((ret = open_socket()) != ERROR_SUCCESS) {
|
}
|
||||||
return ret;
|
|
||||||
}
|
if ((ret = open_socket()) != ERROR_SUCCESS) {
|
||||||
|
return ret;
|
||||||
srs_assert(!tid);
|
}
|
||||||
if((tid = st_thread_create(forward_thread, this, 1, 0)) == NULL){
|
|
||||||
ret = ERROR_ST_CREATE_FORWARD_THREAD;
|
srs_assert(!tid);
|
||||||
srs_error("st_thread_create failed. ret=%d", ret);
|
if((tid = st_thread_create(forward_thread, this, 1, 0)) == NULL){
|
||||||
return ret;
|
ret = ERROR_ST_CREATE_FORWARD_THREAD;
|
||||||
}
|
srs_error("st_thread_create failed. ret=%d", ret);
|
||||||
|
return ret;
|
||||||
return ret;
|
}
|
||||||
}
|
|
||||||
|
return ret;
|
||||||
void SrsForwarder::on_unpublish()
|
}
|
||||||
{
|
|
||||||
if (tid) {
|
void SrsForwarder::on_unpublish()
|
||||||
loop = false;
|
{
|
||||||
st_thread_interrupt(tid);
|
if (tid) {
|
||||||
st_thread_join(tid, NULL);
|
loop = false;
|
||||||
tid = NULL;
|
st_thread_interrupt(tid);
|
||||||
}
|
st_thread_join(tid, NULL);
|
||||||
|
tid = NULL;
|
||||||
if (stfd) {
|
}
|
||||||
int fd = st_netfd_fileno(stfd);
|
|
||||||
st_netfd_close(stfd);
|
if (stfd) {
|
||||||
stfd = NULL;
|
int fd = st_netfd_fileno(stfd);
|
||||||
|
st_netfd_close(stfd);
|
||||||
// st does not close it sometimes,
|
stfd = NULL;
|
||||||
// close it manually.
|
|
||||||
close(fd);
|
// st does not close it sometimes,
|
||||||
}
|
// close it manually.
|
||||||
|
close(fd);
|
||||||
srs_freep(client);
|
}
|
||||||
}
|
|
||||||
|
srs_freep(client);
|
||||||
int SrsForwarder::on_meta_data(SrsSharedPtrMessage* metadata)
|
}
|
||||||
{
|
|
||||||
int ret = ERROR_SUCCESS;
|
int SrsForwarder::on_meta_data(SrsSharedPtrMessage* metadata)
|
||||||
|
{
|
||||||
msgs.push_back(metadata);
|
int ret = ERROR_SUCCESS;
|
||||||
|
|
||||||
return ret;
|
msgs.push_back(metadata);
|
||||||
}
|
|
||||||
|
return ret;
|
||||||
int SrsForwarder::on_audio(SrsSharedPtrMessage* msg)
|
}
|
||||||
{
|
|
||||||
int ret = ERROR_SUCCESS;
|
int SrsForwarder::on_audio(SrsSharedPtrMessage* msg)
|
||||||
|
{
|
||||||
msgs.push_back(msg);
|
int ret = ERROR_SUCCESS;
|
||||||
|
|
||||||
return ret;
|
msgs.push_back(msg);
|
||||||
}
|
|
||||||
|
return ret;
|
||||||
int SrsForwarder::on_video(SrsSharedPtrMessage* msg)
|
}
|
||||||
{
|
|
||||||
int ret = ERROR_SUCCESS;
|
int SrsForwarder::on_video(SrsSharedPtrMessage* msg)
|
||||||
|
{
|
||||||
msgs.push_back(msg);
|
int ret = ERROR_SUCCESS;
|
||||||
|
|
||||||
return ret;
|
msgs.push_back(msg);
|
||||||
}
|
|
||||||
|
return ret;
|
||||||
int SrsForwarder::open_socket()
|
}
|
||||||
{
|
|
||||||
int ret = ERROR_SUCCESS;
|
int SrsForwarder::open_socket()
|
||||||
|
{
|
||||||
srs_trace("forward stream=%s, tcUrl=%s to server=%s, port=%d",
|
int ret = ERROR_SUCCESS;
|
||||||
stream_name.c_str(), tc_url.c_str(), server.c_str(), port);
|
|
||||||
|
srs_trace("forward stream=%s, tcUrl=%s to server=%s, port=%d",
|
||||||
int sock = socket(AF_INET, SOCK_STREAM, 0);
|
stream_name.c_str(), tc_url.c_str(), server.c_str(), port);
|
||||||
if(sock == -1){
|
|
||||||
ret = ERROR_SOCKET_CREATE;
|
int sock = socket(AF_INET, SOCK_STREAM, 0);
|
||||||
srs_error("create socket error. ret=%d", ret);
|
if(sock == -1){
|
||||||
return ret;
|
ret = ERROR_SOCKET_CREATE;
|
||||||
}
|
srs_error("create socket error. ret=%d", ret);
|
||||||
|
return ret;
|
||||||
stfd = st_netfd_open_socket(sock);
|
}
|
||||||
if(stfd == NULL){
|
|
||||||
ret = ERROR_ST_OPEN_SOCKET;
|
stfd = st_netfd_open_socket(sock);
|
||||||
srs_error("st_netfd_open_socket failed. ret=%d", ret);
|
if(stfd == NULL){
|
||||||
return ret;
|
ret = ERROR_ST_OPEN_SOCKET;
|
||||||
}
|
srs_error("st_netfd_open_socket failed. ret=%d", ret);
|
||||||
|
return ret;
|
||||||
srs_freep(client);
|
}
|
||||||
client = new SrsRtmpClient(stfd);
|
|
||||||
|
srs_freep(client);
|
||||||
return ret;
|
client = new SrsRtmpClient(stfd);
|
||||||
}
|
|
||||||
|
return ret;
|
||||||
int SrsForwarder::connect_server()
|
}
|
||||||
{
|
|
||||||
int ret = ERROR_SUCCESS;
|
int SrsForwarder::connect_server()
|
||||||
|
{
|
||||||
std::string ip = parse_server(server);
|
int ret = ERROR_SUCCESS;
|
||||||
if (ip.empty()) {
|
|
||||||
ret = ERROR_SYSTEM_IP_INVALID;
|
std::string ip = parse_server(server);
|
||||||
srs_error("dns resolve server error, ip empty. ret=%d", ret);
|
if (ip.empty()) {
|
||||||
return ret;
|
ret = ERROR_SYSTEM_IP_INVALID;
|
||||||
}
|
srs_error("dns resolve server error, ip empty. ret=%d", ret);
|
||||||
|
return ret;
|
||||||
sockaddr_in addr;
|
}
|
||||||
addr.sin_family = AF_INET;
|
|
||||||
addr.sin_port = htons(port);
|
sockaddr_in addr;
|
||||||
addr.sin_addr.s_addr = inet_addr(ip.c_str());
|
addr.sin_family = AF_INET;
|
||||||
|
addr.sin_port = htons(port);
|
||||||
if (st_connect(stfd, (const struct sockaddr*)&addr, sizeof(sockaddr_in), ST_UTIME_NO_TIMEOUT) == -1){
|
addr.sin_addr.s_addr = inet_addr(ip.c_str());
|
||||||
ret = ERROR_ST_CONNECT;
|
|
||||||
srs_error("connect to server error. ip=%s, port=%d, ret=%d", ip.c_str(), port, ret);
|
if (st_connect(stfd, (const struct sockaddr*)&addr, sizeof(sockaddr_in), ST_UTIME_NO_TIMEOUT) == -1){
|
||||||
return ret;
|
ret = ERROR_ST_CONNECT;
|
||||||
}
|
srs_error("connect to server error. ip=%s, port=%d, ret=%d", ip.c_str(), port, ret);
|
||||||
srs_trace("connect to server success. server=%s, ip=%s, port=%d", server.c_str(), ip.c_str(), port);
|
return ret;
|
||||||
|
}
|
||||||
return ret;
|
srs_trace("connect to server success. server=%s, ip=%s, port=%d", server.c_str(), ip.c_str(), port);
|
||||||
}
|
|
||||||
|
return ret;
|
||||||
std::string SrsForwarder::parse_server(std::string host)
|
}
|
||||||
{
|
|
||||||
if (inet_addr(host.c_str()) != INADDR_NONE) {
|
std::string SrsForwarder::parse_server(std::string host)
|
||||||
return host;
|
{
|
||||||
}
|
if (inet_addr(host.c_str()) != INADDR_NONE) {
|
||||||
|
return host;
|
||||||
hostent* answer = gethostbyname(host.c_str());
|
}
|
||||||
if (answer == NULL) {
|
|
||||||
srs_error("dns resolve host %s error.", host.c_str());
|
hostent* answer = gethostbyname(host.c_str());
|
||||||
return "";
|
if (answer == NULL) {
|
||||||
}
|
srs_error("dns resolve host %s error.", host.c_str());
|
||||||
|
return "";
|
||||||
char ipv4[16];
|
}
|
||||||
memset(ipv4, 0, sizeof(ipv4));
|
|
||||||
for (int i = 0; i < answer->h_length; i++) {
|
char ipv4[16];
|
||||||
inet_ntop(AF_INET, answer->h_addr_list[i], ipv4, sizeof(ipv4));
|
memset(ipv4, 0, sizeof(ipv4));
|
||||||
srs_info("dns resolve host %s to %s.", host.c_str(), ipv4);
|
for (int i = 0; i < answer->h_length; i++) {
|
||||||
break;
|
inet_ntop(AF_INET, answer->h_addr_list[i], ipv4, sizeof(ipv4));
|
||||||
}
|
srs_info("dns resolve host %s to %s.", host.c_str(), ipv4);
|
||||||
|
break;
|
||||||
return ipv4;
|
}
|
||||||
}
|
|
||||||
|
return ipv4;
|
||||||
int SrsForwarder::cycle()
|
}
|
||||||
{
|
|
||||||
int ret = ERROR_SUCCESS;
|
int SrsForwarder::cycle()
|
||||||
|
{
|
||||||
client->set_recv_timeout(SRS_RECV_TIMEOUT_US);
|
int ret = ERROR_SUCCESS;
|
||||||
client->set_send_timeout(SRS_SEND_TIMEOUT_US);
|
|
||||||
|
client->set_recv_timeout(SRS_RECV_TIMEOUT_US);
|
||||||
if ((ret = connect_server()) != ERROR_SUCCESS) {
|
client->set_send_timeout(SRS_SEND_TIMEOUT_US);
|
||||||
return ret;
|
|
||||||
}
|
if ((ret = connect_server()) != ERROR_SUCCESS) {
|
||||||
srs_assert(client);
|
return ret;
|
||||||
|
}
|
||||||
if ((ret = client->handshake()) != ERROR_SUCCESS) {
|
srs_assert(client);
|
||||||
srs_error("handshake with server failed. ret=%d", ret);
|
|
||||||
return ret;
|
if ((ret = client->handshake()) != ERROR_SUCCESS) {
|
||||||
}
|
srs_error("handshake with server failed. ret=%d", ret);
|
||||||
if ((ret = client->connect_app(app, tc_url)) != ERROR_SUCCESS) {
|
return ret;
|
||||||
srs_error("connect with server failed, tcUrl=%s. ret=%d", tc_url.c_str(), ret);
|
}
|
||||||
return ret;
|
if ((ret = client->connect_app(app, tc_url)) != ERROR_SUCCESS) {
|
||||||
}
|
srs_error("connect with server failed, tcUrl=%s. ret=%d", tc_url.c_str(), ret);
|
||||||
if ((ret = client->create_stream(stream_id)) != ERROR_SUCCESS) {
|
return ret;
|
||||||
srs_error("connect with server failed, stream_id=%d. ret=%d", stream_id, ret);
|
}
|
||||||
return ret;
|
if ((ret = client->create_stream(stream_id)) != ERROR_SUCCESS) {
|
||||||
}
|
srs_error("connect with server failed, stream_id=%d. ret=%d", stream_id, ret);
|
||||||
if ((ret = client->publish(stream_name, stream_id)) != ERROR_SUCCESS) {
|
return ret;
|
||||||
srs_error("connect with server failed, stream_name=%s, stream_id=%d. ret=%d",
|
}
|
||||||
stream_name.c_str(), stream_id, ret);
|
if ((ret = client->publish(stream_name, stream_id)) != ERROR_SUCCESS) {
|
||||||
return ret;
|
srs_error("connect with server failed, stream_name=%s, stream_id=%d. ret=%d",
|
||||||
}
|
stream_name.c_str(), stream_id, ret);
|
||||||
|
return ret;
|
||||||
if ((ret = forward()) != ERROR_SUCCESS) {
|
}
|
||||||
return ret;
|
|
||||||
}
|
if ((ret = forward()) != ERROR_SUCCESS) {
|
||||||
|
return ret;
|
||||||
return ret;
|
}
|
||||||
}
|
|
||||||
|
return ret;
|
||||||
int SrsForwarder::forward()
|
}
|
||||||
{
|
|
||||||
int ret = ERROR_SUCCESS;
|
int SrsForwarder::forward()
|
||||||
|
{
|
||||||
client->set_recv_timeout(SRS_PULSE_TIMEOUT_MS * 1000);
|
int ret = ERROR_SUCCESS;
|
||||||
|
|
||||||
SrsPithyPrint pithy_print(SRS_STAGE_FORWARDER);
|
client->set_recv_timeout(SRS_PULSE_TIMEOUT_MS * 1000);
|
||||||
|
|
||||||
while (loop) {
|
SrsPithyPrint pithy_print(SRS_STAGE_FORWARDER);
|
||||||
pithy_print.elapse(SRS_PULSE_TIMEOUT_MS);
|
|
||||||
|
while (loop) {
|
||||||
// switch to other st-threads.
|
pithy_print.elapse(SRS_PULSE_TIMEOUT_MS);
|
||||||
st_usleep(0);
|
|
||||||
|
// switch to other st-threads.
|
||||||
// read from client.
|
st_usleep(0);
|
||||||
if (true) {
|
|
||||||
SrsCommonMessage* msg = NULL;
|
// read from client.
|
||||||
ret = client->recv_message(&msg);
|
if (true) {
|
||||||
|
SrsCommonMessage* msg = NULL;
|
||||||
srs_verbose("play loop recv message. ret=%d", ret);
|
ret = client->recv_message(&msg);
|
||||||
if (ret != ERROR_SUCCESS && ret != ERROR_SOCKET_TIMEOUT) {
|
|
||||||
srs_error("recv server control message failed. ret=%d", ret);
|
srs_verbose("play loop recv message. ret=%d", ret);
|
||||||
return ret;
|
if (ret != ERROR_SUCCESS && ret != ERROR_SOCKET_TIMEOUT) {
|
||||||
}
|
srs_error("recv server control message failed. ret=%d", ret);
|
||||||
}
|
return ret;
|
||||||
|
}
|
||||||
int count = (int)msgs.size();
|
}
|
||||||
|
|
||||||
// reportable
|
int count = (int)msgs.size();
|
||||||
if (pithy_print.can_print()) {
|
|
||||||
srs_trace("-> time=%"PRId64", msgs=%d, obytes=%"PRId64", ibytes=%"PRId64", okbps=%d, ikbps=%d",
|
// reportable
|
||||||
pithy_print.get_age(), count, client->get_send_bytes(), client->get_recv_bytes(), client->get_send_kbps(), client->get_recv_kbps());
|
if (pithy_print.can_print()) {
|
||||||
}
|
srs_trace("-> time=%"PRId64", msgs=%d, obytes=%"PRId64", ibytes=%"PRId64", okbps=%d, ikbps=%d",
|
||||||
|
pithy_print.get_age(), count, client->get_send_bytes(), client->get_recv_bytes(), client->get_send_kbps(), client->get_recv_kbps());
|
||||||
// all msgs to forward.
|
}
|
||||||
for (int i = 0; i < count; i++) {
|
|
||||||
SrsSharedPtrMessage* msg = msgs[i];
|
// all msgs to forward.
|
||||||
msgs[i] = NULL;
|
for (int i = 0; i < count; i++) {
|
||||||
|
SrsSharedPtrMessage* msg = msgs[i];
|
||||||
if ((ret = client->send_message(msg)) != ERROR_SUCCESS) {
|
msgs[i] = NULL;
|
||||||
srs_error("forwarder send message to server failed. ret=%d", ret);
|
|
||||||
return ret;
|
if ((ret = client->send_message(msg)) != ERROR_SUCCESS) {
|
||||||
}
|
srs_error("forwarder send message to server failed. ret=%d", ret);
|
||||||
}
|
return ret;
|
||||||
msgs.clear();
|
}
|
||||||
}
|
}
|
||||||
|
msgs.clear();
|
||||||
return ret;
|
}
|
||||||
}
|
|
||||||
|
return ret;
|
||||||
void SrsForwarder::forward_cycle()
|
}
|
||||||
{
|
|
||||||
int ret = ERROR_SUCCESS;
|
void SrsForwarder::forward_cycle()
|
||||||
|
{
|
||||||
log_context->generate_id();
|
int ret = ERROR_SUCCESS;
|
||||||
srs_trace("forward cycle start");
|
|
||||||
|
log_context->generate_id();
|
||||||
while (loop) {
|
srs_trace("forward cycle start");
|
||||||
if ((ret = cycle()) != ERROR_SUCCESS) {
|
|
||||||
srs_warn("forward cycle failed, ignored and retry, ret=%d", ret);
|
while (loop) {
|
||||||
} else {
|
if ((ret = cycle()) != ERROR_SUCCESS) {
|
||||||
srs_info("forward cycle success, retry");
|
srs_warn("forward cycle failed, ignored and retry, ret=%d", ret);
|
||||||
}
|
} else {
|
||||||
|
srs_info("forward cycle success, retry");
|
||||||
if (!loop) {
|
}
|
||||||
break;
|
|
||||||
}
|
if (!loop) {
|
||||||
|
break;
|
||||||
st_usleep(SRS_FORWARDER_SLEEP_MS * 1000);
|
}
|
||||||
|
|
||||||
if ((ret = open_socket()) != ERROR_SUCCESS) {
|
st_usleep(SRS_FORWARDER_SLEEP_MS * 1000);
|
||||||
srs_warn("forward cycle reopen failed, ignored and retry, ret=%d", ret);
|
|
||||||
} else {
|
if ((ret = open_socket()) != ERROR_SUCCESS) {
|
||||||
srs_info("forward cycle reopen success");
|
srs_warn("forward cycle reopen failed, ignored and retry, ret=%d", ret);
|
||||||
}
|
} else {
|
||||||
}
|
srs_info("forward cycle reopen success");
|
||||||
srs_trace("forward cycle finished");
|
}
|
||||||
}
|
}
|
||||||
|
srs_trace("forward cycle finished");
|
||||||
void* SrsForwarder::forward_thread(void* arg)
|
}
|
||||||
{
|
|
||||||
SrsForwarder* obj = (SrsForwarder*)arg;
|
void* SrsForwarder::forward_thread(void* arg)
|
||||||
srs_assert(obj != NULL);
|
{
|
||||||
|
SrsForwarder* obj = (SrsForwarder*)arg;
|
||||||
obj->loop = true;
|
srs_assert(obj != NULL);
|
||||||
obj->forward_cycle();
|
|
||||||
|
obj->loop = true;
|
||||||
return NULL;
|
obj->forward_cycle();
|
||||||
}
|
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue