我发现显然在Ubuntu 18中,整个DNS设置非常混乱。我通过pritunl VPN连接到我的kube-cluster,并尝试使用kube-dns服务器。因此,我首先尝试使用https://github.com/jonathanio/update-systemd-resolved来通过VPN推送的DNS服务器更新我的DNS设置,但目前看来有些问题(https://github.com/jonathanio/update-systemd-resolved/issues/64)。
以某种方式对DNS ip进行硬编码是可以的,我尝试将IP放置在某些地方:安装resolvconf并将其放置在/etc/resolvconf/resolv.conf.d/head
中,将其放置在/etc/systemd/resolved.conf
中,当然也尝试将其直接放置成为/etc/resolv.conf
,就像一个天真的人一样。重新启动几次后,我达到了更加混乱的状态:
% dig pritunl-ui.infra.svc.cluster.local
[...]
;; ANSWER SECTION:
pritunl-ui.infra.svc.cluster.local. 30 IN A 10.15.246.61
[...]
所以看起来不错,但是:
% curl 'https://pritunl-ui.infra.svc.cluster.local' --insecure
curl: (6) Could not resolve host: pritunl-ui.infra.svc.cluster.local
尽管调用IP确实可以:
% curl 'https://10.15.246.61' --insecure
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 3.2 Final//EN">
<title>Redirecting...</title>
<h1>Redirecting...</h1>
<p>You should be redirected automatically to target URL: <a href="https://10.15.246.61/login">https://10.15.246.61/login</a>. If not click the link.
我也尝试过关闭并重新打开(我的主机),但是保持不变。 nslookup
也可以,tracepath
不能。
% systemd-resolve --status
Global
DNS Servers: 10.15.240.10
DNS Domain: svc.cluster.local
DNSSEC NTA: 10.in-addr.arpa
16.172.in-addr.arpa
168.192.in-addr.arpa
17.172.in-addr.arpa
18.172.in-addr.arpa
19.172.in-addr.arpa
20.172.in-addr.arpa
21.172.in-addr.arpa
22.172.in-addr.arpa
23.172.in-addr.arpa
24.172.in-addr.arpa
25.172.in-addr.arpa
26.172.in-addr.arpa
27.172.in-addr.arpa
28.172.in-addr.arpa
29.172.in-addr.arpa
30.172.in-addr.arpa
31.172.in-addr.arpa
corp
d.f.ip6.arpa
home
internal
intranet
lan
local
private
test
Link 3 (tun0)
Current Scopes: DNS
LLMNR setting: yes
MulticastDNS setting: no
DNSSEC setting: no
DNSSEC supported: no
DNS Servers: 10.15.240.10
DNS Domain: default.svc.cluster.local
~.
Link 2 (wlp2s0)
Current Scopes: DNS
LLMNR setting: yes
MulticastDNS setting: no
DNSSEC setting: no
DNSSEC supported: no
DNS Servers: 192.168.178.1
fd00::cece:1eff:feba:6468
DNS Domain: ~.
fritz.box
有什么想法可以使这项工作成功吗?
答案 0 :(得分:3)
要回答我自己的问题:我更深入地研究了avahi
,nscd
,systemd-resolve
和nsswitch
的魔力。显然问题出在我的/etc/nsswitch.conf
中的这一行:
hosts: files mdns4_minimal [NOTFOUND=return] resolve [!UNAVAIL=return] dns myhostname
我错过了update-systemd-resolved
的自述文件,实际上建议更改此行。所以我将其更改为
hosts: files dns resolve myhostname
EtVoilà,现在卷曲可以到达宿主了:
$ getent ahosts pritunl-ui.infra.svc.cluster.local
10.15.246.61 STREAM pritunl-ui.infra.svc.cluster.local
10.15.246.61 DGRAM
10.15.246.61 RAW
我还试图删除[NOTFOUND=return]
部分,这似乎具有相同的效果,它也可以工作。也许上面写着“如果mdns失败了,就停在这里,忽略其余部分”。我认为这将是一个非常奇怪的策略。