Before that change, etcd and zookeeper would fail to instantiate

the discovery without the key being already there in the store or
created beforehand and implicitely by a 'swarm join'.

Signed-off-by: Alexandre Beslic <abronan@docker.com>
Signed-off-by: Victor Vieux <vieux@docker.com>

This PR allows to configure the discovery path using the
--discovery-opt flag (with "kv.path=path/to/nodes"). We
can point to "docker/nodes" and use the docker discovery.

If docker instances are advertising to the cluster using
the `--cluster-advertise` flag, the swarm join command
becomes unnecessary.

Signed-off-by: Alexandre Beslic <abronan@docker.com>
Signed-off-by: Victor Vieux <vieux@docker.com>
This commit is contained in:
Victor Vieux 2016-01-05 18:41:51 -08:00
parent 390876ba18
commit cc9d62dd28
2 changed files with 26 additions and 8 deletions

View file

@ -17,7 +17,7 @@ import (
) )
const ( const (
discoveryPath = "docker/nodes" defaultDiscoveryPath = "docker/nodes"
) )
// Discovery is exported // Discovery is exported
@ -62,7 +62,14 @@ func (s *Discovery) Initialize(uris string, heartbeat time.Duration, ttl time.Du
s.heartbeat = heartbeat s.heartbeat = heartbeat
s.ttl = ttl s.ttl = ttl
s.path = path.Join(s.prefix, discoveryPath)
// Use a custom path if specified in discovery options
dpath := defaultDiscoveryPath
if clusterOpts["kv.path"] != "" {
dpath = clusterOpts["kv.path"]
}
s.path = path.Join(s.prefix, dpath)
var config *store.Config var config *store.Config
if clusterOpts["kv.cacertfile"] != "" && clusterOpts["kv.certfile"] != "" && clusterOpts["kv.keyfile"] != "" { if clusterOpts["kv.cacertfile"] != "" && clusterOpts["kv.certfile"] != "" && clusterOpts["kv.keyfile"] != "" {
@ -138,6 +145,17 @@ func (s *Discovery) Watch(stopCh <-chan struct{}) (<-chan discovery.Entries, <-c
// Forever: Create a store watch, watch until we get an error and then try again. // Forever: Create a store watch, watch until we get an error and then try again.
// Will only stop if we receive a stopCh request. // Will only stop if we receive a stopCh request.
for { for {
// Create the path to watch if it does not exist yet
exists, err := s.store.Exists(s.path)
if err != nil {
errCh <- err
}
if !exists {
if err := s.store.Put(s.path, []byte(""), &store.WriteOptions{IsDir: true}); err != nil {
errCh <- err
}
}
// Set up a watch. // Set up a watch.
watchCh, err := s.store.WatchTree(s.path, stopCh) watchCh, err := s.store.WatchTree(s.path, stopCh)
if err != nil { if err != nil {

View file

@ -33,7 +33,7 @@ func (ds *DiscoverySuite) TestInitialize(c *check.C) {
s := d.store.(*FakeStore) s := d.store.(*FakeStore)
c.Assert(s.Endpoints, check.HasLen, 1) c.Assert(s.Endpoints, check.HasLen, 1)
c.Assert(s.Endpoints[0], check.Equals, "127.0.0.1") c.Assert(s.Endpoints[0], check.Equals, "127.0.0.1")
c.Assert(d.path, check.Equals, discoveryPath) c.Assert(d.path, check.Equals, defaultDiscoveryPath)
storeMock = &FakeStore{ storeMock = &FakeStore{
Endpoints: []string{"127.0.0.1:1234"}, Endpoints: []string{"127.0.0.1:1234"},
@ -45,7 +45,7 @@ func (ds *DiscoverySuite) TestInitialize(c *check.C) {
s = d.store.(*FakeStore) s = d.store.(*FakeStore)
c.Assert(s.Endpoints, check.HasLen, 1) c.Assert(s.Endpoints, check.HasLen, 1)
c.Assert(s.Endpoints[0], check.Equals, "127.0.0.1:1234") c.Assert(s.Endpoints[0], check.Equals, "127.0.0.1:1234")
c.Assert(d.path, check.Equals, "path/"+discoveryPath) c.Assert(d.path, check.Equals, "path/"+defaultDiscoveryPath)
storeMock = &FakeStore{ storeMock = &FakeStore{
Endpoints: []string{"127.0.0.1:1234", "127.0.0.2:1234", "127.0.0.3:1234"}, Endpoints: []string{"127.0.0.1:1234", "127.0.0.2:1234", "127.0.0.3:1234"},
@ -60,7 +60,7 @@ func (ds *DiscoverySuite) TestInitialize(c *check.C) {
c.Assert(s.Endpoints[1], check.Equals, "127.0.0.2:1234") c.Assert(s.Endpoints[1], check.Equals, "127.0.0.2:1234")
c.Assert(s.Endpoints[2], check.Equals, "127.0.0.3:1234") c.Assert(s.Endpoints[2], check.Equals, "127.0.0.3:1234")
c.Assert(d.path, check.Equals, "path/"+discoveryPath) c.Assert(d.path, check.Equals, "path/"+defaultDiscoveryPath)
} }
// Extremely limited mock store so we can test initialization // Extremely limited mock store so we can test initialization
@ -224,8 +224,8 @@ func (ds *DiscoverySuite) TestWatch(c *check.C) {
&discovery.Entry{Host: "2.2.2.2", Port: "2222"}, &discovery.Entry{Host: "2.2.2.2", Port: "2222"},
} }
kvs := []*store.KVPair{ kvs := []*store.KVPair{
{Key: path.Join("path", discoveryPath, "1.1.1.1"), Value: []byte("1.1.1.1:1111")}, {Key: path.Join("path", defaultDiscoveryPath, "1.1.1.1"), Value: []byte("1.1.1.1:1111")},
{Key: path.Join("path", discoveryPath, "2.2.2.2"), Value: []byte("2.2.2.2:2222")}, {Key: path.Join("path", defaultDiscoveryPath, "2.2.2.2"), Value: []byte("2.2.2.2:2222")},
} }
stopCh := make(chan struct{}) stopCh := make(chan struct{})
@ -245,7 +245,7 @@ func (ds *DiscoverySuite) TestWatch(c *check.C) {
// Add a new entry. // Add a new entry.
expected = append(expected, &discovery.Entry{Host: "3.3.3.3", Port: "3333"}) expected = append(expected, &discovery.Entry{Host: "3.3.3.3", Port: "3333"})
kvs = append(kvs, &store.KVPair{Key: path.Join("path", discoveryPath, "3.3.3.3"), Value: []byte("3.3.3.3:3333")}) kvs = append(kvs, &store.KVPair{Key: path.Join("path", defaultDiscoveryPath, "3.3.3.3"), Value: []byte("3.3.3.3:3333")})
mockCh <- kvs mockCh <- kvs
c.Assert(<-ch, check.DeepEquals, expected) c.Assert(<-ch, check.DeepEquals, expected)