mirror of
				https://github.com/containers/podman.git
				synced 2025-10-26 18:54:17 +08:00 
			
		
		
		
	Merge pull request #11118 from mheon/use_host_resolveconf
Do not add an entry to /etc/hosts with `--net=host`
This commit is contained in:
		| @ -1912,6 +1912,7 @@ func (c *Container) appendHosts(path string, netCtr *Container) (string, error) | |||||||
| // and returns a string in a format that can be written to the host file | // and returns a string in a format that can be written to the host file | ||||||
| func (c *Container) getHosts() string { | func (c *Container) getHosts() string { | ||||||
| 	var hosts string | 	var hosts string | ||||||
|  |  | ||||||
| 	if len(c.config.HostAdd) > 0 { | 	if len(c.config.HostAdd) > 0 { | ||||||
| 		for _, host := range c.config.HostAdd { | 		for _, host := range c.config.HostAdd { | ||||||
| 			// the host format has already been verified at this point | 			// the host format has already been verified at this point | ||||||
| @ -1922,36 +1923,33 @@ func (c *Container) getHosts() string { | |||||||
|  |  | ||||||
| 	hosts += c.cniHosts() | 	hosts += c.cniHosts() | ||||||
|  |  | ||||||
| 	// If not making a network namespace, add our own hostname. | 	// Add hostname for slirp4netns | ||||||
| 	if c.Hostname() != "" { | 	if c.Hostname() != "" { | ||||||
| 		if c.config.NetMode.IsSlirp4netns() { | 		if c.config.NetMode.IsSlirp4netns() { | ||||||
| 			// When using slirp4netns, the interface gets a static IP | 			// When using slirp4netns, the interface gets a static IP | ||||||
| 			slirp4netnsIP, err := GetSlirp4netnsIP(c.slirp4netnsSubnet) | 			slirp4netnsIP, err := GetSlirp4netnsIP(c.slirp4netnsSubnet) | ||||||
| 			if err != nil { | 			if err != nil { | ||||||
| 				logrus.Warn("failed to determine slirp4netnsIP: ", err.Error()) | 				logrus.Warnf("failed to determine slirp4netnsIP: %v", err.Error()) | ||||||
| 			} else { | 			} else { | ||||||
| 				hosts += fmt.Sprintf("# used by slirp4netns\n%s\t%s %s\n", slirp4netnsIP.String(), c.Hostname(), c.config.Name) | 				hosts += fmt.Sprintf("# used by slirp4netns\n%s\t%s %s\n", slirp4netnsIP.String(), c.Hostname(), c.config.Name) | ||||||
| 			} | 			} | ||||||
| 		} else { | 		} | ||||||
| 			hasNetNS := false |  | ||||||
|  | 		// Do we have a network namespace? | ||||||
| 		netNone := false | 		netNone := false | ||||||
| 		for _, ns := range c.config.Spec.Linux.Namespaces { | 		for _, ns := range c.config.Spec.Linux.Namespaces { | ||||||
| 			if ns.Type == spec.NetworkNamespace { | 			if ns.Type == spec.NetworkNamespace { | ||||||
| 					hasNetNS = true |  | ||||||
| 				if ns.Path == "" && !c.config.CreateNetNS { | 				if ns.Path == "" && !c.config.CreateNetNS { | ||||||
| 					netNone = true | 					netNone = true | ||||||
| 				} | 				} | ||||||
| 				break | 				break | ||||||
| 			} | 			} | ||||||
| 		} | 		} | ||||||
| 			if !hasNetNS { |  | ||||||
| 				// 127.0.1.1 and host's hostname to match Docker | 		// If we are net=none (have a network namespace, but not connected to | ||||||
| 				osHostname, _ := os.Hostname() | 		// anything) add the container's name and hostname to localhost. | ||||||
| 				hosts += fmt.Sprintf("127.0.1.1 %s %s %s\n", osHostname, c.Hostname(), c.config.Name) |  | ||||||
| 			} |  | ||||||
| 		if netNone { | 		if netNone { | ||||||
| 				hosts += fmt.Sprintf("127.0.1.1 %s %s\n", c.Hostname(), c.config.Name) | 			hosts += fmt.Sprintf("127.0.0.1 %s %s\n", c.Hostname(), c.config.Name) | ||||||
| 			} |  | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
|  | |||||||
| @ -685,13 +685,6 @@ var _ = Describe("Podman run networking", func() { | |||||||
| 		Expect(podrm).Should(Exit(0)) | 		Expect(podrm).Should(Exit(0)) | ||||||
| 	}) | 	}) | ||||||
|  |  | ||||||
| 	It("podman run net=host adds entry to /etc/hosts", func() { |  | ||||||
| 		run := podmanTest.Podman([]string{"run", "--net=host", ALPINE, "cat", "/etc/hosts"}) |  | ||||||
| 		run.WaitWithDefaultTimeout() |  | ||||||
| 		Expect(run).Should(Exit(0)) |  | ||||||
| 		Expect(strings.Contains(run.OutputToString(), "127.0.1.1")).To(BeTrue()) |  | ||||||
| 	}) |  | ||||||
|  |  | ||||||
| 	It("podman run with --net=host and --hostname sets correct hostname", func() { | 	It("podman run with --net=host and --hostname sets correct hostname", func() { | ||||||
| 		hostname := "testctr" | 		hostname := "testctr" | ||||||
| 		run := podmanTest.Podman([]string{"run", "--net=host", "--hostname", hostname, ALPINE, "hostname"}) | 		run := podmanTest.Podman([]string{"run", "--net=host", "--hostname", hostname, ALPINE, "hostname"}) | ||||||
| @ -731,10 +724,6 @@ var _ = Describe("Podman run networking", func() { | |||||||
| 		ping_test("--net=none") | 		ping_test("--net=none") | ||||||
| 	}) | 	}) | ||||||
|  |  | ||||||
| 	It("podman attempt to ping container name and hostname --net=host", func() { |  | ||||||
| 		ping_test("--net=host") |  | ||||||
| 	}) |  | ||||||
|  |  | ||||||
| 	It("podman attempt to ping container name and hostname --net=private", func() { | 	It("podman attempt to ping container name and hostname --net=private", func() { | ||||||
| 		ping_test("--net=private") | 		ping_test("--net=private") | ||||||
| 	}) | 	}) | ||||||
|  | |||||||
		Reference in New Issue
	
	Block a user
	![75433959+openshift-ci[bot]@users.noreply.github.com](/assets/img/avatar_default.png) openshift-ci[bot]
					openshift-ci[bot]