-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathsm.go
70 lines (55 loc) · 2.61 KB
/
sm.go
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
package gopaxos
import "math"
const (
noCheckpoint = math.MaxUint64 - 1
)
type SMCtx struct {
SMID int64
Ctx interface{}
}
type CheckpointFileInfo struct {
FilePath string
FileSize uint64
}
type CheckpointFileInfoList []CheckpointFileInfo
type StateMachine interface {
//SMID return different SMID which specifies a unique sm.
SMID() int64
//Return true means execute success.
//This 'success' means this execute don't need to retry.
//Sometimes you will have some logical failure in your execute logic,
//and this failure will definite occur on all node, that means this failure is acceptable,
//for this case, return true is the best choice.
//Some system failure will let different node's execute result inconsistent,
//for this case, you must return false to retry this execute to avoid this system failure.
Execute(groupIdx int, instanceID uint64, paxosValue []byte, smCtx *SMCtx) bool
ExecuteForCheckpoint(groupIdx int, instanceID uint64, paxosValue []byte) bool
//Only need to implement this function while you have checkpoint.
//Return your checkpoint's max executed instance id.
//Notice PhxPaxos will call this function very frequently.
GetCheckpointInstanceID(groupIdx int) uint64
//After called this function, the vecFileList that GetCheckpointState return's,
//can't be deleted, moved and modified.
LockCheckpointState() error
//dirPath is checkpoint data root dir path.
//vecFileList is the relative path of the sDirPath.
GetCheckpointState(groupIdx int) (string, []string, error)
UnLockCheckpointState()
//Checkpoint file was on dir(sCheckpointTmpFileDirPath).
//vecFileList is all the file in dir(sCheckpointTmpFileDirPath).
//vecFileList filepath is absolute path.
//After called this function, paxoslib will kill the processor.
//State machine need to understand this when restart.
LoadCheckpointState(groupIdx int, checkpointTmpFileDirPath string, fileList []string, checkpointInstanceID uint64) error
//You can modify your request at this moment.
//At this moment, the state machine data will be up to date.
//If request is batch, propose requests for multiple identical state machines will only call this function once.
//Ensure that the execute function correctly recognizes the modified request.
//Since this function is not always called, the execute function must handle the unmodified request correctly.
BeforePropose(groupIdx int, value []byte) []byte
//Because function BeforePropose much waste cpu,
//Only NeedCallBeforePropose return true then will call function BeforePropose.
//You can use this function to control call frequency.
//Default is false.
NeedCallBeforePropose() bool
}