From b4ec045e9a4d2552834984cad2ec3bfab54513f2 Mon Sep 17 00:00:00 2001 From: Jan De Cooman Date: Wed, 9 Aug 2017 13:30:06 +0200 Subject: [PATCH 1/6] added dnsoptions to the docker driver --- client/driver/docker.go | 8 +++++++- client/driver/docker_test.go | 5 +++++ website/source/docs/drivers/docker.html.md | 3 +++ 3 files changed, 15 insertions(+), 1 deletion(-) diff --git a/client/driver/docker.go b/client/driver/docker.go index 5372abbb525..b8f0dfbd338 100644 --- a/client/driver/docker.go +++ b/client/driver/docker.go @@ -153,6 +153,7 @@ type DockerDriverConfig struct { Privileged bool `mapstructure:"privileged"` // Flag to run the container in privileged mode DNSServers []string `mapstructure:"dns_servers"` // DNS Server for containers DNSSearchDomains []string `mapstructure:"dns_search_domains"` // DNS Search domains for containers + DNSOptions []string `mapstructure:"dns_options"` // DNS Options ExtraHosts []string `mapstructure:"extra_hosts"` // Add host to /etc/hosts (host:IP) Hostname string `mapstructure:"hostname"` // Hostname for containers LabelsRaw []map[string]string `mapstructure:"labels"` // @@ -188,7 +189,7 @@ func NewDockerDriverConfig(task *structs.Task, env *env.TaskEnv) (*DockerDriverC return nil, err } - // Interpolate everything that is a string + // Interpolate everthing that is a string dconf.ImageName = env.ReplaceEnv(dconf.ImageName) dconf.Command = env.ReplaceEnv(dconf.Command) dconf.IpcMode = env.ReplaceEnv(dconf.IpcMode) @@ -205,6 +206,7 @@ func NewDockerDriverConfig(task *structs.Task, env *env.TaskEnv) (*DockerDriverC dconf.VolumeDriver = env.ReplaceEnv(dconf.VolumeDriver) dconf.DNSServers = env.ParseAndReplace(dconf.DNSServers) dconf.DNSSearchDomains = env.ParseAndReplace(dconf.DNSSearchDomains) + dconf.DNSOptions = env.ParseAndReplace(dconf.DNSOptions) dconf.ExtraHosts = env.ParseAndReplace(dconf.ExtraHosts) dconf.MacAddress = env.ReplaceEnv(dconf.MacAddress) dconf.SecurityOpt = env.ParseAndReplace(dconf.SecurityOpt) @@ -409,6 +411,9 @@ func (d *DockerDriver) Validate(config map[string]interface{}) error { "dns_servers": &fields.FieldSchema{ Type: fields.TypeArray, }, + "dns_options": &fields.FieldSchema{ + Type: fields.TypeArray, + }, "dns_search_domains": &fields.FieldSchema{ Type: fields.TypeArray, }, @@ -937,6 +942,7 @@ func (d *DockerDriver) createContainerConfig(ctx *ExecContext, task *structs.Tas // set DNS search domains and extra hosts hostConfig.DNSSearch = driverConfig.DNSSearchDomains + hostConfig.DNSOptions = driverConfig.DNSOptions hostConfig.ExtraHosts = driverConfig.ExtraHosts hostConfig.IpcMode = driverConfig.IpcMode diff --git a/client/driver/docker_test.go b/client/driver/docker_test.go index 496001ec132..2bb651f7224 100644 --- a/client/driver/docker_test.go +++ b/client/driver/docker_test.go @@ -861,6 +861,7 @@ func TestDockerDriver_DNS(t *testing.T) { task, _, _ := dockerTask() task.Config["dns_servers"] = []string{"8.8.8.8", "8.8.4.4"} task.Config["dns_search_domains"] = []string{"example.com", "example.org", "example.net"} + task.Config["dns_options"] = []string{"ndots:1"} client, handle, cleanup := dockerSetup(t, task) defer cleanup() @@ -879,6 +880,10 @@ func TestDockerDriver_DNS(t *testing.T) { if !reflect.DeepEqual(task.Config["dns_search_domains"], container.HostConfig.DNSSearch) { t.Errorf("DNS Servers don't match.\nExpected:\n%s\nGot:\n%s\n", task.Config["dns_search_domains"], container.HostConfig.DNSSearch) } + + if !reflect.DeepEqual(task.Config["dns_options"], container.HostConfig.DNSOptions) { + t.Errorf("DNS Servers don't match.\nExpected:\n%s\nGot:\n%s\n", task.Config["dns_options"], container.HostConfig.DNSOptions) + } } func TestDockerDriver_MACAddress(t *testing.T) { diff --git a/website/source/docs/drivers/docker.html.md b/website/source/docs/drivers/docker.html.md index 192db51c8cd..ea8728ef861 100644 --- a/website/source/docs/drivers/docker.html.md +++ b/website/source/docs/drivers/docker.html.md @@ -78,6 +78,9 @@ The `docker` driver supports the following configuration in the job spec. Only * `dns_search_domains` - (Optional) A list of DNS search domains for the container to use. + +* `dns_options` - (Optional) A list of DNS options for the container to use. + * `dns_servers` - (Optional) A list of DNS servers for the container to use (e.g. ["8.8.8.8", "8.8.4.4"]). Requires Docker v1.10 or greater. From ce8550d6fbd1c647c4ab4bcb9676d134e8278c68 Mon Sep 17 00:00:00 2001 From: Jan De Cooman Date: Wed, 9 Aug 2017 14:44:38 +0200 Subject: [PATCH 2/6] fixed typo --- client/driver/docker.go | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/client/driver/docker.go b/client/driver/docker.go index b8f0dfbd338..df87a07d742 100644 --- a/client/driver/docker.go +++ b/client/driver/docker.go @@ -189,7 +189,7 @@ func NewDockerDriverConfig(task *structs.Task, env *env.TaskEnv) (*DockerDriverC return nil, err } - // Interpolate everthing that is a string + // Interpolate everything that is a string dconf.ImageName = env.ReplaceEnv(dconf.ImageName) dconf.Command = env.ReplaceEnv(dconf.Command) dconf.IpcMode = env.ReplaceEnv(dconf.IpcMode) From cbeb42e1a100453cd6fdd540f28cc4c96c371241 Mon Sep 17 00:00:00 2001 From: Jan De Cooman Date: Thu, 10 Aug 2017 11:06:26 +0200 Subject: [PATCH 3/6] removed empty line --- website/source/docs/drivers/docker.html.md | 1 - 1 file changed, 1 deletion(-) diff --git a/website/source/docs/drivers/docker.html.md b/website/source/docs/drivers/docker.html.md index ea8728ef861..44c5d6e4710 100644 --- a/website/source/docs/drivers/docker.html.md +++ b/website/source/docs/drivers/docker.html.md @@ -78,7 +78,6 @@ The `docker` driver supports the following configuration in the job spec. Only * `dns_search_domains` - (Optional) A list of DNS search domains for the container to use. - * `dns_options` - (Optional) A list of DNS options for the container to use. * `dns_servers` - (Optional) A list of DNS servers for the container to use From d7cdb7d8488a31ebba9be561e9d094aa126dfdf6 Mon Sep 17 00:00:00 2001 From: Jan De Cooman Date: Fri, 11 Aug 2017 09:24:15 +0200 Subject: [PATCH 4/6] updated message in test --- client/driver/docker_test.go | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/client/driver/docker_test.go b/client/driver/docker_test.go index 2bb651f7224..f9524a34630 100644 --- a/client/driver/docker_test.go +++ b/client/driver/docker_test.go @@ -878,11 +878,11 @@ func TestDockerDriver_DNS(t *testing.T) { } if !reflect.DeepEqual(task.Config["dns_search_domains"], container.HostConfig.DNSSearch) { - t.Errorf("DNS Servers don't match.\nExpected:\n%s\nGot:\n%s\n", task.Config["dns_search_domains"], container.HostConfig.DNSSearch) + t.Errorf("DNS Search Domains don't match.\nExpected:\n%s\nGot:\n%s\n", task.Config["dns_search_domains"], container.HostConfig.DNSSearch) } if !reflect.DeepEqual(task.Config["dns_options"], container.HostConfig.DNSOptions) { - t.Errorf("DNS Servers don't match.\nExpected:\n%s\nGot:\n%s\n", task.Config["dns_options"], container.HostConfig.DNSOptions) + t.Errorf("DNS Options don't match.\nExpected:\n%s\nGot:\n%s\n", task.Config["dns_options"], container.HostConfig.DNSOptions) } } From 9c016a7f6aa727ed6d548ec64addaa63283fc414 Mon Sep 17 00:00:00 2001 From: Jan De Cooman Date: Fri, 11 Aug 2017 11:53:24 +0200 Subject: [PATCH 5/6] added a newline --- website/source/docs/drivers/docker.html.md | 1 + 1 file changed, 1 insertion(+) diff --git a/website/source/docs/drivers/docker.html.md b/website/source/docs/drivers/docker.html.md index 44c5d6e4710..bf68becb66f 100644 --- a/website/source/docs/drivers/docker.html.md +++ b/website/source/docs/drivers/docker.html.md @@ -600,3 +600,4 @@ logs will be available to nomad. Users must use the native docker facilities to examine the logs of any jobs running under docker. In the future, we will resolve this issue, one way or another. + From 3af6e7aa9845b9223da6e5ccd74e98114847a42c Mon Sep 17 00:00:00 2001 From: Alex Dadgar Date: Fri, 11 Aug 2017 10:12:22 -0700 Subject: [PATCH 6/6] Update docker.html.md --- website/source/docs/drivers/docker.html.md | 1 - 1 file changed, 1 deletion(-) diff --git a/website/source/docs/drivers/docker.html.md b/website/source/docs/drivers/docker.html.md index bf68becb66f..44c5d6e4710 100644 --- a/website/source/docs/drivers/docker.html.md +++ b/website/source/docs/drivers/docker.html.md @@ -600,4 +600,3 @@ logs will be available to nomad. Users must use the native docker facilities to examine the logs of any jobs running under docker. In the future, we will resolve this issue, one way or another. -