Fix O(n) algorithm in INFO command
This commit is contained in:
parent
4c1f54da78
commit
5047e64dee
@ -1142,8 +1142,7 @@ struct redisMemOverhead *getMemoryOverheadData(void) {
|
|||||||
mem_total+=mem;
|
mem_total+=mem;
|
||||||
|
|
||||||
std::unique_lock<fastlock> ul(g_expireLock);
|
std::unique_lock<fastlock> ul(g_expireLock);
|
||||||
mem = db->setexpire()->bytes_used();
|
mem = db->setexpire()->estimated_bytes_used();
|
||||||
|
|
||||||
mh->db[mh->num_dbs].overhead_ht_expires = mem;
|
mh->db[mh->num_dbs].overhead_ht_expires = mem;
|
||||||
mem_total+=mem;
|
mem_total+=mem;
|
||||||
|
|
||||||
|
@ -240,14 +240,12 @@ public:
|
|||||||
bool empty() const noexcept { return celem == 0; }
|
bool empty() const noexcept { return celem == 0; }
|
||||||
size_t size() const noexcept { return celem; }
|
size_t size() const noexcept { return celem; }
|
||||||
|
|
||||||
size_t bytes_used() const
|
size_t estimated_bytes_used() const
|
||||||
{
|
{
|
||||||
size_t cb = sizeof(this) + (m_data.capacity()-m_data.size())*sizeof(T);
|
// This estimate does't include all the overhead of the internal vectors
|
||||||
for (auto &vec : m_data)
|
size_t cb = sizeof(this)
|
||||||
{
|
+ (m_data.capacity() * sizeof(m_data[0]))
|
||||||
if (vec != nullptr)
|
+ sizeof(T) * size();
|
||||||
cb += vec->bytes_used();
|
|
||||||
}
|
|
||||||
return cb;
|
return cb;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user