mirror of
https://github.com/SChernykh/p2pool.git
synced 2025-01-03 17:29:24 +00:00
TCPServer: better tracking of used sockets
This commit is contained in:
parent
a38a7be73f
commit
924fd4b7bd
1 changed files with 6 additions and 4 deletions
|
@ -143,6 +143,7 @@ void TCPServer<READ_BUF_SIZE, WRITE_BUF_SIZE>::start_listening(const std::string
|
||||||
LOGERR(1, "failed to create tcp server handle, error " << uv_err_name(err));
|
LOGERR(1, "failed to create tcp server handle, error " << uv_err_name(err));
|
||||||
panic();
|
panic();
|
||||||
}
|
}
|
||||||
|
socket->data = this;
|
||||||
|
|
||||||
err = uv_tcp_nodelay(socket, 1);
|
err = uv_tcp_nodelay(socket, 1);
|
||||||
if (err) {
|
if (err) {
|
||||||
|
@ -179,7 +180,6 @@ void TCPServer<READ_BUF_SIZE, WRITE_BUF_SIZE>::start_listening(const std::string
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
socket->data = this;
|
|
||||||
err = uv_listen(reinterpret_cast<uv_stream_t*>(socket), DEFAULT_BACKLOG, on_new_connection);
|
err = uv_listen(reinterpret_cast<uv_stream_t*>(socket), DEFAULT_BACKLOG, on_new_connection);
|
||||||
if (err) {
|
if (err) {
|
||||||
LOGERR(1, "failed to listen on tcp server socket, error " << uv_err_name(err));
|
LOGERR(1, "failed to listen on tcp server socket, error " << uv_err_name(err));
|
||||||
|
@ -325,6 +325,7 @@ bool TCPServer<READ_BUF_SIZE, WRITE_BUF_SIZE>::connect_to_peer_nolock(Client* cl
|
||||||
m_preallocatedClients.push_back(client);
|
m_preallocatedClients.push_back(client);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
client->m_socket.data = client;
|
||||||
|
|
||||||
err = uv_tcp_nodelay(&client->m_socket, 1);
|
err = uv_tcp_nodelay(&client->m_socket, 1);
|
||||||
if (err) {
|
if (err) {
|
||||||
|
@ -541,7 +542,9 @@ void TCPServer<READ_BUF_SIZE, WRITE_BUF_SIZE>::on_connection_close(uv_handle_t*
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
|
LOGERR(5, "internal error: can't find TCPServer instance for peer " << log::Gray() << static_cast<char*>(client->m_addrString) << ", deallocating it");
|
||||||
client->reset();
|
client->reset();
|
||||||
|
delete client;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -603,6 +606,8 @@ void TCPServer<READ_BUF_SIZE, WRITE_BUF_SIZE>::on_new_client(uv_stream_t* server
|
||||||
m_preallocatedClients.push_back(client);
|
m_preallocatedClients.push_back(client);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
client->m_socket.data = client;
|
||||||
|
client->m_owner = this;
|
||||||
|
|
||||||
err = uv_tcp_nodelay(&client->m_socket, 1);
|
err = uv_tcp_nodelay(&client->m_socket, 1);
|
||||||
if (err) {
|
if (err) {
|
||||||
|
@ -633,9 +638,6 @@ void TCPServer<READ_BUF_SIZE, WRITE_BUF_SIZE>::on_new_client_nolock(uv_stream_t*
|
||||||
++m_numConnections;
|
++m_numConnections;
|
||||||
client->m_isIncoming = false;
|
client->m_isIncoming = false;
|
||||||
|
|
||||||
client->m_owner = this;
|
|
||||||
client->m_socket.data = client;
|
|
||||||
|
|
||||||
sockaddr_storage peer_addr;
|
sockaddr_storage peer_addr;
|
||||||
int peer_addr_len = static_cast<int>(sizeof(peer_addr));
|
int peer_addr_len = static_cast<int>(sizeof(peer_addr));
|
||||||
int err = uv_tcp_getpeername(&client->m_socket, reinterpret_cast<sockaddr*>(&peer_addr), &peer_addr_len);
|
int err = uv_tcp_getpeername(&client->m_socket, reinterpret_cast<sockaddr*>(&peer_addr), &peer_addr_len);
|
||||||
|
|
Loading…
Reference in a new issue