/
checks.go
95 lines (73 loc) · 2.75 KB
/
checks.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
91
92
93
94
95
/*
Copyright 2018 The Rook Authors. All rights reserved.
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
*/
package sidecar
import (
"fmt"
"github.com/rook/rook/pkg/operator/cassandra/constants"
"github.com/yanniszark/go-nodetool/nodetool"
"net/http"
)
// setupHTTPChecks brings up the liveness and readiness probes
func (m *MemberController) setupHTTPChecks() error {
http.HandleFunc(constants.LivenessProbePath, livenessCheck(m))
http.HandleFunc(constants.ReadinessProbePath, readinessCheck(m))
err := http.ListenAndServe(fmt.Sprintf("0.0.0.0:%d", constants.ProbePort), nil)
// If ListenAndServe returns, something went wrong
m.logger.Fatalf("Error in HTTP checks: %s", err.Error())
return err
}
func livenessCheck(m *MemberController) func(http.ResponseWriter, *http.Request) {
return func(w http.ResponseWriter, req *http.Request) {
status := http.StatusOK
// Check if JMX is reachable
_, err := m.nodetool.Status()
if err != nil {
m.logger.Errorf("Liveness check failed with error: %s", err.Error())
status = http.StatusServiceUnavailable
}
w.WriteHeader(status)
}
}
func readinessCheck(m *MemberController) func(http.ResponseWriter, *http.Request) {
return func(w http.ResponseWriter, req *http.Request) {
status := http.StatusOK
err := func() error {
// Contact Cassandra to learn about the status of the member
HostIDMap, err := m.nodetool.Status()
if err != nil {
return fmt.Errorf("Error while executing nodetool status in readiness check: %s", err.Error())
}
// Get local node through static ip
localNode, ok := HostIDMap[m.ip]
if !ok {
return fmt.Errorf("Couldn't find node with ip %s in nodetool status.", m.ip)
}
// Check local node status
// Up means the member is alive
if localNode.Status != nodetool.NodeStatusUp {
return fmt.Errorf("Unexpected local node status: %s", localNode.Status)
}
// Check local node state
// Normal means that the member has completed bootstrap and joined the cluster
if localNode.State != nodetool.NodeStateNormal {
return fmt.Errorf("Unexpected local node state: %s", localNode.State)
}
return nil
}()
if err != nil {
m.logger.Errorf("Readiness check failed with error: %s", err.Error())
status = http.StatusServiceUnavailable
}
w.WriteHeader(status)
}
}