main.go 1.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566
  1. package main
  2. import (
  3. "crypto/tls"
  4. "fmt"
  5. "log"
  6. "math/rand"
  7. "net"
  8. "net/http"
  9. "os"
  10. "time"
  11. "github.com/coreos/etcd/config"
  12. "github.com/coreos/etcd/etcd"
  13. )
  14. func main() {
  15. var config = config.New()
  16. if err := config.Load(os.Args[1:]); err != nil {
  17. fmt.Println(err.Error(), "\n")
  18. os.Exit(1)
  19. } else if config.ShowVersion {
  20. fmt.Println("0.5")
  21. os.Exit(0)
  22. } else if config.ShowHelp {
  23. os.Exit(0)
  24. }
  25. e := etcd.New(config, genId())
  26. go e.Run()
  27. go func() {
  28. serve("raft", config.Peer.BindAddr, config.PeerTLSInfo(), e.RaftHandler())
  29. }()
  30. serve("etcd", config.BindAddr, config.EtcdTLSInfo(), e)
  31. }
  32. func genId() int {
  33. r := rand.New(rand.NewSource(int64(time.Now().Nanosecond())))
  34. return r.Int()
  35. }
  36. func serve(who string, addr string, info *config.TLSInfo, handler http.Handler) {
  37. t, terr := info.ServerConfig()
  38. l, err := net.Listen("tcp", addr)
  39. if err != nil {
  40. log.Fatal(err)
  41. }
  42. log.Printf("%v server starts listening on %v\n", who, addr)
  43. switch info.Scheme() {
  44. case "http":
  45. log.Printf("%v server starts serving HTTP\n", who)
  46. case "https":
  47. if t == nil {
  48. log.Fatalf("failed to create %v tls: %v\n", who, terr)
  49. }
  50. l = tls.NewListener(l, t)
  51. log.Printf("%v server starts serving HTTPS\n", who)
  52. default:
  53. log.Fatal("unsupported http scheme", info.Scheme())
  54. }
  55. log.Fatal(http.Serve(l, handler))
  56. }