mirror of
https://github.com/tailscale/tailscale.git
synced 2025-04-03 06:45:49 +00:00
net/dns: use direct when NetworkManager has no systemd-resolved
Endeavour OS, at least, uses NetworkManager 1.44.2 and does not use systemd-resolved behind the scenes at all. If we find ourselves in that situation, return "direct" not "systemd-resolved" Fixes https://github.com/tailscale/tailscale/issues/9687 Signed-off-by: Denton Gentry <dgentry@tailscale.com>
This commit is contained in:
parent
56ebcd1ed4
commit
97ee3891f1
@ -265,6 +265,13 @@ func dnsMode(logf logger.Logf, env newOSConfigEnv) (ret string, err error) {
|
|||||||
dbg("nm-safe", "yes")
|
dbg("nm-safe", "yes")
|
||||||
return "network-manager", nil
|
return "network-manager", nil
|
||||||
}
|
}
|
||||||
|
if err := env.nmIsUsingResolved(); err != nil {
|
||||||
|
// If systemd-resolved is not running at all, then we don't have any
|
||||||
|
// other choice: we take direct control of DNS.
|
||||||
|
dbg("nm-resolved", "no")
|
||||||
|
return "direct", nil
|
||||||
|
}
|
||||||
|
|
||||||
health.SetDNSManagerHealth(errors.New("systemd-resolved and NetworkManager are wired together incorrectly; MagicDNS will probably not work. For more info, see https://tailscale.com/s/resolved-nm"))
|
health.SetDNSManagerHealth(errors.New("systemd-resolved and NetworkManager are wired together incorrectly; MagicDNS will probably not work. For more info, see https://tailscale.com/s/resolved-nm"))
|
||||||
dbg("nm-safe", "no")
|
dbg("nm-safe", "no")
|
||||||
return "systemd-resolved", nil
|
return "systemd-resolved", nil
|
||||||
|
@ -270,6 +270,18 @@ func TestLinuxDNSMode(t *testing.T) {
|
|||||||
wantLog: "dns: [resolved-ping=yes rc=resolved resolved=file nm=no resolv-conf-mode=fortests ret=systemd-resolved]",
|
wantLog: "dns: [resolved-ping=yes rc=resolved resolved=file nm=no resolv-conf-mode=fortests ret=systemd-resolved]",
|
||||||
want: "systemd-resolved",
|
want: "systemd-resolved",
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
// regression test for https://github.com/tailscale/tailscale/issues/9687
|
||||||
|
name: "networkmanager_endeavouros",
|
||||||
|
env: env(resolvDotConf(
|
||||||
|
"# Generated by NetworkManager",
|
||||||
|
"search example.com localdomain",
|
||||||
|
"nameserver 10.0.0.1"),
|
||||||
|
nmRunning("1.44.2", false)),
|
||||||
|
wantLog: "dns: resolvedIsActuallyResolver error: resolv.conf doesn't point to systemd-resolved; points to [10.0.0.1]\n" +
|
||||||
|
"dns: [rc=nm resolved=not-in-use ret=direct]",
|
||||||
|
want: "direct",
|
||||||
|
},
|
||||||
}
|
}
|
||||||
for _, tt := range tests {
|
for _, tt := range tests {
|
||||||
t.Run(tt.name, func(t *testing.T) {
|
t.Run(tt.name, func(t *testing.T) {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user