-
Notifications
You must be signed in to change notification settings - Fork 27
/
flusher.hh
102 lines (82 loc) · 2.32 KB
/
flusher.hh
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
/* -*- Mode: C++; tab-width: 4; c-basic-offset: 4; indent-tabs-mode: nil -*- */
#ifndef FLUSHER_H
#define FLUSHER_H 1
#include "common.hh"
#include "ep.hh"
#include "dispatcher.hh"
enum flusher_state {
initializing,
running,
pausing,
paused,
stopping,
stopped
};
class Flusher;
const double DEFAULT_MIN_SLEEP_TIME = 0.1;
/**
* A DispatcherCallback adaptor over Flusher.
*/
class FlusherStepper : public DispatcherCallback {
public:
FlusherStepper(Flusher* f) : flusher(f) { }
bool callback(Dispatcher &d, TaskId t);
std::string description() {
return std::string("Running a flusher loop.");
}
hrtime_t maxExpectedDuration() {
// Flusher can take a while, but let's report if it runs for
// more than ten minutes.
return 10 * 60 * 1000 * 1000;
}
private:
Flusher *flusher;
};
/**
* Manage persistence of data for an EventuallyPersistentStore.
*/
class Flusher {
public:
Flusher(EventuallyPersistentStore *st, Dispatcher *d) :
store(st), _state(initializing), dispatcher(d),
flushRv(0), prevFlushRv(0), minSleepTime(0.1), flushQueue(NULL) {
}
~Flusher() {
if (_state != stopped) {
getLogger()->log(EXTENSION_LOG_WARNING, NULL,
"Flusher being destroyed in state %s\n",
stateName(_state));
}
}
bool stop();
void wait();
bool pause();
bool resume();
void initialize(TaskId);
void start(void);
void wake(void);
bool step(Dispatcher&, TaskId);
enum flusher_state state() const;
const char * stateName() const;
private:
bool transition_state(enum flusher_state to);
int doFlush();
void completeFlush();
void schedule_UNLOCKED();
double computeMinSleepTime();
EventuallyPersistentStore *store;
volatile enum flusher_state _state;
Mutex taskMutex;
TaskId task;
Dispatcher *dispatcher;
const char * stateName(enum flusher_state st) const;
// Current flush cycle state.
int flushRv;
int prevFlushRv;
double minSleepTime;
std::queue<QueuedItem> *flushQueue;
std::queue<QueuedItem> *rejectQueue;
rel_time_t flushStart;
DISALLOW_COPY_AND_ASSIGN(Flusher);
};
#endif /* FLUSHER_H */