Files
etcd/main.go
Blake Mizerany 41ccf13393 config -> cfg
It is extremely confusing to use variables named the same as a package.
Please no longer do this.
2014-09-03 09:20:07 -07:00

74 lines
1.7 KiB
Go

package main
import (
"crypto/tls"
"fmt"
"log"
"net"
"net/http"
"os"
"time"
"github.com/coreos/etcd/cfg"
"github.com/coreos/etcd/etcd"
)
func main() {
var config = cfg.New()
if err := config.Load(os.Args[1:]); err != nil {
fmt.Println(etcd.Usage() + "\n")
fmt.Println(err.Error(), "\n")
os.Exit(1)
} else if config.ShowVersion {
fmt.Println("0.5")
os.Exit(0)
} else if config.ShowHelp {
os.Exit(0)
}
e, err := etcd.New(config)
if err != nil {
log.Fatal("etcd:", err)
}
go e.Run()
corsInfo, err := newCORSInfo(config.CorsOrigins)
if err != nil {
log.Fatal("cors:", err)
}
readTimeout := time.Duration(config.HTTPReadTimeout) * time.Second
writeTimeout := time.Duration(config.HTTPWriteTimeout) * time.Second
go func() {
serve("raft", config.Peer.BindAddr, config.PeerTLSInfo(), corsInfo, e.RaftHandler(), readTimeout, writeTimeout)
}()
serve("etcd", config.BindAddr, config.EtcdTLSInfo(), corsInfo, e, readTimeout, writeTimeout)
}
func serve(who string, addr string, tinfo *cfg.TLSInfo, cinfo *CORSInfo, handler http.Handler, readTimeout, writeTimeout time.Duration) {
t, terr := tinfo.ServerConfig()
l, err := net.Listen("tcp", addr)
if err != nil {
log.Fatal(err)
}
log.Printf("%v server starts listening on %v\n", who, addr)
switch tinfo.Scheme() {
case "http":
log.Printf("%v server starts serving HTTP\n", who)
case "https":
if t == nil {
log.Fatalf("failed to create %v tls: %v\n", who, terr)
}
l = tls.NewListener(l, t)
log.Printf("%v server starts serving HTTPS\n", who)
default:
log.Fatal("unsupported http scheme", tinfo.Scheme())
}
h := &CORSHandler{handler, cinfo}
s := &http.Server{Handler: h, ReadTimeout: readTimeout, WriteTimeout: writeTimeout}
log.Fatal(s.Serve(l))
}