improved shutdown behavior. decreased tracker timeouts to 5 seconds. added more logging

This commit is contained in:
Arvid Norberg 2007-10-07 18:06:56 +00:00
parent b51f40260a
commit 28274bf1bd
5 changed files with 34 additions and 10 deletions

View File

@ -85,7 +85,7 @@ namespace libtorrent
: user_agent(user_agent_) : user_agent(user_agent_)
, tracker_completion_timeout(60) , tracker_completion_timeout(60)
, tracker_receive_timeout(20) , tracker_receive_timeout(20)
, stop_tracker_timeout(10) , stop_tracker_timeout(5)
, tracker_maximum_response_length(1024*1024) , tracker_maximum_response_length(1024*1024)
, piece_timeout(120) , piece_timeout(120)
, request_queue_time(3.f) , request_queue_time(3.f)

View File

@ -234,6 +234,7 @@ namespace libtorrent
void remove_request(tracker_connection const*); void remove_request(tracker_connection const*);
bool empty() const; bool empty() const;
int num_requests() const;
private: private:

View File

@ -638,11 +638,26 @@ namespace detail
void session_impl::abort() void session_impl::abort()
{ {
mutex_t::scoped_lock l(m_mutex); mutex_t::scoped_lock l(m_mutex);
TORRENT_ASSERT(!m_abort); if (m_abort) return;
m_io_service.stop();
#if defined(TORRENT_LOGGING)
(*m_logger) << time_now_string() << " *** ABORT CALLED ***\n";
#endif
// abort the main thread // abort the main thread
m_abort = true; m_abort = true;
m_io_service.stop(); if (m_lsd) m_lsd->close();
l.unlock(); if (m_upnp) m_upnp->close();
if (m_natpmp) m_natpmp->close();
#ifndef TORRENT_DISABLE_DHT
if (m_dht) m_dht->stop();
#endif
m_timer.cancel();
// abort all torrents
for (torrent_map::iterator i = m_torrents.begin()
, end(m_torrents.end()); i != end; ++i)
{
i->second->abort();
}
mutex::scoped_lock l2(m_checker_impl.m_mutex); mutex::scoped_lock l2(m_checker_impl.m_mutex);
// abort the checker thread // abort the checker thread
@ -1031,17 +1046,17 @@ namespace detail
// too expensive // too expensive
// INVARIANT_CHECK; // INVARIANT_CHECK;
if (m_abort) return;
if (e) if (e)
{ {
#if defined(TORRENT_LOGGING) #if defined(TORRENT_LOGGING)
(*m_logger) << "*** SECOND TIMER FAILED " << e.message() << "\n"; (*m_logger) << "*** SECOND TIMER FAILED " << e.message() << "\n";
#endif #endif
m_abort = true; abort();
m_io_service.stop();
return; return;
} }
if (m_abort) return;
float tick_interval = total_microseconds(time_now() - m_last_tick) / 1000000.f; float tick_interval = total_microseconds(time_now() - m_last_tick) / 1000000.f;
m_last_tick = time_now(); m_last_tick = time_now();
@ -1488,6 +1503,10 @@ namespace detail
m_settings.stop_tracker_timeout) m_settings.stop_tracker_timeout)
&& !m_tracker_manager.empty()) && !m_tracker_manager.empty())
{ {
#if defined(TORRENT_VERBOSE_LOGGING) || defined(TORRENT_LOGGING)
(*m_logger) << time_now_string() << " " << m_tracker_manager.num_requests()
<< " tracker requests pending\n";
#endif
tracker_timer.expires_from_now(milliseconds(100)); tracker_timer.expires_from_now(milliseconds(100));
tracker_timer.async_wait(m_strand.wrap( tracker_timer.async_wait(m_strand.wrap(
bind(&io_service::stop, &m_io_service))); bind(&io_service::stop, &m_io_service)));
@ -2072,9 +2091,7 @@ namespace detail
session_impl::~session_impl() session_impl::~session_impl()
{ {
#ifndef TORRENT_DISABLE_DHT abort();
stop_dht();
#endif
#if defined(TORRENT_VERBOSE_LOGGING) || defined(TORRENT_LOGGING) #if defined(TORRENT_VERBOSE_LOGGING) || defined(TORRENT_LOGGING)
(*m_logger) << time_now_string() << "\n\n *** shutting down session *** \n\n"; (*m_logger) << time_now_string() << "\n\n *** shutting down session *** \n\n";

View File

@ -1029,6 +1029,7 @@ namespace libtorrent
bind(&torrent::on_files_released, shared_from_this(), _1, _2)); bind(&torrent::on_files_released, shared_from_this(), _1, _2));
m_owning_storage = 0; m_owning_storage = 0;
m_announce_timer.cancel();
} }
void torrent::on_files_released(int ret, disk_io_job const& j) void torrent::on_files_released(int ret, disk_io_job const& j)

View File

@ -584,4 +584,9 @@ namespace libtorrent
return m_connections.empty(); return m_connections.empty();
} }
int tracker_manager::num_requests() const
{
mutex_t::scoped_lock l(m_mutex);
return m_connections.size();
}
} }