main.go 1.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556
  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 := "node1"
  11. addr := "127.0.0.1:9001"
  12. dataDir := "../data/node1"
  13. // Initial Cluster configuration (Node 1 + Node 2)
  14. clusterNodes := map[string]string{
  15. "node1": "127.0.0.1:9001",
  16. "node2": "127.0.0.1:9002",
  17. }
  18. config := raft.DefaultConfig()
  19. config.NodeID = nodeID
  20. config.ListenAddr = addr
  21. config.DataDir = dataDir
  22. config.ClusterNodes = clusterNodes
  23. config.LogCompactionEnabled = false // Requirement: No bin log compression
  24. // Console Logger
  25. config.Logger = raft.NewConsoleLogger(nodeID, 1) // Info level
  26. // Ensure data directory exists
  27. if err := os.MkdirAll(dataDir, 0755); err != nil {
  28. log.Fatalf("Failed to create data directory: %v", err)
  29. }
  30. // Create KV Server
  31. server, err := raft.NewKVServer(config)
  32. if err != nil {
  33. log.Fatalf("Failed to create server: %v", err)
  34. }
  35. // Register demo commands
  36. common.RegisterDemoCommands(server.CLI)
  37. // Start server
  38. if err := server.Start(); err != nil {
  39. log.Fatalf("Failed to start server: %v", err)
  40. }
  41. defer server.Stop()
  42. // Keep main thread running
  43. select {}
  44. }