Browse Source

minor adjustment for weed master nodes clustering

pull/2/head
Chris Lu 11 years ago
parent
commit
6887e55f6a
  1. 11
      go/weed/weed_server/raft_server.go
  2. 7
      go/weed/weed_server/raft_server_handlers.go

11
go/weed/weed_server/raft_server.go

@ -32,10 +32,12 @@ func NewRaftServer(r *mux.Router, version string, peers []string, httpAddr strin
router: r, router: r,
} }
//raft.SetLogLevel(2)
if glog.V(4) {
raft.SetLogLevel(2)
}
var err error var err error
transporter := raft.NewHTTPTransporter("/raft")
transporter := raft.NewHTTPTransporter("/cluster")
s.raftServer, err = raft.NewServer(s.httpAddr, s.dataDir, transporter, nil, nil, "") s.raftServer, err = raft.NewServer(s.httpAddr, s.dataDir, transporter, nil, nil, "")
if err != nil { if err != nil {
glog.V(0).Infoln(err) glog.V(0).Infoln(err)
@ -46,7 +48,8 @@ func NewRaftServer(r *mux.Router, version string, peers []string, httpAddr strin
s.raftServer.SetElectionTimeout(1500 * time.Millisecond) s.raftServer.SetElectionTimeout(1500 * time.Millisecond)
s.raftServer.Start() s.raftServer.Start()
s.router.HandleFunc("/raft/join", s.joinHandler).Methods("POST")
s.router.HandleFunc("/cluster/join", s.joinHandler).Methods("POST")
s.router.HandleFunc("/cluster/status", s.statusHandler).Methods("GET")
// Join to leader if specified. // Join to leader if specified.
if len(s.peers) > 0 { if len(s.peers) > 0 {
@ -117,7 +120,7 @@ func (s *RaftServer) Join(peers []string) error {
for _, m := range peers { for _, m := range peers {
glog.V(0).Infoln("Attempting to connect to:", m) glog.V(0).Infoln("Attempting to connect to:", m)
resp, err := http.Post(fmt.Sprintf("http://%s/raft/join", strings.TrimSpace(m)), "application/json", &b)
resp, err := http.Post(fmt.Sprintf("http://%s/cluster/join", strings.TrimSpace(m)), "application/json", &b)
glog.V(0).Infoln("Post returned: ", err) glog.V(0).Infoln("Post returned: ", err)
if err != nil { if err != nil {

7
go/weed/weed_server/raft_server_handlers.go

@ -44,3 +44,10 @@ func (s *RaftServer) redirectToLeader(w http.ResponseWriter, req *http.Request)
http.Error(w, "Leader unknown", http.StatusInternalServerError) http.Error(w, "Leader unknown", http.StatusInternalServerError)
} }
} }
func (s *RaftServer) statusHandler(w http.ResponseWriter, r *http.Request) {
m := make(map[string]interface{})
m["Leader"] = s.Leader()
m["Members"] = s.Members()
writeJsonQuiet(w, r, m)
}
Loading…
Cancel
Save