TCPServer: better tracking of used sockets

This commit is contained in:
SChernykh 2021-08-25 13:58:00 +02:00
parent a38a7be73f
commit 924fd4b7bd

View file

@ -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);