我有 4nodes 2001、2002、2003 和 2004 的集群。它们是使用 goraft 绑定的。假设 2001 是主服务器。现在当它失败时,另一个节点成为服务器。现在我想要的是,成为当前服务器的节点应该发送消息,我是新的领导者。那么如何实现呢?我正在将 GORAFT 与 GORAFD 实现一起使用。我在这里附上源代码。
main.go - 对于客户端
package main
import (
"flag"
"fmt"
"github.com/goraft/raft"
"github.com/goraft/raftd/command"
"github.com/goraft/raftd/server"
"log"
"math/rand"
"os"
"time"
"strconv"
)
var verbose bool
var trace bool
var debug bool
var host string
var port int
var join string
func init() {
flag.Parse()
flag.BoolVar(&verbose, "v", false, "verbose logging")
flag.BoolVar(&trace, "trace", false, "Raft trace debugging")
flag.BoolVar(&debug, "debug", false, "Raft debugging")
flag.StringVar(&host, "h", "localhost", "hostname")
p,_:=strconv.Atoi(flag.Arg(1))
flag.IntVar(&port, "p", p, "port")
flag.StringVar(&join, "join", "", "host:port of leader to join")
flag.Usage = func() {
fmt.Fprintf(os.Stderr, "Usage: %s [arguments] <data-path> \n", os.Args[0])
flag.PrintDefaults()
}
}
func main() {
log.SetFlags(0)
flag.Parse()
if verbose {
log.Print("Verbose logging enabled.")
}
if trace {
raft.SetLogLevel(raft.Trace)
log.Print("Raft trace debugging enabled.")
} else if debug {
raft.SetLogLevel(raft.Debug)
log.Print("Raft debugging enabled.")
}
rand.Seed(time.Now().UnixNano())
// Setup commands.
raft.RegisterCommand(&command.WriteCommand{})
// Set the data directory.
if flag.NArg() == 0 {
flag.Usage()
log.Fatal("Data path argument required")
}
path := flag.Arg(0)
if err := os.MkdirAll(path, 0744); err != nil {
log.Fatalf("Unable to create path: %v", err)
}
log.SetFlags(log.LstdFlags)
s := server.New(path, host, port)
log.Fatal(s.ListenAndServe("localhost:2001"))
fmt.Println("I am changing my status");
}
米琪卡哇伊
相关分类