mirror of
https://github.com/codex-storage/deluge.git
synced 2025-01-15 05:54:24 +00:00
fast reconnect fixes
This commit is contained in:
parent
7d98d49803
commit
b403530fab
@ -176,13 +176,7 @@ namespace libtorrent
|
|||||||
void set_non_prioritized(bool b)
|
void set_non_prioritized(bool b)
|
||||||
{ m_non_prioritized = b; }
|
{ m_non_prioritized = b; }
|
||||||
|
|
||||||
void fast_reconnect(bool r)
|
void fast_reconnect(bool r);
|
||||||
{
|
|
||||||
if (peer_info_struct() && peer_info_struct()->fast_reconnects > 0) return;
|
|
||||||
m_fast_reconnect = r;
|
|
||||||
if (peer_info_struct()) ++peer_info_struct()->fast_reconnects;
|
|
||||||
|
|
||||||
}
|
|
||||||
bool fast_reconnect() const { return m_fast_reconnect; }
|
bool fast_reconnect() const { return m_fast_reconnect; }
|
||||||
|
|
||||||
// this adds an announcement in the announcement queue
|
// this adds an announcement in the announcement queue
|
||||||
|
@ -99,7 +99,7 @@ namespace libtorrent
|
|||||||
, allow_multiple_connections_per_ip(false)
|
, allow_multiple_connections_per_ip(false)
|
||||||
, max_failcount(3)
|
, max_failcount(3)
|
||||||
, min_reconnect_time(60)
|
, min_reconnect_time(60)
|
||||||
, peer_connect_timeout(10)
|
, peer_connect_timeout(7)
|
||||||
, ignore_limits_on_local_network(true)
|
, ignore_limits_on_local_network(true)
|
||||||
, connection_speed(20)
|
, connection_speed(20)
|
||||||
, send_redundant_have(false)
|
, send_redundant_have(false)
|
||||||
|
@ -204,7 +204,6 @@ namespace libtorrent
|
|||||||
|
|
||||||
// if this fails, we need to reconnect
|
// if this fails, we need to reconnect
|
||||||
// fast.
|
// fast.
|
||||||
pi->connected = time_now() - seconds(m_ses.settings().min_reconnect_time);
|
|
||||||
fast_reconnect(true);
|
fast_reconnect(true);
|
||||||
|
|
||||||
write_pe1_2_dhkey();
|
write_pe1_2_dhkey();
|
||||||
|
@ -394,6 +394,16 @@ namespace libtorrent
|
|||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void peer_connection::fast_reconnect(bool r)
|
||||||
|
{
|
||||||
|
if (peer_info_struct() && peer_info_struct()->fast_reconnects > 1) return;
|
||||||
|
m_fast_reconnect = r;
|
||||||
|
peer_info_struct()->connected = time_now()
|
||||||
|
- seconds(m_ses.settings().min_reconnect_time
|
||||||
|
* m_ses.settings().max_failcount);
|
||||||
|
if (peer_info_struct()) ++peer_info_struct()->fast_reconnects;
|
||||||
|
}
|
||||||
|
|
||||||
void peer_connection::announce_piece(int index)
|
void peer_connection::announce_piece(int index)
|
||||||
{
|
{
|
||||||
// dont announce during handshake
|
// dont announce during handshake
|
||||||
@ -1922,7 +1932,6 @@ namespace libtorrent
|
|||||||
|
|
||||||
void peer_connection::timed_out()
|
void peer_connection::timed_out()
|
||||||
{
|
{
|
||||||
if (m_peer_info) ++m_peer_info->failcount;
|
|
||||||
#if defined(TORRENT_VERBOSE_LOGGING) || defined(TORRENT_LOGGING)
|
#if defined(TORRENT_VERBOSE_LOGGING) || defined(TORRENT_LOGGING)
|
||||||
(*m_ses.m_logger) << "CONNECTION TIMED OUT: " << m_remote.address().to_string()
|
(*m_ses.m_logger) << "CONNECTION TIMED OUT: " << m_remote.address().to_string()
|
||||||
<< "\n";
|
<< "\n";
|
||||||
|
@ -986,7 +986,8 @@ namespace libtorrent
|
|||||||
i->second.prev_amount_upload = 0;
|
i->second.prev_amount_upload = 0;
|
||||||
i->second.connection = &c;
|
i->second.connection = &c;
|
||||||
TORRENT_ASSERT(i->second.connection);
|
TORRENT_ASSERT(i->second.connection);
|
||||||
i->second.connected = time_now();
|
if (!c.fast_reconnect())
|
||||||
|
i->second.connected = time_now();
|
||||||
// m_last_optimistic_disconnect = time_now();
|
// m_last_optimistic_disconnect = time_now();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -569,8 +569,19 @@ namespace detail
|
|||||||
, m_checker_impl(*this)
|
, m_checker_impl(*this)
|
||||||
{
|
{
|
||||||
#ifdef WIN32
|
#ifdef WIN32
|
||||||
// windows XP has a limit of 10 simultaneous connections
|
// windows XP has a limit on the number of
|
||||||
m_half_open.limit(8);
|
// simultaneous half-open TCP connections
|
||||||
|
DWORD windows_version = ::GetVersion();
|
||||||
|
if ((windows_version & 0xff) >= 6)
|
||||||
|
{
|
||||||
|
// on vista the limit is 5 (in home edition)
|
||||||
|
m_half_open.limit(4);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
// on XP SP2 it's 10
|
||||||
|
m_half_open.limit(8);
|
||||||
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
m_bandwidth_manager[peer_connection::download_channel] = &m_download_channel;
|
m_bandwidth_manager[peer_connection::download_channel] = &m_download_channel;
|
||||||
|
@ -1678,8 +1678,6 @@ namespace libtorrent
|
|||||||
|
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
TORRENT_ASSERT(m_connections.find(a) == m_connections.end());
|
|
||||||
|
|
||||||
// add the newly connected peer to this torrent's peer list
|
// add the newly connected peer to this torrent's peer list
|
||||||
TORRENT_ASSERT(m_connections.find(a) == m_connections.end());
|
TORRENT_ASSERT(m_connections.find(a) == m_connections.end());
|
||||||
m_connections.insert(
|
m_connections.insert(
|
||||||
@ -1893,10 +1891,13 @@ namespace libtorrent
|
|||||||
std::make_pair(a, boost::get_pointer(c)));
|
std::make_pair(a, boost::get_pointer(c)));
|
||||||
m_ses.m_connections.insert(std::make_pair(s, c));
|
m_ses.m_connections.insert(std::make_pair(s, c));
|
||||||
|
|
||||||
|
int timeout = settings().peer_connect_timeout;
|
||||||
|
if (peerinfo) timeout += 3 * peerinfo->failcount;
|
||||||
|
|
||||||
m_ses.m_half_open.enqueue(
|
m_ses.m_half_open.enqueue(
|
||||||
bind(&peer_connection::connect, c, _1)
|
bind(&peer_connection::connect, c, _1)
|
||||||
, bind(&peer_connection::timed_out, c)
|
, bind(&peer_connection::timed_out, c)
|
||||||
, seconds(settings().peer_connect_timeout));
|
, seconds(timeout));
|
||||||
}
|
}
|
||||||
catch (std::exception& e)
|
catch (std::exception& e)
|
||||||
{
|
{
|
||||||
@ -2400,8 +2401,6 @@ namespace libtorrent
|
|||||||
|
|
||||||
piece_manager& torrent::filesystem()
|
piece_manager& torrent::filesystem()
|
||||||
{
|
{
|
||||||
INVARIANT_CHECK;
|
|
||||||
|
|
||||||
TORRENT_ASSERT(m_owning_storage.get());
|
TORRENT_ASSERT(m_owning_storage.get());
|
||||||
return *m_owning_storage;
|
return *m_owning_storage;
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user