extended stats logging
This commit is contained in:
parent
5456f2ac91
commit
bf77ee4199
|
@ -1,3 +1,4 @@
|
||||||
|
* extended stats logging with statistics=on builds
|
||||||
* added new session functions to more efficiently query torrent status
|
* added new session functions to more efficiently query torrent status
|
||||||
* added alerts for added and removed torrents
|
* added alerts for added and removed torrents
|
||||||
* expanded plugin interface to support session wide states
|
* expanded plugin interface to support session wide states
|
||||||
|
|
|
@ -864,6 +864,9 @@ namespace libtorrent
|
||||||
// logger used to write bandwidth usage statistics
|
// logger used to write bandwidth usage statistics
|
||||||
std::ofstream m_stats_logger;
|
std::ofstream m_stats_logger;
|
||||||
int m_second_counter;
|
int m_second_counter;
|
||||||
|
// the number of peers that were disconnected this
|
||||||
|
// tick due to protocol error
|
||||||
|
int m_error_peers;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// each second tick the timer takes a little
|
// each second tick the timer takes a little
|
||||||
|
|
|
@ -3315,6 +3315,11 @@ namespace libtorrent
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifdef TORRENT_STATS
|
||||||
|
if (error == 2) ++m_ses.m_error_peers;
|
||||||
|
#endif
|
||||||
|
|
||||||
// we cannot do this in a constructor
|
// we cannot do this in a constructor
|
||||||
TORRENT_ASSERT(m_in_constructor == false);
|
TORRENT_ASSERT(m_in_constructor == false);
|
||||||
if (error > 0) m_failed = true;
|
if (error > 0) m_failed = true;
|
||||||
|
|
|
@ -786,15 +786,23 @@ namespace aux {
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef TORRENT_STATS
|
#ifdef TORRENT_STATS
|
||||||
|
//#error log wasted bytes, failed bytes, peers disconnected with an error, disk buffer usage
|
||||||
m_stats_logger.open("session_stats.log", std::ios::trunc);
|
m_stats_logger.open("session_stats.log", std::ios::trunc);
|
||||||
m_stats_logger <<
|
m_stats_logger <<
|
||||||
"second:upload rate:download rate:downloading torrents:seeding torrents"
|
"second:upload rate:download rate:downloading torrents:seeding torrents"
|
||||||
":peers:connecting peers:disk block buffers:unchoked peers:num list peers"
|
":peers:connecting peers:disk block buffers:num list peers"
|
||||||
":peer allocations:peer storage bytes:checking torrents:stopped torrents"
|
":peer allocations:peer storage bytes:checking torrents:stopped torrents"
|
||||||
":peers bw-up:peers bw-down:peers disk-up:peers disk-down"
|
":peers bw-up:peers bw-down:peers disk-up:peers disk-down"
|
||||||
":smooth upload rate:smooth download rate:disk write queued bytes"
|
":smooth upload rate:smooth download rate:disk write queued bytes"
|
||||||
":peers 0-10:peers 10-50:peers 50-100:peers 100-500:peers 500-1000:peers 1000-\n\n";
|
":peers down 0:peers down 0-10:peers down 10-50:peers down 50-100:peers down 100-500"
|
||||||
|
":peers down 500-1000:peers down 1000-"
|
||||||
|
":peers up 0:peers up 0-10:peers up 10-50:peers up 50-100:peers up 100-500: peers up 500-1000"
|
||||||
|
":peers up 1000-:error peers"
|
||||||
|
":peers down interesting:peers down unchoked:peers down requests"
|
||||||
|
":peers up interested:peers up unchoked:peers up requests"
|
||||||
|
"\n\n";
|
||||||
m_second_counter = 0;
|
m_second_counter = 0;
|
||||||
|
m_error_peers = 0;
|
||||||
#endif
|
#endif
|
||||||
#ifdef TORRENT_DISK_STATS
|
#ifdef TORRENT_DISK_STATS
|
||||||
m_buffer_usage_logger.open("buffer_stats.log", std::ios::trunc);
|
m_buffer_usage_logger.open("buffer_stats.log", std::ios::trunc);
|
||||||
|
@ -2514,9 +2522,15 @@ namespace aux {
|
||||||
downloaded = m_stat.total_download();
|
downloaded = m_stat.total_download();
|
||||||
uploaded = m_stat.total_upload();
|
uploaded = m_stat.total_upload();
|
||||||
size_type num_peers = 0;
|
size_type num_peers = 0;
|
||||||
int peer_dl_rate_buckets[6];
|
int peer_dl_rate_buckets[7];
|
||||||
|
int peer_ul_rate_buckets[7];
|
||||||
memset(peer_dl_rate_buckets, 0, sizeof(peer_dl_rate_buckets));
|
memset(peer_dl_rate_buckets, 0, sizeof(peer_dl_rate_buckets));
|
||||||
|
memset(peer_ul_rate_buckets, 0, sizeof(peer_ul_rate_buckets));
|
||||||
|
|
||||||
|
int peers_up_interested = 0;
|
||||||
|
int peers_down_interesting = 0;
|
||||||
|
int peers_up_requests = 0;
|
||||||
|
int peers_down_requests = 0;
|
||||||
for (torrent_map::iterator i = m_torrents.begin()
|
for (torrent_map::iterator i = m_torrents.begin()
|
||||||
, end(m_torrents.end()); i != end; ++i)
|
, end(m_torrents.end()); i != end; ++i)
|
||||||
{
|
{
|
||||||
|
@ -2533,34 +2547,48 @@ namespace aux {
|
||||||
}
|
}
|
||||||
int num_complete_connections = 0;
|
int num_complete_connections = 0;
|
||||||
int num_half_open = 0;
|
int num_half_open = 0;
|
||||||
int unchoked_peers = 0;
|
int peers_down_unchoked = 0;
|
||||||
|
int peers_up_unchoked = 0;
|
||||||
for (connection_map::iterator i = m_connections.begin()
|
for (connection_map::iterator i = m_connections.begin()
|
||||||
, end(m_connections.end()); i != end; ++i)
|
, end(m_connections.end()); i != end; ++i)
|
||||||
{
|
{
|
||||||
peer_connection* p = i->get();
|
peer_connection* p = i->get();
|
||||||
if (p->is_connecting())
|
if (p->is_connecting())
|
||||||
++num_half_open;
|
|
||||||
else
|
|
||||||
{
|
{
|
||||||
++num_complete_connections;
|
++num_half_open;
|
||||||
if (!p->is_choked()) ++unchoked_peers;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
int bucket = 0;
|
++num_complete_connections;
|
||||||
|
if (!p->is_choked()) ++peers_up_unchoked;
|
||||||
|
if (!p->has_peer_choked()) ++peers_down_unchoked;
|
||||||
|
if (!p->download_queue().empty()) ++peers_down_requests;
|
||||||
|
if (p->is_peer_interested()) ++peers_up_interested;
|
||||||
|
if (p->is_interesting()) ++peers_down_interesting;
|
||||||
|
if (p->send_buffer_size() > 20) ++peers_up_requests;
|
||||||
|
|
||||||
|
int dl_bucket = 0;
|
||||||
int dl_rate = p->statistics().download_rate();
|
int dl_rate = p->statistics().download_rate();
|
||||||
if (dl_rate < 10000)
|
if (dl_rate == 0) dl_bucket = 0;
|
||||||
bucket = 0;
|
else if (dl_rate < 10000) dl_bucket = 1;
|
||||||
else if (dl_rate < 50000)
|
else if (dl_rate < 50000) dl_bucket = 2;
|
||||||
bucket = 1;
|
else if (dl_rate < 100000) dl_bucket = 3;
|
||||||
else if (dl_rate < 100000)
|
else if (dl_rate < 500000) dl_bucket = 4;
|
||||||
bucket = 2;
|
else if (dl_rate < 1000000) dl_bucket = 5;
|
||||||
else if (dl_rate < 500000)
|
else dl_bucket = 6;
|
||||||
bucket = 3;
|
|
||||||
else if (dl_rate < 1000000)
|
int ul_rate = p->statistics().upload_rate();
|
||||||
bucket = 4;
|
int ul_bucket = 0;
|
||||||
else
|
if (ul_rate == 0) dl_bucket = 0;
|
||||||
bucket = 5;
|
else if (ul_rate < 10000) dl_bucket = 1;
|
||||||
++peer_dl_rate_buckets[bucket];
|
else if (ul_rate < 50000) dl_bucket = 2;
|
||||||
|
else if (ul_rate < 100000) dl_bucket = 3;
|
||||||
|
else if (ul_rate < 500000) dl_bucket = 4;
|
||||||
|
else if (ul_rate < 1000000) dl_bucket = 5;
|
||||||
|
else ul_bucket = 6;
|
||||||
|
|
||||||
|
++peer_dl_rate_buckets[dl_bucket];
|
||||||
|
++peer_ul_rate_buckets[ul_bucket];
|
||||||
}
|
}
|
||||||
|
|
||||||
m_stats_logger
|
m_stats_logger
|
||||||
|
@ -2572,7 +2600,6 @@ namespace aux {
|
||||||
<< num_complete_connections << "\t"
|
<< num_complete_connections << "\t"
|
||||||
<< num_half_open << "\t"
|
<< num_half_open << "\t"
|
||||||
<< m_disk_thread.disk_allocations() << "\t"
|
<< m_disk_thread.disk_allocations() << "\t"
|
||||||
<< unchoked_peers << "\t"
|
|
||||||
<< num_peers << "\t"
|
<< num_peers << "\t"
|
||||||
<< logging_allocator::allocations << "\t"
|
<< logging_allocator::allocations << "\t"
|
||||||
<< logging_allocator::allocated_bytes << "\t"
|
<< logging_allocator::allocated_bytes << "\t"
|
||||||
|
@ -2591,7 +2618,23 @@ namespace aux {
|
||||||
<< peer_dl_rate_buckets[3] << "\t"
|
<< peer_dl_rate_buckets[3] << "\t"
|
||||||
<< peer_dl_rate_buckets[4] << "\t"
|
<< peer_dl_rate_buckets[4] << "\t"
|
||||||
<< peer_dl_rate_buckets[5] << "\t"
|
<< peer_dl_rate_buckets[5] << "\t"
|
||||||
|
<< peer_dl_rate_buckets[6] << "\t"
|
||||||
|
<< peer_ul_rate_buckets[0] << "\t"
|
||||||
|
<< peer_ul_rate_buckets[1] << "\t"
|
||||||
|
<< peer_ul_rate_buckets[2] << "\t"
|
||||||
|
<< peer_ul_rate_buckets[3] << "\t"
|
||||||
|
<< peer_ul_rate_buckets[4] << "\t"
|
||||||
|
<< peer_ul_rate_buckets[5] << "\t"
|
||||||
|
<< peer_ul_rate_buckets[6] << "\t"
|
||||||
|
<< m_error_peers << "\t"
|
||||||
|
<< peers_down_interesting << "\t"
|
||||||
|
<< peers_down_unchoked << "\t"
|
||||||
|
<< peers_down_requests << "\t"
|
||||||
|
<< peers_up_interested << "\t"
|
||||||
|
<< peers_up_unchoked << "\t"
|
||||||
|
<< peers_up_requests << "\t"
|
||||||
<< std::endl;
|
<< std::endl;
|
||||||
|
m_error_peers = 0;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// --------------------------------------------------------------
|
// --------------------------------------------------------------
|
||||||
|
|
Loading…
Reference in New Issue