2013-06-09 21:42:34 +04:00
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
2014-07-06 21:19:23 +04:00
|
|
|
"flag"
|
|
|
|
"log"
|
|
|
|
"net/http"
|
|
|
|
"net/url"
|
|
|
|
"strings"
|
2014-01-18 22:09:54 +04:00
|
|
|
|
2014-03-24 21:55:37 +04:00
|
|
|
"github.com/coreos/etcd/etcd"
|
2014-07-06 21:19:23 +04:00
|
|
|
)
|
|
|
|
|
|
|
|
var (
|
|
|
|
laddr = flag.String("l", ":8000", "The port to listen on")
|
|
|
|
paddr = flag.String("p", "127.0.0.1:8000", "The public address to be adversited")
|
|
|
|
cluster = flag.String("c", "", "The cluster to join")
|
2013-06-09 21:42:34 +04:00
|
|
|
)
|
|
|
|
|
|
|
|
func main() {
|
2014-07-06 21:19:23 +04:00
|
|
|
flag.Parse()
|
|
|
|
|
|
|
|
p, err := sanitizeURL(*paddr)
|
|
|
|
if err != nil {
|
|
|
|
log.Fatal(err)
|
2013-10-10 01:26:49 +04:00
|
|
|
}
|
|
|
|
|
2014-07-06 21:19:23 +04:00
|
|
|
var e *etcd.Server
|
|
|
|
|
|
|
|
if len(*cluster) == 0 {
|
|
|
|
e = etcd.New(1, p, nil)
|
|
|
|
go e.Bootstrap()
|
|
|
|
} else {
|
|
|
|
addrs := strings.Split(*cluster, ",")
|
|
|
|
cStr := addrs[0]
|
|
|
|
c, err := sanitizeURL(cStr)
|
|
|
|
if err != nil {
|
|
|
|
log.Fatal(err)
|
|
|
|
}
|
|
|
|
e = etcd.New(len(addrs), p, []string{c})
|
|
|
|
go e.Join()
|
|
|
|
}
|
|
|
|
|
|
|
|
if err := http.ListenAndServe(*laddr, e); err != nil {
|
|
|
|
log.Fatal("system", err)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func sanitizeURL(ustr string) (string, error) {
|
|
|
|
u, err := url.Parse(ustr)
|
|
|
|
if err != nil {
|
|
|
|
return "", err
|
|
|
|
}
|
|
|
|
|
|
|
|
if u.Scheme == "" {
|
|
|
|
u.Scheme = "http"
|
|
|
|
}
|
|
|
|
return u.String(), nil
|
2013-06-09 21:42:34 +04:00
|
|
|
}
|