Rainbond/pkg/api/region/node.go

249 lines
6.0 KiB
Go
Raw Normal View History

package region
import (
"github.com/goodrain/rainbond/pkg/node/api/model"
"bytes"
"net/http"
"io/ioutil"
"encoding/json"
"github.com/bitly/go-simplejson"
2017-11-22 18:46:17 +08:00
"github.com/Sirupsen/logrus"
"fmt"
)
var nodeServer *RNodeServer
func NewNode(nodeAPI string) {
if nodeServer==nil {
nodeServer=&RNodeServer{
2017-11-23 16:13:45 +08:00
NodeAPI:nodeAPI,
}
}
}
func GetNode() *RNodeServer {
return nodeServer
}
type RNodeServer struct {
2017-11-23 16:13:45 +08:00
NodeAPI string
}
func (r *RNodeServer)Tasks() TaskInterface {
return &Task{}
}
func (r *RNodeServer)Nodes() NodeInterface {
return &Node{}
}
type Task struct {
2017-11-23 16:13:45 +08:00
TaskID string `json:"task_id"`
}
type Node struct {
2017-11-23 16:13:45 +08:00
Id string
Node *model.HostNode `json:"node"`
}
type TaskInterface interface {
Get(name string) (*Task)
Exec(nodes []string ) error
}
type NodeInterface interface {
Add(node *model.APIHostNode)
Delete()
Rule(rule string) []*model.HostNode
2017-11-22 18:46:17 +08:00
Get(node string) *Node
List() []*model.HostNode
Up()
Down()
UnSchedulable()
ReSchedulable()
Label(label map[string]string)
}
func (t *Node)Label(label map[string]string) {
body,_:=json.Marshal(label)
2017-11-27 15:59:02 +08:00
_,_,err:=nodeServer.Request("/nodes/"+t.Id+"/labels","PUT",body)
if err != nil {
logrus.Errorf("error details %s",err.Error())
}
}
func (t *Node)Add(node *model.APIHostNode) {
body,_:=json.Marshal(node)
2017-11-27 12:06:28 +08:00
_,_,err:=nodeServer.Request("/nodes","POST",body)
if err != nil {
logrus.Errorf("error details %s",err.Error())
}
}
func (t *Node) Delete() {
_,_,err:=nodeServer.Request("/nodes/"+t.Id,"DELETE",nil)
if err != nil {
logrus.Errorf("error details %s",err.Error())
}
}
2017-11-22 18:46:17 +08:00
func (t *Node)Up() {
2017-11-23 16:13:45 +08:00
nodeServer.Request("/nodes/"+t.Id+"/up","POST",nil)
2017-11-22 18:46:17 +08:00
}
func (t *Node)Down() {
2017-11-23 16:13:45 +08:00
nodeServer.Request("/nodes/"+t.Id+"/down","POST",nil)
2017-11-22 18:46:17 +08:00
}
func (t *Node)UnSchedulable() {
2017-11-23 16:13:45 +08:00
nodeServer.Request("/nodes/"+t.Id+"/unschedulable","PUT",nil)
2017-11-22 18:46:17 +08:00
}
func (t *Node)ReSchedulable() {
2017-11-23 16:13:45 +08:00
nodeServer.Request("/nodes/"+t.Id+"/reschedulable","PUT",nil)
2017-11-22 18:46:17 +08:00
}
2017-11-22 18:46:17 +08:00
func (t *Node)Get(node string) *Node {
2017-11-23 16:13:45 +08:00
body,_,err:=nodeServer.Request("/nodes/"+node,"GET",nil)
2017-11-22 18:46:17 +08:00
if err != nil {
2017-11-23 16:13:45 +08:00
logrus.Errorf("error get node %s,details %s",node,err.Error())
2017-11-22 18:46:17 +08:00
return nil
}
2017-11-23 16:13:45 +08:00
t.Id=node
2017-11-22 18:46:17 +08:00
var stored model.HostNode
2017-11-23 16:13:45 +08:00
j,err:=simplejson.NewJson(body)
2017-11-22 18:46:17 +08:00
if err != nil {
2017-11-23 16:13:45 +08:00
logrus.Errorf("error get node %s 's json,details %s",node,err.Error())
2017-11-22 18:46:17 +08:00
return nil
}
2017-11-23 16:13:45 +08:00
bean:=j.Get("bean")
n,err:=json.Marshal(bean)
if err != nil {
logrus.Errorf("error get bean from response,details %s",err.Error())
return nil
}
err=json.Unmarshal([]byte(n),&stored)
if err != nil {
logrus.Errorf("error unmarshal node %s,details %s",node,err.Error())
return nil
}
t.Node=&stored
2017-11-22 18:46:17 +08:00
return t
}
func (t *Node)Rule(rule string) []*model.HostNode {
body,_,err:=nodeServer.Request("/nodes/"+rule,"GET",nil)
if err != nil {
logrus.Errorf("error get rule %s ,details %s",rule,err.Error())
return nil
}
j,err:=simplejson.NewJson(body)
if err != nil {
logrus.Errorf("error get json ,details %s",err.Error())
return nil
}
nodeArr,err:=j.Get("list").Array()
if err != nil {
logrus.Infof("error occurd,details %s",err.Error())
return nil
}
jsonA, _ := json.Marshal(nodeArr)
nodes := []*model.HostNode{}
err=json.Unmarshal(jsonA, &nodes)
if err != nil {
logrus.Infof("error occurd,details %s",err.Error())
return nil
}
return nodes
}
2017-11-22 18:46:17 +08:00
func (t *Node)List() []*model.HostNode {
2017-11-23 16:13:45 +08:00
body,_,err:=nodeServer.Request("/nodes","GET",nil)
if err != nil {
logrus.Errorf("error get nodes ,details %s",err.Error())
return nil
}
j,err:=simplejson.NewJson(body)
if err != nil {
logrus.Errorf("error get json ,details %s",err.Error())
return nil
2017-11-23 16:13:45 +08:00
}
2017-11-22 18:46:17 +08:00
nodeArr,err:=j.Get("list").Array()
if err != nil {
logrus.Infof("error occurd,details %s",err.Error())
return nil
}
jsonA, _ := json.Marshal(nodeArr)
nodes := []*model.HostNode{}
err=json.Unmarshal(jsonA, &nodes)
if err != nil {
logrus.Infof("error occurd,details %s",err.Error())
return nil
}
return nodes
}
func (t *Task)Get(id string) (*Task) {
return &Task{
2017-11-23 16:13:45 +08:00
TaskID:id,
}
}
func (t *Task)Exec(nodes []string ) error {
2017-11-23 16:13:45 +08:00
taskId:=t.TaskID
var nodesBody struct {
Nodes []string `json:"nodes"`
}
nodesBody.Nodes=nodes
body,_:=json.Marshal(nodesBody)
url:="/tasks/"+taskId+"/exec"
2017-11-23 16:13:45 +08:00
resp,code,err:=nodeServer.Request(url,"POST",body)
if code != 200 {
fmt.Println("executing failed:"+string(resp))
}
if err!=nil {
return err
}
return err
}
type TaskStatus struct {
Status map[string]model.TaskStatus `json:"status,omitempty"`
}
func (t *Task)Status() (*TaskStatus,error) {
2017-11-23 16:13:45 +08:00
taskId:=t.TaskID
2017-11-28 11:22:04 +08:00
return HandleTaskStatus(taskId)
}
func HandleTaskStatus(task string) (*TaskStatus,error) {
resp,code,err:=nodeServer.Request("/tasks/"+task+"/status","GET",nil)
if err != nil {
2017-11-23 16:13:45 +08:00
logrus.Errorf("error execute status Request,details %s",err.Error())
return nil,err
}
if code == 200 {
2017-11-28 11:22:04 +08:00
j, _ := simplejson.NewJson(resp)
bean := j.Get("bean")
beanB, _ := json.Marshal(bean)
var status TaskStatus
2017-11-27 19:24:59 +08:00
2017-11-28 11:22:04 +08:00
json,_:=simplejson.NewJson(beanB)
second:=json.Interface()
2017-11-27 19:24:59 +08:00
2017-11-28 11:22:04 +08:00
logrus.Infof("second level is %v",second)
m:=second.(map[string]interface{})
for k,_:=range m {
var taskStatus model.TaskStatus
logrus.Infof("handling %s status",k)
taskStatus.CompleStatus=m[k].(map[string]interface{})["comple_status"].(string)
taskStatus.Status=m[k].(map[string]interface{})["status"].(string)
taskStatus.JobID=k
taskStatus.ShellCode=m[k].(map[string]interface{})["shell_code"].(int)
status.Status[k]=taskStatus
}
return &status,nil
}
return nil,nil
}
2017-11-23 16:13:45 +08:00
func (r *RNodeServer)Request(url ,method string, body []byte) ([]byte,int,error) {
2017-11-28 11:22:04 +08:00
logrus.Infof("requesting url: %s by method :%s,and body is ",r.NodeAPI+url,method,string(body))
2017-11-23 16:13:45 +08:00
request, err := http.NewRequest(method, r.NodeAPI+url, bytes.NewBuffer(body))
if err != nil {
return nil,500,err
}
request.Header.Set("Content-Type", "application/json")
res, err := http.DefaultClient.Do(request)
if err != nil {
return nil, 500,err
}
data, err := ioutil.ReadAll(res.Body)
defer res.Body.Close()
2017-11-27 12:06:28 +08:00
logrus.Infof("response is %s,response code is %d",string(data),res.StatusCode)
return data,res.StatusCode,err
}