main.go 994 B

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051
  1. package main
  2. import (
  3. "log"
  4. "os"
  5. "igit.com/xbase/raft"
  6. "igit.com/xbase/raft/example/basic/common"
  7. )
  8. func main() {
  9. // Configuration
  10. nodeID := "node4"
  11. addr := "127.0.0.1:9004"
  12. dataDir := "../data/node4"
  13. // Standalone configuration
  14. clusterNodes := map[string]string{
  15. "node4": "127.0.0.1:9004",
  16. }
  17. config := raft.DefaultConfig()
  18. config.NodeID = nodeID
  19. config.ListenAddr = addr
  20. config.DataDir = dataDir
  21. config.ClusterNodes = clusterNodes
  22. config.LogCompactionEnabled = false
  23. config.Logger = raft.NewConsoleLogger(nodeID, 1)
  24. if err := os.MkdirAll(dataDir, 0755); err != nil {
  25. log.Fatalf("Failed to create data directory: %v", err)
  26. }
  27. server, err := raft.NewKVServer(config)
  28. if err != nil {
  29. log.Fatalf("Failed to create server: %v", err)
  30. }
  31. // Register demo commands
  32. common.RegisterDemoCommands(server.CLI)
  33. if err := server.Start(); err != nil {
  34. log.Fatalf("Failed to start server: %v", err)
  35. }
  36. defer server.Stop()
  37. // Keep main thread running
  38. select {}
  39. }