mirror of https://github.com/docker/docs.git
add etchosts
Docker-DCO-1.1-Signed-off-by: Victor Vieux <vieux@docker.com> (github: vieux)
This commit is contained in:
parent
222605b5fb
commit
a1a029f6d7
|
@ -22,6 +22,7 @@ import (
|
||||||
"github.com/dotcloud/docker/links"
|
"github.com/dotcloud/docker/links"
|
||||||
"github.com/dotcloud/docker/nat"
|
"github.com/dotcloud/docker/nat"
|
||||||
"github.com/dotcloud/docker/pkg/label"
|
"github.com/dotcloud/docker/pkg/label"
|
||||||
|
"github.com/dotcloud/docker/pkg/networkfs/etchosts"
|
||||||
"github.com/dotcloud/docker/runconfig"
|
"github.com/dotcloud/docker/runconfig"
|
||||||
"github.com/dotcloud/docker/utils"
|
"github.com/dotcloud/docker/utils"
|
||||||
)
|
)
|
||||||
|
@ -513,26 +514,11 @@ func (container *Container) buildHostname() {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func (container *Container) buildHostnameAndHostsFiles(IP string) {
|
func (container *Container) buildHostnameAndHostsFiles(IP string) error {
|
||||||
container.buildHostname()
|
container.buildHostname()
|
||||||
|
|
||||||
hostsContent := []byte(`
|
|
||||||
127.0.0.1 localhost
|
|
||||||
::1 localhost ip6-localhost ip6-loopback
|
|
||||||
fe00::0 ip6-localnet
|
|
||||||
ff00::0 ip6-mcastprefix
|
|
||||||
ff02::1 ip6-allnodes
|
|
||||||
ff02::2 ip6-allrouters
|
|
||||||
`)
|
|
||||||
|
|
||||||
container.HostsPath = path.Join(container.root, "hosts")
|
container.HostsPath = path.Join(container.root, "hosts")
|
||||||
|
return etchosts.Build(container.HostsPath, IP, container.Config.Hostname, container.Config.Domainname)
|
||||||
if container.Config.Domainname != "" {
|
|
||||||
hostsContent = append([]byte(fmt.Sprintf("%s\t%s.%s %s\n", IP, container.Config.Hostname, container.Config.Domainname, container.Config.Hostname)), hostsContent...)
|
|
||||||
} else if !container.Config.NetworkDisabled {
|
|
||||||
hostsContent = append([]byte(fmt.Sprintf("%s\t%s\n", IP, container.Config.Hostname)), hostsContent...)
|
|
||||||
}
|
|
||||||
ioutil.WriteFile(container.HostsPath, hostsContent, 0644)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func (container *Container) allocateNetwork() error {
|
func (container *Container) allocateNetwork() error {
|
||||||
|
@ -1072,12 +1058,12 @@ func (container *Container) initializeNetworking() error {
|
||||||
container.Config.Domainname = nc.Config.Domainname
|
container.Config.Domainname = nc.Config.Domainname
|
||||||
} else if container.daemon.config.DisableNetwork {
|
} else if container.daemon.config.DisableNetwork {
|
||||||
container.Config.NetworkDisabled = true
|
container.Config.NetworkDisabled = true
|
||||||
container.buildHostnameAndHostsFiles("127.0.1.1")
|
return container.buildHostnameAndHostsFiles("127.0.1.1")
|
||||||
} else {
|
} else {
|
||||||
if err := container.allocateNetwork(); err != nil {
|
if err := container.allocateNetwork(); err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
container.buildHostnameAndHostsFiles(container.NetworkSettings.IPAddress)
|
return container.buildHostnameAndHostsFiles(container.NetworkSettings.IPAddress)
|
||||||
}
|
}
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1 @@
|
||||||
|
Victor Vieux <victor.vieux@docker.com> (@vieux)
|
|
@ -0,0 +1,34 @@
|
||||||
|
package etchosts
|
||||||
|
|
||||||
|
import (
|
||||||
|
"bytes"
|
||||||
|
"fmt"
|
||||||
|
"io/ioutil"
|
||||||
|
)
|
||||||
|
|
||||||
|
var defaultContent = map[string]string{
|
||||||
|
"localhost": "127.0.0.1",
|
||||||
|
"localhost ip6-localhost ip6-loopback": "::1",
|
||||||
|
"ip6-localnet": "fe00::0",
|
||||||
|
"ip6-mcastprefix": "ff00::0",
|
||||||
|
"ip6-allnodes": "ff02::1",
|
||||||
|
"ip6-allrouters": "ff02::2",
|
||||||
|
}
|
||||||
|
|
||||||
|
func Build(path, IP, hostname, domainname string) error {
|
||||||
|
content := bytes.NewBuffer(nil)
|
||||||
|
if IP != "" {
|
||||||
|
if domainname != "" {
|
||||||
|
content.WriteString(fmt.Sprintf("%s\t%s.%s %s\n", IP, hostname, domainname, hostname))
|
||||||
|
} else {
|
||||||
|
content.WriteString(fmt.Sprintf("%s\t%s\n", IP, hostname))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
for hosts, ip := range defaultContent {
|
||||||
|
if _, err := content.WriteString(fmt.Sprintf("%s\t%s\n", ip, hosts)); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return ioutil.WriteFile(path, content.Bytes(), 0644)
|
||||||
|
}
|
|
@ -0,0 +1,74 @@
|
||||||
|
package etchosts
|
||||||
|
|
||||||
|
import (
|
||||||
|
"bytes"
|
||||||
|
"io/ioutil"
|
||||||
|
"os"
|
||||||
|
"testing"
|
||||||
|
)
|
||||||
|
|
||||||
|
func TestBuildHostnameDomainname(t *testing.T) {
|
||||||
|
file, err := ioutil.TempFile("", "")
|
||||||
|
if err != nil {
|
||||||
|
t.Fatal(err)
|
||||||
|
}
|
||||||
|
defer os.Remove(file.Name())
|
||||||
|
|
||||||
|
err = Build(file.Name(), "10.11.12.13", "testhostname", "testdomainname")
|
||||||
|
if err != nil {
|
||||||
|
t.Fatal(err)
|
||||||
|
}
|
||||||
|
|
||||||
|
content, err := ioutil.ReadFile(file.Name())
|
||||||
|
if err != nil {
|
||||||
|
t.Fatal(err)
|
||||||
|
}
|
||||||
|
|
||||||
|
if expected := "10.11.12.13\ttesthostname.testdomainname testhostname\n"; !bytes.Contains(content, []byte(expected)) {
|
||||||
|
t.Fatalf("Expected to find '%s' got '%s'", expected, content)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestBuildHostname(t *testing.T) {
|
||||||
|
file, err := ioutil.TempFile("", "")
|
||||||
|
if err != nil {
|
||||||
|
t.Fatal(err)
|
||||||
|
}
|
||||||
|
defer os.Remove(file.Name())
|
||||||
|
|
||||||
|
err = Build(file.Name(), "10.11.12.13", "testhostname", "")
|
||||||
|
if err != nil {
|
||||||
|
t.Fatal(err)
|
||||||
|
}
|
||||||
|
|
||||||
|
content, err := ioutil.ReadFile(file.Name())
|
||||||
|
if err != nil {
|
||||||
|
t.Fatal(err)
|
||||||
|
}
|
||||||
|
|
||||||
|
if expected := "10.11.12.13\ttesthostname\n"; !bytes.Contains(content, []byte(expected)) {
|
||||||
|
t.Fatalf("Expected to find '%s' got '%s'", expected, content)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestBuildNoIP(t *testing.T) {
|
||||||
|
file, err := ioutil.TempFile("", "")
|
||||||
|
if err != nil {
|
||||||
|
t.Fatal(err)
|
||||||
|
}
|
||||||
|
defer os.Remove(file.Name())
|
||||||
|
|
||||||
|
err = Build(file.Name(), "", "testhostname", "")
|
||||||
|
if err != nil {
|
||||||
|
t.Fatal(err)
|
||||||
|
}
|
||||||
|
|
||||||
|
content, err := ioutil.ReadFile(file.Name())
|
||||||
|
if err != nil {
|
||||||
|
t.Fatal(err)
|
||||||
|
}
|
||||||
|
|
||||||
|
if expected := ""; !bytes.Contains(content, []byte(expected)) {
|
||||||
|
t.Fatalf("Expected to find '%s' got '%s'", expected, content)
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue