main.go 1.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374
  1. package main
  2. import (
  3. "crypto/tls"
  4. "fmt"
  5. "log"
  6. "net"
  7. "net/http"
  8. "os"
  9. "time"
  10. "github.com/coreos/etcd/config"
  11. "github.com/coreos/etcd/etcd"
  12. ehttp "github.com/coreos/etcd/http"
  13. )
  14. func main() {
  15. var config = config.New()
  16. if err := config.Load(os.Args[1:]); err != nil {
  17. fmt.Println(etcd.Usage() + "\n")
  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, err := etcd.New(config)
  27. if err != nil {
  28. log.Fatal("etcd:", err)
  29. }
  30. go e.Run()
  31. corsInfo, err := ehttp.NewCORSInfo(config.CorsOrigins)
  32. if err != nil {
  33. log.Fatal("cors:", err)
  34. }
  35. readTimeout := time.Duration(config.HTTPReadTimeout) * time.Second
  36. writeTimeout := time.Duration(config.HTTPWriteTimeout) * time.Second
  37. go func() {
  38. serve("raft", config.Peer.BindAddr, config.PeerTLSInfo(), corsInfo, e.RaftHandler(), readTimeout, writeTimeout)
  39. }()
  40. serve("etcd", config.BindAddr, config.EtcdTLSInfo(), corsInfo, e, readTimeout, writeTimeout)
  41. }
  42. func serve(who string, addr string, tinfo *config.TLSInfo, cinfo *ehttp.CORSInfo, handler http.Handler, readTimeout, writeTimeout time.Duration) {
  43. t, terr := tinfo.ServerConfig()
  44. l, err := net.Listen("tcp", addr)
  45. if err != nil {
  46. log.Fatal(err)
  47. }
  48. log.Printf("%v server starts listening on %v\n", who, addr)
  49. switch tinfo.Scheme() {
  50. case "http":
  51. log.Printf("%v server starts serving HTTP\n", who)
  52. case "https":
  53. if t == nil {
  54. log.Fatalf("failed to create %v tls: %v\n", who, terr)
  55. }
  56. l = tls.NewListener(l, t)
  57. log.Printf("%v server starts serving HTTPS\n", who)
  58. default:
  59. log.Fatal("unsupported http scheme", tinfo.Scheme())
  60. }
  61. h := &ehttp.CORSHandler{handler, cinfo}
  62. s := &http.Server{Handler: h, ReadTimeout: readTimeout, WriteTimeout: writeTimeout}
  63. log.Fatal(s.Serve(l))
  64. }