main.go 1.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273
  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. ehttp "github.com/coreos/etcd/http"
  14. )
  15. func main() {
  16. var config = config.New()
  17. if err := config.Load(os.Args[1:]); err != nil {
  18. fmt.Println(err.Error(), "\n")
  19. os.Exit(1)
  20. } else if config.ShowVersion {
  21. fmt.Println("0.5")
  22. os.Exit(0)
  23. } else if config.ShowHelp {
  24. os.Exit(0)
  25. }
  26. e := etcd.New(config, genId())
  27. go e.Run()
  28. corsInfo, err := ehttp.NewCORSInfo(config.CorsOrigins)
  29. if err != nil {
  30. log.Fatal("cors:", err)
  31. }
  32. go func() {
  33. serve("raft", config.Peer.BindAddr, config.PeerTLSInfo(), corsInfo, e.RaftHandler())
  34. }()
  35. serve("etcd", config.BindAddr, config.EtcdTLSInfo(), corsInfo, e)
  36. }
  37. func genId() int64 {
  38. r := rand.New(rand.NewSource(int64(time.Now().Nanosecond())))
  39. return r.Int63()
  40. }
  41. func serve(who string, addr string, tinfo *config.TLSInfo, cinfo *ehttp.CORSInfo, handler http.Handler) {
  42. t, terr := tinfo.ServerConfig()
  43. l, err := net.Listen("tcp", addr)
  44. if err != nil {
  45. log.Fatal(err)
  46. }
  47. log.Printf("%v server starts listening on %v\n", who, addr)
  48. switch tinfo.Scheme() {
  49. case "http":
  50. log.Printf("%v server starts serving HTTP\n", who)
  51. case "https":
  52. if t == nil {
  53. log.Fatalf("failed to create %v tls: %v\n", who, terr)
  54. }
  55. l = tls.NewListener(l, t)
  56. log.Printf("%v server starts serving HTTPS\n", who)
  57. default:
  58. log.Fatal("unsupported http scheme", tinfo.Scheme())
  59. }
  60. h := &ehttp.CORSHandler{handler, cinfo}
  61. log.Fatal(http.Serve(l, h))
  62. }