remove get drainstatus api
This commit is contained in:
@@ -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)
|
|
||||||
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|||||||
@@ -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
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user