main.go 1.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273
  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/conf"
  11. "github.com/coreos/etcd/etcdserver"
  12. )
  13. func main() {
  14. var cfg = conf.New()
  15. if err := cfg.Load(os.Args[1:]); err != nil {
  16. fmt.Println(etcdserver.Usage() + "\n")
  17. fmt.Println(err.Error(), "\n")
  18. os.Exit(1)
  19. } else if cfg.ShowVersion {
  20. fmt.Println("0.5")
  21. os.Exit(0)
  22. } else if cfg.ShowHelp {
  23. os.Exit(0)
  24. }
  25. e, err := etcdserver.New(cfg)
  26. if err != nil {
  27. log.Fatal("etcd:", err)
  28. }
  29. go e.Run()
  30. corsInfo, err := newCORSInfo(cfg.CorsOrigins)
  31. if err != nil {
  32. log.Fatal("cors:", err)
  33. }
  34. readTimeout := time.Duration(cfg.HTTPReadTimeout) * time.Second
  35. writeTimeout := time.Duration(cfg.HTTPWriteTimeout) * time.Second
  36. go func() {
  37. serve("raft", cfg.Peer.BindAddr, cfg.PeerTLSInfo(), corsInfo, e.RaftHandler(), readTimeout, writeTimeout)
  38. }()
  39. serve("etcd", cfg.BindAddr, cfg.EtcdTLSInfo(), corsInfo, e, readTimeout, writeTimeout)
  40. }
  41. func serve(who string, addr string, tinfo *conf.TLSInfo, cinfo *CORSInfo, handler http.Handler, readTimeout, writeTimeout time.Duration) {
  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 := &CORSHandler{handler, cinfo}
  61. s := &http.Server{Handler: h, ReadTimeout: readTimeout, WriteTimeout: writeTimeout}
  62. log.Fatal(s.Serve(l))
  63. }