mirror of
https://github.com/dragonflydb/dragonfly.git
synced 2025-05-11 10:25:47 +02:00
Improve eviction policy design for dash table
This commit is contained in:
parent
cceb0d90ca
commit
4fcb74930e
8 changed files with 201 additions and 58 deletions
|
@ -96,11 +96,14 @@ class DbSlice {
|
|||
expire_base_[generation & 1] = now;
|
||||
}
|
||||
|
||||
void SetMaxMemory(size_t max_memory) {
|
||||
max_memory_ = max_memory;
|
||||
}
|
||||
|
||||
uint64_t expire_base() const {
|
||||
return expire_base_[0];
|
||||
}
|
||||
|
||||
|
||||
// returns wall clock in millis as it has been set via UpdateExpireClock.
|
||||
uint64_t Now() const {
|
||||
return now_ms_;
|
||||
|
@ -224,6 +227,7 @@ class DbSlice {
|
|||
uint64_t expire_base_[2]; // Used for expire logic, represents a real clock.
|
||||
|
||||
uint64_t version_ = 1; // Used to version entries in the PrimeTable.
|
||||
uint64_t max_memory_ = -1;
|
||||
mutable SliceEvents events_; // we may change this even for const operations.
|
||||
|
||||
using LockTable = absl::flat_hash_map<std::string, IntentLock>;
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue