-
Notifications
You must be signed in to change notification settings - Fork 7
/
Copy pathhealth.go
90 lines (74 loc) · 2.38 KB
/
health.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
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
package balancer
import (
"sync"
"time"
)
const (
WriteSetStateSync int = 4
)
// ServerHealth represents a Server health state
type ServerHealth struct {
sync.Mutex
up bool
err error
ioRunning bool
wsrepReady bool
lastUpdate time.Time
secondsBehindMaster *int
openConnections *int
runningConnections *int
wsrepLocalState *int
}
// IsUP returns if the server is UP
func (h *ServerHealth) IsUP() bool {
h.Lock()
defer h.Unlock()
return h.up
}
// GetErr returns server's last error
func (h *ServerHealth) GetErr() error {
return h.err
}
// GetSecondsBehindMaster returns server's seconds behind master
func (h *ServerHealth) GetSecondsBehindMaster() *int {
return h.secondsBehindMaster
}
// GetWriteSetReplicationState returns server's wsrep_local_state
func (h *ServerHealth) GetWriteSetReplicationState() *int {
return h.wsrepLocalState
}
// GetWriteSetReady returns server's wsrep_ready
func (h *ServerHealth) GetWriteSetReady() bool {
return h.wsrepReady
}
// GetOpenConnections returns server's open connections
func (h *ServerHealth) GetOpenConnections() *int {
return h.openConnections
}
// GetRunningConnections returns the number of connections that are not sleeping.
func (h *ServerHealth) GetRunningConnections() *int {
return h.runningConnections
}
// GetSlaveRunning returns the IO status from slave
func (h *ServerHealth) IORunning() bool {
return h.ioRunning
}
func (h *ServerHealth) setStatus(up, ioRunning, wsrepReady bool, err error, secondsBehindMaster, openConnections, runningConnections, wsrepLocalState *int) {
h.Lock()
defer h.Unlock()
h.up = up
h.ioRunning = ioRunning
h.err = err
h.secondsBehindMaster = secondsBehindMaster
h.wsrepLocalState = wsrepLocalState
h.wsrepReady = wsrepReady
h.openConnections = openConnections
h.runningConnections = runningConnections
h.lastUpdate = time.Now()
}
func (h *ServerHealth) setUP(err error, ioRunning, wsrepReady bool, secondsBehindMaster, openConnections, runningConnections, wsrepLocalState *int) {
h.setStatus(true, ioRunning, wsrepReady, err, secondsBehindMaster, openConnections, runningConnections, wsrepLocalState)
}
func (h *ServerHealth) setDown(err error, ioRunning, wsrepReady bool, secondsBehindMaster, openConnections, runningConnections, wsrepLocalState *int) {
h.setStatus(false, ioRunning, wsrepReady, err, secondsBehindMaster, openConnections, runningConnections, wsrepLocalState)
}