Skip to content

Commit

Permalink
Default Address Pool Code Refactor
Browse files Browse the repository at this point in the history
 We have two params that have been passed around as part of swarm init
config. As part of refactoring the code, we created NetworkConfig struct
and added address pool and subnet mask length as part of the new struct
Older PR review comment has been addressed in this commit.
Signed-off-by: selansen <elango.siva@docker.com>
  • Loading branch information
selansen committed Sep 7, 2018
1 parent 0703acf commit a6d8e98
Show file tree
Hide file tree
Showing 10 changed files with 73 additions and 63 deletions.
21 changes: 8 additions & 13 deletions manager/allocator/allocator.go
Original file line number Diff line number Diff line change
@@ -1,12 +1,12 @@
package allocator

import (
"net"
"sync"

"github.com/docker/docker/pkg/plugingetter"
"github.com/docker/go-events"
"github.com/docker/swarmkit/api"
"github.com/docker/swarmkit/manager/allocator/cnmallocator"
"github.com/docker/swarmkit/manager/state"
"github.com/docker/swarmkit/manager/state/store"
"golang.org/x/net/context"
Expand Down Expand Up @@ -34,12 +34,8 @@ type Allocator struct {
// pluginGetter provides access to docker's plugin inventory.
pluginGetter plugingetter.PluginGetter

// DefaultAddrPool specifies default subnet pool for global scope networks
defaultAddrPool []*net.IPNet

// SubnetSize specifies the subnet size of the networks created from
// the default subnet pool
subnetSize int
// networkConfig stores network related config for the cluster
networkConfig *cnmallocator.NetworkConfig
}

// taskBallot controls how the voting for task allocation is
Expand Down Expand Up @@ -73,17 +69,16 @@ type allocActor struct {

// New returns a new instance of Allocator for use during allocation
// stage of the manager.
func New(store *store.MemoryStore, pg plugingetter.PluginGetter, defaultAddrPool []*net.IPNet, subnetSize int) (*Allocator, error) {
func New(store *store.MemoryStore, pg plugingetter.PluginGetter, netConfig *cnmallocator.NetworkConfig) (*Allocator, error) {
a := &Allocator{
store: store,
taskBallot: &taskBallot{
votes: make(map[string][]string),
},
stopChan: make(chan struct{}),
doneChan: make(chan struct{}),
pluginGetter: pg,
defaultAddrPool: defaultAddrPool,
subnetSize: subnetSize,
stopChan: make(chan struct{}),
doneChan: make(chan struct{}),
pluginGetter: pg,
networkConfig: netConfig,
}

return a, nil
Expand Down
2 changes: 1 addition & 1 deletion manager/allocator/allocator_linux_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,7 @@ func TestIPAMNotNil(t *testing.T) {
assert.NotNil(t, s)
defer s.Close()

a, err := New(s, nil, nil, 0)
a, err := New(s, nil, nil)
assert.NoError(t, err)
assert.NotNil(t, a)

Expand Down
12 changes: 6 additions & 6 deletions manager/allocator/allocator_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -27,7 +27,7 @@ func TestAllocator(t *testing.T) {
assert.NotNil(t, s)
defer s.Close()

a, err := New(s, nil, nil, 0)
a, err := New(s, nil, nil)
assert.NoError(t, err)
assert.NotNil(t, a)

Expand Down Expand Up @@ -668,7 +668,7 @@ func TestNoDuplicateIPs(t *testing.T) {

return nil
}))
a, err := New(s, nil, nil, 0)
a, err := New(s, nil, nil)
assert.NoError(t, err)
assert.NotNil(t, a)

Expand Down Expand Up @@ -800,7 +800,7 @@ func TestAllocatorRestoreForDuplicateIPs(t *testing.T) {
return true
}

a, err := New(s, nil, nil, 0)
a, err := New(s, nil, nil)
assert.NoError(t, err)
assert.NotNil(t, a)
// Start allocator
Expand Down Expand Up @@ -950,7 +950,7 @@ func TestAllocatorRestartNoEndpointSpec(t *testing.T) {
return true
}

a, err := New(s, nil, nil, 0)
a, err := New(s, nil, nil)
assert.NoError(t, err)
assert.NotNil(t, a)
// Start allocator
Expand Down Expand Up @@ -1154,7 +1154,7 @@ func TestAllocatorRestoreForUnallocatedNetwork(t *testing.T) {
return true
}

a, err := New(s, nil, nil, 0)
a, err := New(s, nil, nil)
assert.NoError(t, err)
assert.NotNil(t, a)
// Start allocator
Expand All @@ -1181,7 +1181,7 @@ func TestNodeAllocator(t *testing.T) {
assert.NotNil(t, s)
defer s.Close()

a, err := New(s, nil, nil, 0)
a, err := New(s, nil, nil)
assert.NoError(t, err)
assert.NotNil(t, a)

Expand Down
15 changes: 7 additions & 8 deletions manager/allocator/cnmallocator/drivers_ipam.go
Original file line number Diff line number Diff line change
@@ -1,7 +1,6 @@
package cnmallocator

import (
"net"
"strconv"
"strings"

Expand All @@ -14,24 +13,24 @@ import (
"github.com/sirupsen/logrus"
)

func initIPAMDrivers(r *drvregistry.DrvRegistry, defaultAddrPool []*net.IPNet, subnetSize int) error {
func initIPAMDrivers(r *drvregistry.DrvRegistry, netConfig *NetworkConfig) error {
var addressPool []*ipamutils.NetworkToSplit
var str strings.Builder
str.WriteString("Subnetlist - ")
// Extract defaultAddrPool param info and construct ipamutils.NetworkToSplit
// from the info. We will be using it to call Libnetwork API
// We also need to log new address pool info whenever swarm init
// happens with default address pool option
if defaultAddrPool != nil {
for _, p := range defaultAddrPool {
if netConfig != nil {
for _, p := range netConfig.DefaultAddrPool {
addressPool = append(addressPool, &ipamutils.NetworkToSplit{
Base: p.String(),
Size: subnetSize,
Base: p,
Size: int(netConfig.SubnetSize),
})
str.WriteString(p.String() + ",")
str.WriteString(p + ",")
}
str.WriteString(": Size ")
str.WriteString(strconv.Itoa(subnetSize))
str.WriteString(strconv.Itoa(int(netConfig.SubnetSize)))
}
if err := ipamutils.ConfigGlobalScopeDefaultNetworks(addressPool); err != nil {
return err
Expand Down
14 changes: 12 additions & 2 deletions manager/allocator/cnmallocator/networkallocator.go
Original file line number Diff line number Diff line change
Expand Up @@ -86,8 +86,18 @@ type initializer struct {
ntype string
}

// NetworkConfig is used to store network related cluster config in the Manager.
type NetworkConfig struct {
// DefaultAddrPool specifies default subnet pool for global scope networks
DefaultAddrPool []string

// SubnetSize specifies the subnet size of the networks created from
// the default subnet pool
SubnetSize uint32
}

// New returns a new NetworkAllocator handle
func New(pg plugingetter.PluginGetter, defaultAddrPool []*net.IPNet, subnetSize int) (networkallocator.NetworkAllocator, error) {
func New(pg plugingetter.PluginGetter, netConfig *NetworkConfig) (networkallocator.NetworkAllocator, error) {
na := &cnmNetworkAllocator{
networks: make(map[string]*network),
services: make(map[string]struct{}),
Expand All @@ -106,7 +116,7 @@ func New(pg plugingetter.PluginGetter, defaultAddrPool []*net.IPNet, subnetSize
return nil, err
}

if err = initIPAMDrivers(reg, defaultAddrPool, subnetSize); err != nil {
if err = initIPAMDrivers(reg, netConfig); err != nil {
return nil, err
}

Expand Down
2 changes: 1 addition & 1 deletion manager/allocator/cnmallocator/networkallocator_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,7 @@ import (
)

func newNetworkAllocator(t *testing.T) networkallocator.NetworkAllocator {
na, err := New(nil, nil, 0)
na, err := New(nil, nil)
assert.NoError(t, err)
assert.NotNil(t, na)
return na
Expand Down
10 changes: 9 additions & 1 deletion manager/allocator/network.go
Original file line number Diff line number Diff line change
Expand Up @@ -68,7 +68,15 @@ type networkContext struct {
}

func (a *Allocator) doNetworkInit(ctx context.Context) (err error) {
na, err := cnmallocator.New(a.pluginGetter, a.defaultAddrPool, a.subnetSize)
var netConfig *cnmallocator.NetworkConfig
if a.networkConfig != nil && a.networkConfig.DefaultAddrPool != nil {
netConfig = &cnmallocator.NetworkConfig{
DefaultAddrPool: a.networkConfig.DefaultAddrPool,
SubnetSize: a.networkConfig.SubnetSize,
}
}

na, err := cnmallocator.New(a.pluginGetter, netConfig)
if err != nil {
return err
}
Expand Down
13 changes: 13 additions & 0 deletions manager/controlapi/cluster.go
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,13 @@ const (
// expiredCertGrace is the amount of time to keep a node in the
// blacklist beyond its certificate expiration timestamp.
expiredCertGrace = 24 * time.Hour * 7
// inbuilt default subnet size
inbuiltSubnetSize = 24
)

var (
// inbuilt default address pool
inbuiltDefaultAddressPool = []string{"10.0.0.0/8"}
)

func validateClusterSpec(spec *api.ClusterSpec) error {
Expand Down Expand Up @@ -268,6 +275,12 @@ func redactClusters(clusters []*api.Cluster) []*api.Cluster {
DefaultAddressPool: cluster.DefaultAddressPool,
SubnetSize: cluster.SubnetSize,
}
if newCluster.DefaultAddressPool == nil {
// This is just for CLI display. Set the inbuilt default pool for
// user reference.
newCluster.DefaultAddressPool = inbuiltDefaultAddressPool
newCluster.SubnetSize = inbuiltSubnetSize
}
redactedClusters = append(redactedClusters, newCluster)
}

Expand Down
35 changes: 12 additions & 23 deletions manager/manager.go
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,7 @@ import (
"github.com/docker/swarmkit/identity"
"github.com/docker/swarmkit/log"
"github.com/docker/swarmkit/manager/allocator"
"github.com/docker/swarmkit/manager/allocator/cnmallocator"
"github.com/docker/swarmkit/manager/allocator/networkallocator"
"github.com/docker/swarmkit/manager/controlapi"
"github.com/docker/swarmkit/manager/dispatcher"
Expand Down Expand Up @@ -127,12 +128,8 @@ type Config struct {
// FIPS setting.
FIPS bool

// DefaultAddrPool specifies default subnet pool for global scope networks
DefaultAddrPool []*net.IPNet

// SubnetSize specifies the subnet size of the networks created from
// the default subnet pool
SubnetSize int
// NetworkConfig stores network related config for the cluster
NetworkConfig *cnmallocator.NetworkConfig
}

// Manager is the cluster manager for Swarm.
Expand Down Expand Up @@ -947,14 +944,10 @@ func (m *Manager) becomeLeader(ctx context.Context) {
nil,
0)

var defaultAddrPool []string
for _, p := range m.config.DefaultAddrPool {
defaultAddrPool = append(defaultAddrPool, p.String())
}
// If defaultAddrPool is valid we update cluster object with new value
if defaultAddrPool != nil {
clusterObj.DefaultAddressPool = defaultAddrPool
clusterObj.SubnetSize = uint32(m.config.SubnetSize)
if m.config.NetworkConfig != nil && m.config.NetworkConfig.DefaultAddrPool != nil {
clusterObj.DefaultAddressPool = m.config.NetworkConfig.DefaultAddrPool
clusterObj.SubnetSize = m.config.NetworkConfig.SubnetSize
}

err := store.CreateCluster(tx, clusterObj)
Expand Down Expand Up @@ -1003,24 +996,20 @@ func (m *Manager) becomeLeader(ctx context.Context) {

// If DefaultAddrPool is null, Read from store and check if
// DefaultAddrPool info is stored in cluster object
if m.config.DefaultAddrPool == nil {
if m.config.NetworkConfig == nil || m.config.NetworkConfig.DefaultAddrPool == nil {
var cluster *api.Cluster
s.View(func(tx store.ReadTx) {
cluster = store.GetCluster(tx, clusterID)
})
if cluster.DefaultAddressPool != nil {
for _, address := range cluster.DefaultAddressPool {
_, b, err := net.ParseCIDR(address)
if err != nil {
log.G(ctx).WithError(err).Error("Default Address Pool reading failed for cluster object %s", address)
}
m.config.DefaultAddrPool = append(m.config.DefaultAddrPool, b)
m.config.NetworkConfig.DefaultAddrPool = append(m.config.NetworkConfig.DefaultAddrPool, address)
}
m.config.NetworkConfig.SubnetSize = cluster.SubnetSize
}
m.config.SubnetSize = int(cluster.SubnetSize)
}

m.allocator, err = allocator.New(s, m.config.PluginGetter, m.config.DefaultAddrPool, m.config.SubnetSize)
m.allocator, err = allocator.New(s, m.config.PluginGetter, m.config.NetworkConfig)
if err != nil {
log.G(ctx).WithError(err).Error("failed to create allocator")
// TODO(stevvooe): It doesn't seem correct here to fail
Expand Down Expand Up @@ -1144,7 +1133,7 @@ func defaultClusterObject(
rootCA *ca.RootCA,
fips bool,
defaultAddressPool []string,
subnetSize int) *api.Cluster {
subnetSize uint32) *api.Cluster {
var caKey []byte
if rcaSigner, err := rootCA.Signer(); err == nil {
caKey = rcaSigner.Key
Expand Down Expand Up @@ -1178,7 +1167,7 @@ func defaultClusterObject(
UnlockKeys: initialUnlockKeys,
FIPS: fips,
DefaultAddressPool: defaultAddressPool,
SubnetSize: uint32(subnetSize),
SubnetSize: subnetSize,
}
}

Expand Down
12 changes: 4 additions & 8 deletions node/node.go
Original file line number Diff line number Diff line change
Expand Up @@ -28,6 +28,7 @@ import (
"github.com/docker/swarmkit/ioutils"
"github.com/docker/swarmkit/log"
"github.com/docker/swarmkit/manager"
"github.com/docker/swarmkit/manager/allocator/cnmallocator"
"github.com/docker/swarmkit/manager/encryption"
"github.com/docker/swarmkit/remotes"
"github.com/docker/swarmkit/xnet"
Expand Down Expand Up @@ -105,12 +106,8 @@ type Config struct {
// for connections to the remote API (including the raft service).
AdvertiseRemoteAPI string

// DefaultAddrPool specifies default subnet pool for global scope networks
DefaultAddrPool []*net.IPNet

// SubnetSize specifies the subnet size of the networks created from
// the default subnet pool
SubnetSize int
// NetworkConfig stores network related config for the cluster
NetworkConfig *cnmallocator.NetworkConfig

// Executor specifies the executor to use for the agent.
Executor exec.Executor
Expand Down Expand Up @@ -1002,8 +999,7 @@ func (n *Node) runManager(ctx context.Context, securityConfig *ca.SecurityConfig
PluginGetter: n.config.PluginGetter,
RootCAPaths: rootPaths,
FIPS: n.config.FIPS,
DefaultAddrPool: n.config.DefaultAddrPool,
SubnetSize: n.config.SubnetSize,
NetworkConfig: n.config.NetworkConfig,
})
if err != nil {
return false, err
Expand Down

0 comments on commit a6d8e98

Please sign in to comment.