Blake Mizerany 11 years ago
parent
commit
22c8ec0a80
3 changed files with 26 additions and 62 deletions
  1. 1 0
      etcdserver2/etcdhttp/http.go
  2. 1 1
      etcdserver2/etcdhttp/http_test.go
  3. 24 61
      main.go

+ 1 - 0
etcdserver2/etcdhttp/http.go

@@ -66,6 +66,7 @@ func Sender(prefix string, p Peers) func(msgs []raftpb.Message) {
 }
 
 func httpPost(url string, data []byte) bool {
+	// TODO: set timeouts
 	resp, err := http.Post(url, "application/protobuf", bytes.NewBuffer(data))
 	if err != nil {
 		elog.TODO()

+ 1 - 1
etcdserver2/etcdhttp/http_test.go

@@ -26,7 +26,7 @@ func TestSet(t *testing.T) {
 
 	st := store.New()
 
-	n := raft.Start(ctx, 1, []int64{1})
+	n := raft.Start(1, []int64{1})
 	n.Campaign(ctx)
 
 	srv := &etcdserver.Server{

+ 24 - 61
main.go

@@ -1,73 +1,36 @@
 package main
 
 import (
-	"crypto/tls"
-	"fmt"
+	"flag"
 	"log"
-	"net"
 	"net/http"
-	"os"
-	"time"
 
-	"github.com/coreos/etcd/conf"
-	"github.com/coreos/etcd/etcdserver"
+	etcdserver "github.com/coreos/etcd/etcdserver2"
+	"github.com/coreos/etcd/etcdserver2/etcdhttp"
+	"github.com/coreos/etcd/raft"
+	"github.com/coreos/etcd/raft/raftpb"
 )
 
-func main() {
-	var cfg = conf.New()
-	if err := cfg.Load(os.Args[1:]); err != nil {
-		fmt.Println(etcdserver.Usage() + "\n")
-		fmt.Println(err.Error(), "\n")
-		os.Exit(1)
-	} else if cfg.ShowVersion {
-		fmt.Println("0.5")
-		os.Exit(0)
-	} else if cfg.ShowHelp {
-		os.Exit(0)
-	}
-
-	e, err := etcdserver.New(cfg)
-	if err != nil {
-		log.Fatal("etcd:", err)
-	}
-	go e.Run()
-
-	corsInfo, err := newCORSInfo(cfg.CorsOrigins)
-	if err != nil {
-		log.Fatal("cors:", err)
-	}
-
-	readTimeout := time.Duration(cfg.HTTPReadTimeout) * time.Second
-	writeTimeout := time.Duration(cfg.HTTPWriteTimeout) * time.Second
-	go func() {
-		serve("raft", cfg.Peer.BindAddr, cfg.PeerTLSInfo(), corsInfo, e.RaftHandler(), readTimeout, writeTimeout)
-	}()
-	serve("etcd", cfg.BindAddr, cfg.EtcdTLSInfo(), corsInfo, e, readTimeout, writeTimeout)
-}
+var (
+	id = flag.String("id", "default", "The id of this server")
+)
 
-func serve(who string, addr string, tinfo *conf.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)
+func main() {
+	const V2Prefix = "/v2"
+
+	peers := etcdhttp.Discover(V2Prefix, peerips)
+	n := raft.Start(*id, peers.Ids())
+	s := &etcdserver.Server{
+		Node: n,
+		Save: func(st raftpb.State, ents []raftpb.Entry) {}, // TODO: use wal
+		Send: etcdhttp.Sender(V2Prefix),
 	}
-	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())
+	etcdserver.Start(s)
+	h := &etcdhttp.Handler{
+		Timeout: timeout,
+		Server:  s,
+		Peers:   peers,
 	}
-
-	h := &CORSHandler{handler, cinfo}
-	s := &http.Server{Handler: h, ReadTimeout: readTimeout, WriteTimeout: writeTimeout}
-	log.Fatal(s.Serve(l))
+	http.Handle(V2Prefix, http.StripPrefix(V2Prefix, h))
+	log.Fatal(http.ListenAndServe(*laddr, nil))
 }