forked from premiere/premiere-libtorrent
change semantics of disk read time and add disk hash time
This commit is contained in:
parent
ff7bbc6cd0
commit
a08bcf7459
|
@ -853,6 +853,8 @@ Returns status of the disk cache for this session.
|
||||||
int total_used_buffers;
|
int total_used_buffers;
|
||||||
int average_queue_time;
|
int average_queue_time;
|
||||||
int average_read_time;
|
int average_read_time;
|
||||||
|
int average_write_time;
|
||||||
|
int average_hash_time;
|
||||||
int job_queue_length;
|
int job_queue_length;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -886,9 +888,18 @@ used in peer connections.
|
||||||
``average_queue_time`` is the number of microseconds an average disk I/O job
|
``average_queue_time`` is the number of microseconds an average disk I/O job
|
||||||
has to wait in the job queue before it get processed.
|
has to wait in the job queue before it get processed.
|
||||||
|
|
||||||
``average_read_time`` is the number of microseconds a read job takes to
|
``average_read_time`` is the time read jobs takes on average to complete
|
||||||
wait in the queue and complete, in microseconds. This only includes
|
(not including the time in the queue), in microseconds. This only measures
|
||||||
cache misses.
|
read cache misses.
|
||||||
|
|
||||||
|
``average_write_time`` is the time write jobs takes to complete, on average,
|
||||||
|
in microseconds. This does not include the time the job sits in the disk job
|
||||||
|
queue or in the write cache, only blocks that are flushed to disk.
|
||||||
|
|
||||||
|
``average_hash_time`` is the time hash jobs takes to complete on average, in
|
||||||
|
microseconds. Hash jobs include running SHA-1 on the data (which for the most
|
||||||
|
part is done incrementally) and sometimes reading back parts of the piece. It
|
||||||
|
also includes checking files without valid resume data.
|
||||||
|
|
||||||
``job_queue_length`` is the number of jobs in the job queue.
|
``job_queue_length`` is the number of jobs in the job queue.
|
||||||
|
|
||||||
|
|
|
@ -170,6 +170,7 @@ namespace libtorrent
|
||||||
, average_queue_time(0)
|
, average_queue_time(0)
|
||||||
, average_read_time(0)
|
, average_read_time(0)
|
||||||
, average_write_time(0)
|
, average_write_time(0)
|
||||||
|
, average_hash_time(0)
|
||||||
, job_queue_length(0)
|
, job_queue_length(0)
|
||||||
{}
|
{}
|
||||||
|
|
||||||
|
@ -204,6 +205,7 @@ namespace libtorrent
|
||||||
int average_queue_time;
|
int average_queue_time;
|
||||||
int average_read_time;
|
int average_read_time;
|
||||||
int average_write_time;
|
int average_write_time;
|
||||||
|
int average_hash_time;
|
||||||
int job_queue_length;
|
int job_queue_length;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -429,13 +431,16 @@ namespace libtorrent
|
||||||
cache_status m_cache_stats;
|
cache_status m_cache_stats;
|
||||||
|
|
||||||
// keeps average queue time for disk jobs (in microseconds)
|
// keeps average queue time for disk jobs (in microseconds)
|
||||||
sliding_average<4096> m_queue_time;
|
sliding_average<512> m_queue_time;
|
||||||
|
|
||||||
// average read time for cache misses (in microseconds)
|
// average read time for cache misses (in microseconds)
|
||||||
sliding_average<4096> m_read_time;
|
sliding_average<512> m_read_time;
|
||||||
|
|
||||||
// average write time (in microseconds)
|
// average write time (in microseconds)
|
||||||
sliding_average<4096> m_write_time;
|
sliding_average<512> m_write_time;
|
||||||
|
|
||||||
|
// average hash time (in microseconds)
|
||||||
|
sliding_average<512> m_hash_time;
|
||||||
|
|
||||||
typedef std::multimap<size_type, disk_io_job> read_jobs_t;
|
typedef std::multimap<size_type, disk_io_job> read_jobs_t;
|
||||||
read_jobs_t m_sorted_read_jobs;
|
read_jobs_t m_sorted_read_jobs;
|
||||||
|
|
|
@ -59,7 +59,7 @@ gen_report('peer_errors', ['error peers', 'peer disconnects', 'peers eof', 'peer
|
||||||
gen_report('piece_picker_end_game', ['end game piece picker blocks', 'strict end game piece picker blocks', 'piece picker blocks', 'piece picks', 'reject piece picks', 'unchoked piece picks', 'incoming redundant piece picks', 'incoming piece picks', 'end game piece picks', 'snubbed piece picks'])
|
gen_report('piece_picker_end_game', ['end game piece picker blocks', 'strict end game piece picker blocks', 'piece picker blocks', 'piece picks', 'reject piece picks', 'unchoked piece picks', 'incoming redundant piece picks', 'incoming piece picks', 'end game piece picks', 'snubbed piece picks'])
|
||||||
gen_report('piece_picker', ['piece picks', 'reject piece picks', 'unchoked piece picks', 'incoming redundant piece picks', 'incoming piece picks', 'end game piece picks', 'snubbed piece picks'])
|
gen_report('piece_picker', ['piece picks', 'reject piece picks', 'unchoked piece picks', 'incoming redundant piece picks', 'incoming piece picks', 'end game piece picks', 'snubbed piece picks'])
|
||||||
gen_report('bandwidth', ['% failed payload bytes', '% wasted payload bytes', '% protocol bytes'])
|
gen_report('bandwidth', ['% failed payload bytes', '% wasted payload bytes', '% protocol bytes'])
|
||||||
gen_report('disk_time', ['disk read time', 'disk write time', 'disk queue time'])
|
gen_report('disk_time', ['disk read time', 'disk write time', 'disk queue time', 'disk hash time'])
|
||||||
gen_report('disk_cache_hits', ['disk block read', 'read cache hits', 'disk block written'])
|
gen_report('disk_cache_hits', ['disk block read', 'read cache hits', 'disk block written'])
|
||||||
gen_report('disk_cache', ['read disk cache size', 'disk cache size', 'disk buffer allocations'])
|
gen_report('disk_cache', ['read disk cache size', 'disk cache size', 'disk buffer allocations'])
|
||||||
gen_report('disk_queue', ['disk queue size', 'disk queued bytes'])
|
gen_report('disk_queue', ['disk queue size', 'disk queued bytes'])
|
||||||
|
|
|
@ -1966,6 +1966,7 @@ namespace libtorrent
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
ptime read_start = time_now_hires();
|
||||||
disk_buffer_holder read_holder(*this, j.buffer);
|
disk_buffer_holder read_holder(*this, j.buffer);
|
||||||
|
|
||||||
bool hit;
|
bool hit;
|
||||||
|
@ -2006,8 +2007,7 @@ namespace libtorrent
|
||||||
}
|
}
|
||||||
if (!hit)
|
if (!hit)
|
||||||
{
|
{
|
||||||
ptime now = time_now_hires();
|
m_read_time.add_sample(total_microseconds(time_now_hires() - read_start));
|
||||||
m_read_time.add_sample(total_microseconds(now - j.start_time));
|
|
||||||
}
|
}
|
||||||
TORRENT_ASSERT(j.buffer == read_holder.get());
|
TORRENT_ASSERT(j.buffer == read_holder.get());
|
||||||
read_holder.release();
|
read_holder.release();
|
||||||
|
@ -2133,6 +2133,8 @@ namespace libtorrent
|
||||||
mutex::scoped_lock l(m_piece_mutex);
|
mutex::scoped_lock l(m_piece_mutex);
|
||||||
INVARIANT_CHECK;
|
INVARIANT_CHECK;
|
||||||
|
|
||||||
|
ptime hash_start = time_now_hires();
|
||||||
|
|
||||||
cache_piece_index_t& idx = m_pieces.get<0>();
|
cache_piece_index_t& idx = m_pieces.get<0>();
|
||||||
cache_piece_index_t::iterator i = find_cached_piece(m_pieces, j, l);
|
cache_piece_index_t::iterator i = find_cached_piece(m_pieces, j, l);
|
||||||
if (i != idx.end())
|
if (i != idx.end())
|
||||||
|
@ -2163,6 +2165,8 @@ namespace libtorrent
|
||||||
|
|
||||||
ret = (j.storage->info()->hash_for_piece(j.piece) == h)?0:-2;
|
ret = (j.storage->info()->hash_for_piece(j.piece) == h)?0:-2;
|
||||||
if (ret == -2) j.storage->mark_failed(j.piece);
|
if (ret == -2) j.storage->mark_failed(j.piece);
|
||||||
|
|
||||||
|
m_hash_time.add_sample(total_microseconds(time_now_hires() - hash_start));
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case disk_io_job::move_storage:
|
case disk_io_job::move_storage:
|
||||||
|
@ -2313,10 +2317,13 @@ namespace libtorrent
|
||||||
m_last_file_check = time_now_hires();
|
m_last_file_check = time_now_hires();
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
ptime hash_start = time_now_hires();
|
||||||
if (m_waiting_to_shutdown) break;
|
if (m_waiting_to_shutdown) break;
|
||||||
|
|
||||||
ret = j.storage->check_files(j.piece, j.offset, j.error);
|
ret = j.storage->check_files(j.piece, j.offset, j.error);
|
||||||
|
|
||||||
|
m_hash_time.add_sample(total_microseconds(time_now_hires() - hash_start));
|
||||||
|
|
||||||
TORRENT_TRY {
|
TORRENT_TRY {
|
||||||
TORRENT_ASSERT(j.callback);
|
TORRENT_ASSERT(j.callback);
|
||||||
if (j.callback && ret == piece_manager::need_full_check)
|
if (j.callback && ret == piece_manager::need_full_check)
|
||||||
|
|
|
@ -939,6 +939,7 @@ namespace aux {
|
||||||
":read disk cache size"
|
":read disk cache size"
|
||||||
":disk cache size"
|
":disk cache size"
|
||||||
":disk buffer allocations"
|
":disk buffer allocations"
|
||||||
|
":disk hash time"
|
||||||
"\n\n", m_stats_logger);
|
"\n\n", m_stats_logger);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
@ -2783,6 +2784,7 @@ namespace aux {
|
||||||
, cs.read_cache_size
|
, cs.read_cache_size
|
||||||
, cs.cache_size
|
, cs.cache_size
|
||||||
, cs.total_used_buffers
|
, cs.total_used_buffers
|
||||||
|
, int(cs.average_hash_time)
|
||||||
);
|
);
|
||||||
m_last_cache_status = cs;
|
m_last_cache_status = cs;
|
||||||
m_last_failed = m_total_failed_bytes;
|
m_last_failed = m_total_failed_bytes;
|
||||||
|
|
Loading…
Reference in New Issue