remove get drainstatus api

This commit is contained in:
yanmingfan
2018-06-21 17:36:05 +08:00
parent cf3b66555b
commit 7bdda2c9d6
2 changed files with 21 additions and 43 deletions

View File

@@ -38,10 +38,6 @@ func Register(ws *restful.WebService, subPath string) {
ws.Route(ws.POST(subPath+"/{nodename}/drainage").To(handleDrainNode).Filter(route.RouteLogging)). ws.Route(ws.POST(subPath+"/{nodename}/drainage").To(handleDrainNode).Filter(route.RouteLogging)).
Consumes(restful.MIME_JSON, restful.MIME_XML). Consumes(restful.MIME_JSON, restful.MIME_XML).
Produces(restful.MIME_JSON) Produces(restful.MIME_JSON)
ws.Route(ws.GET(subPath+"/{nodename}/drainage").To(handleDrainStatus).Filter(route.RouteLogging)).
Consumes(restful.MIME_JSON, restful.MIME_XML).
Produces(restful.MIME_JSON)
} }
func MakeRequest(node string, ch chan<- metrics.NodeMetrics) { func MakeRequest(node string, ch chan<- metrics.NodeMetrics) {
@@ -94,20 +90,3 @@ func handleDrainNode(request *restful.Request, response *restful.Response) {
} }
} }
func handleDrainStatus(request *restful.Request, response *restful.Response) {
nodeName := request.PathParameter("nodename")
result, err := metrics.DrainStatus(nodeName)
if err != nil {
response.WriteHeaderAndEntity(http.StatusInternalServerError, constants.MessageResponse{Message: err.Error()})
} else {
response.WriteAsJson(result)
}
}

View File

@@ -251,17 +251,27 @@ func DrainNode(nodename string) (msg constants.MessageResponse, err error) {
data := []byte(" {\"spec\":{\"unschedulable\":true}}") data := []byte(" {\"spec\":{\"unschedulable\":true}}")
nodestatus, err := k8sclient.CoreV1().Nodes().Patch(nodename, types.StrategicMergePatchType, data) nodestatus, err := k8sclient.CoreV1().Nodes().Patch(nodename, types.StrategicMergePatchType, data)
glog.Info(nodestatus)
if err != nil { if err != nil {
glog.Fatal(err) glog.Fatal(err)
return msg, err return msg, err
} }
msg.Message = "success" glog.Info(nodestatus)
return msg, nil donech := make(chan bool)
errch := make(chan error)
go drainEviction(nodename, donech, errch)
for {
select {
case err := <-errch:
return msg, err
case <-donech:
msg.Message = "success"
return msg, nil
}
}
} }
func DrainStatus(nodename string) (msg constants.MessageResponse, err error) { func drainEviction(nodename string, donech chan bool, errch chan error) {
k8sclient := kubeclient.NewK8sClient() k8sclient := kubeclient.NewK8sClient()
var options metav1.ListOptions var options metav1.ListOptions
@@ -269,10 +279,8 @@ func DrainStatus(nodename string) (msg constants.MessageResponse, err error) {
options.FieldSelector = "spec.nodeName=" + nodename options.FieldSelector = "spec.nodeName=" + nodename
podList, err := k8sclient.CoreV1().Pods("").List(options) podList, err := k8sclient.CoreV1().Pods("").List(options)
if err != nil { if err != nil {
glog.Fatal(err) glog.Fatal(err)
return msg, err errch <- err
} }
options.FieldSelector = "" options.FieldSelector = ""
daemonsetList, err := k8sclient.AppsV1beta2().DaemonSets("").List(options) daemonsetList, err := k8sclient.AppsV1beta2().DaemonSets("").List(options)
@@ -280,7 +288,7 @@ func DrainStatus(nodename string) (msg constants.MessageResponse, err error) {
if err != nil { if err != nil {
glog.Fatal(err) glog.Fatal(err)
return msg, err errch <- err
} }
// remove mirror pod static pod // remove mirror pod static pod
@@ -295,16 +303,11 @@ func DrainStatus(nodename string) (msg constants.MessageResponse, err error) {
} else { } else {
pods = append(pods, pod) pods = append(pods, pod)
} }
} }
} }
} }
if len(pods) == 0 { if len(pods) == 0 {
donech <- true
msg.Message = fmt.Sprintf("success")
return msg, nil
} else { } else {
//create eviction //create eviction
@@ -315,14 +318,10 @@ func DrainStatus(nodename string) (msg constants.MessageResponse, err error) {
evicerr := evictPods(pods, 0, getPodFn) evicerr := evictPods(pods, 0, getPodFn)
if evicerr == nil { if evicerr == nil {
donech <- true
msg.Message = fmt.Sprintf("success")
return msg, nil
} else { } else {
glog.Fatal(evicerr)
glog.Info(evicerr) errch <- err
return msg, evicerr
} }
} }