extended stats logging

This commit is contained in:
Arvid Norberg 2011-02-03 06:22:22 +00:00
parent 5456f2ac91
commit bf77ee4199
4 changed files with 75 additions and 23 deletions

View File

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

View File

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

View File

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

View File

@ -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
// -------------------------------------------------------------- // --------------------------------------------------------------