From 5f4716b4ea08b10d65e4141be51f30139d826c66 Mon Sep 17 00:00:00 2001 From: Clint Armstrong Date: Fri, 7 Apr 2017 09:58:17 -0400 Subject: [PATCH 1/2] Allow specifying container IP with docker driver --- client/driver/docker.go | 28 ++++++++++++++++++---- website/source/docs/drivers/docker.html.md | 6 +++++ 2 files changed, 30 insertions(+), 4 deletions(-) diff --git a/client/driver/docker.go b/client/driver/docker.go index 7fe21b67788..60ab5385f77 100644 --- a/client/driver/docker.go +++ b/client/driver/docker.go @@ -136,6 +136,8 @@ type DockerDriverConfig struct { IpcMode string `mapstructure:"ipc_mode"` // The IPC mode of the container - host and none NetworkMode string `mapstructure:"network_mode"` // The network mode of the container - host, nat and none NetworkAliases []string `mapstructure:"network_aliases"` // The network-scoped alias for the container + IPv4Address string `mapstructure:"ipv4_address"` // The container ipv4 address + IPv6Address string `mapstructure:"ipv6_address"` // the container ipv6 address PidMode string `mapstructure:"pid_mode"` // The PID mode of the container - host and none UTSMode string `mapstructure:"uts_mode"` // The UTS mode of the container - host and none UsernsMode string `mapstructure:"userns_mode"` // The User namespace mode of the container - host and none @@ -187,6 +189,8 @@ func NewDockerDriverConfig(task *structs.Task, env *env.TaskEnvironment) (*Docke dconf.IpcMode = env.ReplaceEnv(dconf.IpcMode) dconf.NetworkMode = env.ReplaceEnv(dconf.NetworkMode) dconf.NetworkAliases = env.ParseAndReplace(dconf.NetworkAliases) + dconf.IPv4Address = env.ReplaceEnv(dconf.IPv4Address) + dconf.IPv6Address = env.ReplaceEnv(dconf.IPv6Address) dconf.PidMode = env.ReplaceEnv(dconf.PidMode) dconf.UTSMode = env.ReplaceEnv(dconf.UTSMode) dconf.Hostname = env.ReplaceEnv(dconf.Hostname) @@ -341,6 +345,12 @@ func (d *DockerDriver) Validate(config map[string]interface{}) error { "network_aliases": &fields.FieldSchema{ Type: fields.TypeArray, }, + "ipv4_address": &fields.FieldSchema{ + Type: fields.TypeString, + }, + "ipv6_address": &fields.FieldSchema{ + Type: fields.TypeString, + }, "pid_mode": &fields.FieldSchema{ Type: fields.TypeString, }, @@ -916,19 +926,29 @@ func (d *DockerDriver) createContainerConfig(ctx *ExecContext, task *structs.Tas d.logger.Printf("[DEBUG] driver.docker: setting container name to: %s", containerName) var networkingConfig *docker.NetworkingConfig - if len(driverConfig.NetworkAliases) > 0 { + if len(driverConfig.NetworkAliases) > 0 || driverConfig.IPv4Address != "" || driverConfig.IPv6Address != "" { networkingConfig = &docker.NetworkingConfig{ EndpointsConfig: map[string]*docker.EndpointConfig{ - hostConfig.NetworkMode: &docker.EndpointConfig{ - Aliases: driverConfig.NetworkAliases, - }, + hostConfig.NetworkMode: &docker.EndpointConfig{}, }, } + } + if len(driverConfig.NetworkAliases) > 0 { + networkingConfig.EndpointsConfig[hostConfig.NetworkMode].Aliases = driverConfig.NetworkAliases d.logger.Printf("[DEBUG] driver.docker: using network_mode %q with network aliases: %v", hostConfig.NetworkMode, strings.Join(driverConfig.NetworkAliases, ", ")) } + if driverConfig.IPv4Address != "" || driverConfig.IPv6Address != "" { + networkingConfig.EndpointsConfig[hostConfig.NetworkMode].IPAMConfig = &docker.EndpointIPAMConfig{ + IPv4Address: driverConfig.IPv4Address, + IPv6Address: driverConfig.IPv6Address, + } + d.logger.Printf("[DEBUG] driver.docker: using network_mode %q with ipv4: %q and ipv6: %q", + hostConfig.NetworkMode, driverConfig.IPv4Address, driverConfig.IPv6Address) + } + return docker.CreateContainerOptions{ Name: containerName, Config: config, diff --git a/website/source/docs/drivers/docker.html.md b/website/source/docs/drivers/docker.html.md index 7f74283f0a1..19958ba5fc2 100644 --- a/website/source/docs/drivers/docker.html.md +++ b/website/source/docs/drivers/docker.html.md @@ -144,6 +144,12 @@ The `docker` driver supports the following configuration in the job spec: } ``` +* `ipv4_address` - (Optional) The IPv4 address to be used for the container. In + requires docker 1.13.0. + +* `ipv6_address` - (Optional) The IPv6 address to be used for the container. In + requires docker 1.13.0. + * `hostname` - (Optional) The hostname to assign to the container. When launching more than one of a task (using `count`) with this option set, every container the task starts will have the same hostname. From 976f58b23c6d6864f879c1b5895fd7d17a7314f1 Mon Sep 17 00:00:00 2001 From: Clint Armstrong Date: Fri, 7 Apr 2017 15:58:16 -0400 Subject: [PATCH 2/2] Update docs to clarify that user defined networks are required --- website/source/docs/drivers/docker.html.md | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/website/source/docs/drivers/docker.html.md b/website/source/docs/drivers/docker.html.md index 19958ba5fc2..1358640c451 100644 --- a/website/source/docs/drivers/docker.html.md +++ b/website/source/docs/drivers/docker.html.md @@ -144,11 +144,11 @@ The `docker` driver supports the following configuration in the job spec: } ``` -* `ipv4_address` - (Optional) The IPv4 address to be used for the container. In - requires docker 1.13.0. +* `ipv4_address` - (Optional) The IPv4 address to be used for the container. + Requires docker 1.13.0. Only works with user defined networks. -* `ipv6_address` - (Optional) The IPv6 address to be used for the container. In - requires docker 1.13.0. +* `ipv6_address` - (Optional) The IPv6 address to be used for the container. + Requires docker 1.13.0. Only works with user defined networks. * `hostname` - (Optional) The hostname to assign to the container. When launching more than one of a task (using `count`) with this option set, every