generated from openacid/gotmpl
-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathpropose.go
55 lines (48 loc) · 1.09 KB
/
propose.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
package traft
// request sent to Loop() to propose a cmd
type proposeReq struct {
cmd *Cmd
finCh chan *ProposeReply
}
func (tr *TRaft) hdlPropose(cmd *Cmd, finCh chan<- *ProposeReply) {
id := tr.Id
me := tr.Status[id]
now := uSecondI64()
if now > me.VoteExpireAt {
lg.Infow("hdl-propose:VoteExpired", "me.VoteExpireAt-now", me.VoteExpireAt-now)
// no valid leader for now
finCh <- &ProposeReply{
OK: false,
Err: "vote expired",
}
lg.Infow("hdl-propose: returning")
return
}
if me.VotedFor.Id != id {
finCh <- &ProposeReply{
OK: false,
Err: "I am not leader",
OtherLeader: me.VotedFor.Clone(),
}
return
}
rec := tr.AddLog(cmd)
lg.Infow("hdl-propose:added-rec", "rec", rec.ShortStr(), "rec.Overrides:", rec.Overrides.DebugStr())
me.Accepted.Union(rec.Overrides)
go tr.forwardLog(
me.VotedFor.Clone(),
tr.Config.Clone(),
[]*LogRecord{rec},
func(rst *logForwardRst) {
if rst.err != nil {
finCh <- &ProposeReply{
OK: false,
Err: rst.err.Error(),
}
} else {
finCh <- &ProposeReply{
OK: true,
}
}
})
}