extend logging of UDP tracker announces (to track down unit test flapping)
This commit is contained in:
parent
9172874b5c
commit
d140d71e1a
|
@ -363,8 +363,9 @@ namespace libtorrent
|
||||||
mutable mutex_t m_mutex;
|
mutable mutex_t m_mutex;
|
||||||
|
|
||||||
// maps transactionid to the udp_tracker_connection
|
// maps transactionid to the udp_tracker_connection
|
||||||
// TODO: 2 this should be unique_ptr in the future
|
// TODO: this should be unique_ptr in the future
|
||||||
typedef boost::unordered_map<boost::uint32_t, boost::shared_ptr<udp_tracker_connection> > udp_conns_t;
|
typedef boost::unordered_map<boost::uint32_t
|
||||||
|
, boost::shared_ptr<udp_tracker_connection> > udp_conns_t;
|
||||||
udp_conns_t m_udp_conns;
|
udp_conns_t m_udp_conns;
|
||||||
|
|
||||||
typedef std::vector<boost::shared_ptr<http_tracker_connection> > http_conns_t;
|
typedef std::vector<boost::shared_ptr<http_tracker_connection> > http_conns_t;
|
||||||
|
|
|
@ -310,13 +310,28 @@ namespace libtorrent
|
||||||
, udp::endpoint const& ep, char const* buf, int size)
|
, udp::endpoint const& ep, char const* buf, int size)
|
||||||
{
|
{
|
||||||
// ignore packets smaller than 8 bytes
|
// ignore packets smaller than 8 bytes
|
||||||
if (size < 8) return false;
|
if (size < 8)
|
||||||
|
{
|
||||||
|
#if defined TORRENT_LOGGING
|
||||||
|
m_ses.debug_log("incoming packet from %s, not a UDP tracker message "
|
||||||
|
"(%d Bytes)", print_endpoint(*from).c_str(), size);
|
||||||
|
#endif
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
const char* ptr = buf + 4;
|
const char* ptr = buf + 4;
|
||||||
boost::uint32_t transaction = detail::read_uint32(ptr);
|
boost::uint32_t transaction = detail::read_uint32(ptr);
|
||||||
udp_conns_t::iterator i = m_udp_conns.find(transaction);
|
udp_conns_t::iterator i = m_udp_conns.find(transaction);
|
||||||
|
|
||||||
if (i == m_udp_conns.end()) return false;
|
if (i == m_udp_conns.end())
|
||||||
|
{
|
||||||
|
#if defined TORRENT_LOGGING
|
||||||
|
m_ses.debug_log("incoming UDP tracker packet from %s has invalid "
|
||||||
|
"transaction ID (%" PRIu32 ")", print_endpoint(*from).c_str()
|
||||||
|
, transaction);
|
||||||
|
#endif
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
boost::shared_ptr<tracker_connection> p = i->second;
|
boost::shared_ptr<tracker_connection> p = i->second;
|
||||||
// on_receive() may remove the tracker connection from the list
|
// on_receive() may remove the tracker connection from the list
|
||||||
|
@ -327,13 +342,27 @@ namespace libtorrent
|
||||||
, char const* hostname, char const* buf, int size)
|
, char const* hostname, char const* buf, int size)
|
||||||
{
|
{
|
||||||
// ignore packets smaller than 8 bytes
|
// ignore packets smaller than 8 bytes
|
||||||
if (size < 8) return false;
|
if (size < 8)
|
||||||
|
{
|
||||||
|
#if defined TORRENT_LOGGING
|
||||||
|
m_ses.debug_log("incoming packet from %s, not a UDP tracker message "
|
||||||
|
"(%d Bytes)", hostname, size);
|
||||||
|
#endif
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
const char* ptr = buf + 4;
|
const char* ptr = buf + 4;
|
||||||
boost::uint32_t transaction = detail::read_uint32(ptr);
|
boost::uint32_t transaction = detail::read_uint32(ptr);
|
||||||
udp_conns_t::iterator i = m_udp_conns.find(transaction);
|
udp_conns_t::iterator i = m_udp_conns.find(transaction);
|
||||||
|
|
||||||
if (i == m_udp_conns.end()) return false;
|
if (i == m_udp_conns.end())
|
||||||
|
{
|
||||||
|
#if defined TORRENT_LOGGING
|
||||||
|
m_ses.debug_log("incoming UDP tracker packet from %s has invalid "
|
||||||
|
"transaction ID (%x)", hostname, int(transaction));
|
||||||
|
#endif
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
boost::shared_ptr<tracker_connection> p = i->second;
|
boost::shared_ptr<tracker_connection> p = i->second;
|
||||||
// on_receive() may remove the tracker connection from the list
|
// on_receive() may remove the tracker connection from the list
|
||||||
|
|
|
@ -339,25 +339,46 @@ namespace libtorrent
|
||||||
bool udp_tracker_connection::on_receive(error_code const& e
|
bool udp_tracker_connection::on_receive(error_code const& e
|
||||||
, udp::endpoint const& ep, char const* buf, int size)
|
, udp::endpoint const& ep, char const* buf, int size)
|
||||||
{
|
{
|
||||||
// ignore resposes before we've sent any requests
|
#if defined TORRENT_LOGGING
|
||||||
if (m_state == action_error) return false;
|
boost::shared_ptr<request_callback> cb = requester();
|
||||||
|
#endif
|
||||||
|
|
||||||
if (m_abort) return false;
|
// ignore resposes before we've sent any requests
|
||||||
|
if (m_state == action_error)
|
||||||
|
{
|
||||||
|
#if defined TORRENT_LOGGING
|
||||||
|
if (cb) cb->debug_log("<== UDP_TRACKER [ m_action == error ]");
|
||||||
|
#endif
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (m_abort)
|
||||||
|
{
|
||||||
|
#if defined TORRENT_LOGGING
|
||||||
|
if (cb) cb->debug_log("<== UDP_TRACKER [ aborted]");
|
||||||
|
#endif
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
// ignore packet not sent from the tracker
|
// ignore packet not sent from the tracker
|
||||||
// if m_target is inaddr_any, it suggests that we
|
// if m_target is inaddr_any, it suggests that we
|
||||||
// sent the packet through a proxy only knowing
|
// sent the packet through a proxy only knowing
|
||||||
// the hostname, in which case this packet might be for us
|
// the hostname, in which case this packet might be for us
|
||||||
if (!is_any(m_target.address()) && m_target != ep) return false;
|
if (!is_any(m_target.address()) && m_target != ep)
|
||||||
|
{
|
||||||
|
#if defined TORRENT_LOGGING
|
||||||
|
if (cb) cb->debug_log("<== UDP_TRACKER [ unexpected source IP: %s "
|
||||||
|
"expected: %s ]"
|
||||||
|
, print_endpoint(ep).c_str()
|
||||||
|
, print_endpoint(m_target).c_str());
|
||||||
|
#endif
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
if (e) fail(e);
|
if (e) fail(e);
|
||||||
|
|
||||||
#if defined TORRENT_LOGGING
|
#if defined TORRENT_LOGGING
|
||||||
boost::shared_ptr<request_callback> cb = requester();
|
if (cb) cb->debug_log("<== UDP_TRACKER_PACKET [ size: %d ]", size);
|
||||||
if (cb)
|
|
||||||
{
|
|
||||||
cb->debug_log("<== UDP_TRACKER_PACKET [ size: %d ]", size);
|
|
||||||
}
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// ignore packets smaller than 8 bytes
|
// ignore packets smaller than 8 bytes
|
||||||
|
@ -368,14 +389,18 @@ namespace libtorrent
|
||||||
boost::uint32_t transaction = detail::read_uint32(ptr);
|
boost::uint32_t transaction = detail::read_uint32(ptr);
|
||||||
|
|
||||||
#if defined TORRENT_LOGGING
|
#if defined TORRENT_LOGGING
|
||||||
if (cb)
|
if (cb) cb->debug_log("*** UDP_TRACKER_PACKET [ action: %d ]", action);
|
||||||
{
|
|
||||||
cb->debug_log("*** UDP_TRACKER_PACKET [ action: %d ]", action);
|
|
||||||
}
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// ignore packets with incorrect transaction id
|
// ignore packets with incorrect transaction id
|
||||||
if (m_transaction_id != transaction) return false;
|
if (m_transaction_id != transaction)
|
||||||
|
{
|
||||||
|
#if defined TORRENT_LOGGING
|
||||||
|
if (cb) cb->debug_log("*** UDP_TRACKER_PACKET [ tid: %x ]"
|
||||||
|
, int(transaction));
|
||||||
|
#endif
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
if (action == action_error)
|
if (action == action_error)
|
||||||
{
|
{
|
||||||
|
@ -384,16 +409,21 @@ namespace libtorrent
|
||||||
}
|
}
|
||||||
|
|
||||||
// ignore packets that's not a response to our message
|
// ignore packets that's not a response to our message
|
||||||
if (action != m_state) return false;
|
if (action != m_state)
|
||||||
|
{
|
||||||
|
#if defined TORRENT_LOGGING
|
||||||
|
if (cb) cb->debug_log("*** UDP_TRACKER_PACKET [ unexpected action: %d "
|
||||||
|
" expected: %d ]", action, m_state);
|
||||||
|
#endif
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
restart_read_timeout();
|
restart_read_timeout();
|
||||||
|
|
||||||
#if defined TORRENT_LOGGING
|
#if defined TORRENT_LOGGING
|
||||||
if (cb)
|
if (cb)
|
||||||
{
|
|
||||||
cb->debug_log("*** UDP_TRACKER_RESPONSE [ tid: %x ]"
|
cb->debug_log("*** UDP_TRACKER_RESPONSE [ tid: %x ]"
|
||||||
, int(transaction));
|
, int(transaction));
|
||||||
}
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
switch (m_state)
|
switch (m_state)
|
||||||
|
|
|
@ -64,30 +64,30 @@ struct peer_server
|
||||||
m_acceptor.open(tcp::v4(), ec);
|
m_acceptor.open(tcp::v4(), ec);
|
||||||
if (ec)
|
if (ec)
|
||||||
{
|
{
|
||||||
fprintf(stderr, "Error opening peer listen socket: %s\n", ec.message().c_str());
|
fprintf(stderr, "PEER Error opening peer listen socket: %s\n", ec.message().c_str());
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
m_acceptor.bind(tcp::endpoint(address_v4::any(), 0), ec);
|
m_acceptor.bind(tcp::endpoint(address_v4::any(), 0), ec);
|
||||||
if (ec)
|
if (ec)
|
||||||
{
|
{
|
||||||
fprintf(stderr, "Error binding peer socket to port 0: %s\n", ec.message().c_str());
|
fprintf(stderr, "PEER Error binding peer socket to port 0: %s\n", ec.message().c_str());
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
m_port = m_acceptor.local_endpoint(ec).port();
|
m_port = m_acceptor.local_endpoint(ec).port();
|
||||||
if (ec)
|
if (ec)
|
||||||
{
|
{
|
||||||
fprintf(stderr, "Error getting local endpoint of peer socket: %s\n", ec.message().c_str());
|
fprintf(stderr, "PEER Error getting local endpoint of peer socket: %s\n", ec.message().c_str());
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
m_acceptor.listen(10, ec);
|
m_acceptor.listen(10, ec);
|
||||||
if (ec)
|
if (ec)
|
||||||
{
|
{
|
||||||
fprintf(stderr, "Error listening on peer socket: %s\n", ec.message().c_str());
|
fprintf(stderr, "PEER Error listening on peer socket: %s\n", ec.message().c_str());
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
fprintf(stderr, "%s: peer initialized on port %d\n", time_now_string(), m_port);
|
fprintf(stderr, "%s: PEER peer initialized on port %d\n", time_now_string(), m_port);
|
||||||
|
|
||||||
m_thread.reset(new thread(boost::bind(&peer_server::thread_fun, this)));
|
m_thread.reset(new thread(boost::bind(&peer_server::thread_fun, this)));
|
||||||
}
|
}
|
||||||
|
@ -130,11 +130,11 @@ struct peer_server
|
||||||
|
|
||||||
if (ec)
|
if (ec)
|
||||||
{
|
{
|
||||||
fprintf(stderr, "Error accepting connection on peer socket: %s\n", ec.message().c_str());
|
fprintf(stderr, "PEER Error accepting connection on peer socket: %s\n", ec.message().c_str());
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
fprintf(stderr, "%s: incoming peer connection\n", time_now_string());
|
fprintf(stderr, "%s: PEER incoming peer connection\n", time_now_string());
|
||||||
++m_peer_requests;
|
++m_peer_requests;
|
||||||
socket.close(ec);
|
socket.close(ec);
|
||||||
}
|
}
|
||||||
|
@ -158,8 +158,8 @@ int num_peer_hits()
|
||||||
|
|
||||||
void stop_peer()
|
void stop_peer()
|
||||||
{
|
{
|
||||||
fprintf(stderr, "%s: stop_peer()\n", time_now_string());
|
fprintf(stderr, "%s: PEER stop_peer()\n", time_now_string());
|
||||||
g_peer.reset();
|
g_peer.reset();
|
||||||
fprintf(stderr, "%s: stop_peer() done\n", time_now_string());
|
fprintf(stderr, "%s: PEER stop_peer() done\n", time_now_string());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -88,19 +88,24 @@ struct udp_tracker
|
||||||
{
|
{
|
||||||
case 0: // connect
|
case 0: // connect
|
||||||
|
|
||||||
fprintf(stderr, "%s: UDP connect from %s\n", time_now_string(), print_endpoint(*from).c_str());
|
fprintf(stderr, "%s: UDP connect from %s\n", time_now_string()
|
||||||
|
, print_endpoint(*from).c_str());
|
||||||
ptr = buffer;
|
ptr = buffer;
|
||||||
detail::write_uint32(0, ptr); // action = connect
|
detail::write_uint32(0, ptr); // action = connect
|
||||||
detail::write_uint32(transaction_id, ptr); // transaction_id
|
detail::write_uint32(transaction_id, ptr); // transaction_id
|
||||||
detail::write_uint64(10, ptr); // connection_id
|
detail::write_uint64(10, ptr); // connection_id
|
||||||
m_socket.send_to(asio::buffer(buffer, 16), *from, 0, e);
|
m_socket.send_to(asio::buffer(buffer, 16), *from, 0, e);
|
||||||
if (e) fprintf(stderr, "%s: send_to failed. ERROR: %s\n", time_now_string(), e.message().c_str());
|
if (e) fprintf(stderr, "%s: UDP send_to failed. ERROR: %s\n"
|
||||||
|
, time_now_string(), e.message().c_str());
|
||||||
|
else fprintf(stderr, "%s: UDP sent response to: %s\n"
|
||||||
|
, time_now_string(), print_endpoint(*from).c_str());
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 1: // announce
|
case 1: // announce
|
||||||
|
|
||||||
++m_udp_announces;
|
++m_udp_announces;
|
||||||
fprintf(stderr, "%s: UDP announce [%d]\n", time_now_string(), int(m_udp_announces));
|
fprintf(stderr, "%s: UDP announce [%d]\n", time_now_string()
|
||||||
|
, int(m_udp_announces));
|
||||||
ptr = buffer;
|
ptr = buffer;
|
||||||
detail::write_uint32(1, ptr); // action = announce
|
detail::write_uint32(1, ptr); // action = announce
|
||||||
detail::write_uint32(transaction_id, ptr); // transaction_id
|
detail::write_uint32(transaction_id, ptr); // transaction_id
|
||||||
|
@ -109,14 +114,18 @@ struct udp_tracker
|
||||||
detail::write_uint32(1, ptr); // complete
|
detail::write_uint32(1, ptr); // complete
|
||||||
// 0 peers
|
// 0 peers
|
||||||
m_socket.send_to(asio::buffer(buffer, 20), *from, 0, e);
|
m_socket.send_to(asio::buffer(buffer, 20), *from, 0, e);
|
||||||
if (e) fprintf(stderr, "%s: send_to failed. ERROR: %s\n", time_now_string(), e.message().c_str());
|
if (e) fprintf(stderr, "%s: UDP send_to failed. ERROR: %s\n"
|
||||||
|
, time_now_string(), e.message().c_str());
|
||||||
|
else fprintf(stderr, "%s: UDP sent response to: %s\n"
|
||||||
|
, time_now_string(), print_endpoint(*from).c_str());
|
||||||
break;
|
break;
|
||||||
case 2:
|
case 2:
|
||||||
// ignore scrapes
|
// ignore scrapes
|
||||||
fprintf(stderr, "%s: UDP scrape\n", time_now_string());
|
fprintf(stderr, "%s: UDP scrape (ignored)\n", time_now_string());
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
fprintf(stderr, "%s: UDP unknown message: %d\n", time_now_string(), action);
|
fprintf(stderr, "%s: UDP unknown message: %d\n", time_now_string()
|
||||||
|
, action);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -134,20 +143,20 @@ struct udp_tracker
|
||||||
m_socket.open(udp::v4(), ec);
|
m_socket.open(udp::v4(), ec);
|
||||||
if (ec)
|
if (ec)
|
||||||
{
|
{
|
||||||
fprintf(stderr, "Error opening listen UDP tracker socket: %s\n", ec.message().c_str());
|
fprintf(stderr, "UDP Error opening listen UDP tracker socket: %s\n", ec.message().c_str());
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
m_socket.bind(udp::endpoint(address_v4::any(), 0), ec);
|
m_socket.bind(udp::endpoint(address_v4::any(), 0), ec);
|
||||||
if (ec)
|
if (ec)
|
||||||
{
|
{
|
||||||
fprintf(stderr, "Error binding UDP tracker socket to port 0: %s\n", ec.message().c_str());
|
fprintf(stderr, "UDP Error binding UDP tracker socket to port 0: %s\n", ec.message().c_str());
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
m_port = m_socket.local_endpoint(ec).port();
|
m_port = m_socket.local_endpoint(ec).port();
|
||||||
if (ec)
|
if (ec)
|
||||||
{
|
{
|
||||||
fprintf(stderr, "Error getting local endpoint of UDP tracker socket: %s\n", ec.message().c_str());
|
fprintf(stderr, "UDP Error getting local endpoint of UDP tracker socket: %s\n", ec.message().c_str());
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -188,11 +197,11 @@ struct udp_tracker
|
||||||
|
|
||||||
if (ec)
|
if (ec)
|
||||||
{
|
{
|
||||||
fprintf(stderr, "Error running UDP tracker service: %s\n", ec.message().c_str());
|
fprintf(stderr, "UDP Error running UDP tracker service: %s\n", ec.message().c_str());
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
fprintf(stderr, "exiting UDP tracker thread\n");
|
fprintf(stderr, "UDP exiting UDP tracker thread\n");
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -213,8 +222,8 @@ int num_udp_announces()
|
||||||
|
|
||||||
void stop_udp_tracker()
|
void stop_udp_tracker()
|
||||||
{
|
{
|
||||||
fprintf(stderr, "%s: stop_udp_tracker()\n", time_now_string());
|
fprintf(stderr, "%s: UDP stop_udp_tracker()\n", time_now_string());
|
||||||
g_udp_tracker.reset();
|
g_udp_tracker.reset();
|
||||||
fprintf(stderr, "%s: stop_udp_tracker() done\n", time_now_string());
|
fprintf(stderr, "%s: UDP stop_udp_tracker() done\n", time_now_string());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue