2014-02-15 09:10:49 +08:00
|
|
|
package operation
|
|
|
|
|
|
|
|
import (
|
2014-10-27 02:34:55 +08:00
|
|
|
"encoding/json"
|
|
|
|
|
2016-06-03 09:09:14 +08:00
|
|
|
"github.com/chrislusf/seaweedfs/weed/glog"
|
|
|
|
"github.com/chrislusf/seaweedfs/weed/util"
|
2014-02-15 09:10:49 +08:00
|
|
|
)
|
|
|
|
|
|
|
|
type ClusterStatusResult struct {
|
2014-04-16 00:30:08 +08:00
|
|
|
IsLeader bool `json:"IsLeader,omitempty"`
|
|
|
|
Leader string `json:"Leader,omitempty"`
|
|
|
|
Peers []string `json:"Peers,omitempty"`
|
2014-02-15 09:10:49 +08:00
|
|
|
}
|
|
|
|
|
2017-01-14 02:20:40 +08:00
|
|
|
func ListMasters(server string) (leader string, peers []string, err error) {
|
2014-02-15 09:10:49 +08:00
|
|
|
jsonBlob, err := util.Get("http://" + server + "/cluster/status")
|
|
|
|
glog.V(2).Info("list masters result :", string(jsonBlob))
|
|
|
|
if err != nil {
|
2017-01-14 02:20:40 +08:00
|
|
|
return "", nil, err
|
2014-02-15 09:10:49 +08:00
|
|
|
}
|
|
|
|
var ret ClusterStatusResult
|
|
|
|
err = json.Unmarshal(jsonBlob, &ret)
|
|
|
|
if err != nil {
|
2017-01-14 02:20:40 +08:00
|
|
|
return "", nil, err
|
2014-02-15 09:10:49 +08:00
|
|
|
}
|
2017-01-14 02:20:40 +08:00
|
|
|
peers = ret.Peers
|
2014-03-03 14:16:54 +08:00
|
|
|
if ret.IsLeader {
|
2017-01-14 02:20:40 +08:00
|
|
|
peers = append(peers, ret.Leader)
|
2014-03-03 14:16:54 +08:00
|
|
|
}
|
2017-01-14 02:20:40 +08:00
|
|
|
return ret.Leader, peers, nil
|
2014-02-15 09:10:49 +08:00
|
|
|
}
|