1
0
mirror of https://github.com/rancher/os.git synced 2025-08-15 21:43:42 +00:00

Merge pull request #875 from joshwget/fix-dns-override

If DNS override is set, pass `--nohook resolv.conf` to dhcpd
This commit is contained in:
Darren Shepherd 2016-04-12 10:14:36 -07:00
commit dcba30813c
3 changed files with 15 additions and 9 deletions

View File

@ -48,11 +48,18 @@ func Main() {
if err != nil {
log.Fatal(err)
}
hostname, _ := cloudinit.SetHostname(cfg) // ignore error
log.Infof("Network: hostname: '%s'", hostname)
if _, err := resolvconf.Build("/etc/resolv.conf", cfg.Rancher.Network.Dns.Nameservers, cfg.Rancher.Network.Dns.Search, nil); err != nil {
log.Error(err)
}
if err := netconf.ApplyNetworkConfigs(&cfg.Rancher.Network); err != nil {
log.Error(err)
}
hostname, _ = cloudinit.SetHostname(cfg) // ignore error
log.Infof("Network: hostname: '%s' (from DHCP, if not set by cloud-config)", hostname)
if hostname != "" {
@ -76,12 +83,7 @@ func Main() {
log.Error(err)
}
}
if cfg.Rancher.Network.Dns.Override {
log.WithFields(log.Fields{"nameservers": cfg.Rancher.Network.Dns.Nameservers}).Info("Override nameservers")
if _, err := resolvconf.Build("/etc/resolv.conf", cfg.Rancher.Network.Dns.Nameservers, cfg.Rancher.Network.Dns.Search, nil); err != nil {
log.Error(err)
}
}
if f, err := os.Create(NETWORK_DONE); err != nil {
log.Error(err)
} else {

View File

@ -70,7 +70,7 @@ import:
version: v1.10.3
- package: github.com/rancher/netconf
version: f953ace624d8bade198682d343eb7e25d9c8899c
version: 6cd9ea0b3a45482c9e9aee9be9ca88c96b2f71e6
- package: github.com/ryanuber/go-glob
version: 0067a9abd927e50aed5190662702f81231413ae0

View File

@ -187,7 +187,7 @@ func ApplyNetworkConfigs(netCfg *NetworkConfig) error {
for iface, args := range dhcpLinks {
wg.Add(1)
go func(iface, args string) {
runDhcp(iface, args)
runDhcp(netCfg, iface, args)
wg.Done()
}(iface, args)
}
@ -197,7 +197,7 @@ func ApplyNetworkConfigs(netCfg *NetworkConfig) error {
return err
}
func runDhcp(iface string, argstr string) {
func runDhcp(netCfg *NetworkConfig, iface string, argstr string) {
log.Infof("Running DHCP on %s", iface)
args := []string{}
if argstr != "" {
@ -211,6 +211,10 @@ func runDhcp(iface string, argstr string) {
args = defaultDhcpArgs
}
if netCfg.Dns.Override {
args = append(args, "--nohook", "resolv.conf")
}
args = append(args, iface)
cmd := exec.Command(args[0], args[1:]...)
cmd.Stdout = os.Stdout