修复 ubuntu 16.04 上的 DNS

Fix dns on ubuntu 16.04

我在我的虚拟 ubuntu 16.04 机器上搞乱了我的 DNS。你能帮我诊断出问题所在并让 DNS 重新工作吗?我可以使用 IP 地址连接到服务器。但是,当我使用主机名时,我的盒子无法解析它们。这曾经有效 - 我做了一些事情把它搞砸了,但不记得我编辑了什么文件。

ubuntu版本:

lsb_release -a
No LSB modules are available.
Distributor ID: Ubuntu
Description:    Ubuntu 16.04.7 LTS
Release:    16.04
Codename:   xenial

这是使用主机名的问题:

  root@ubuntu:/etc/dhcp# curl -vvv http://example.com
  * Rebuilt URL to: http://example.com/
  * Could not resolve host: example.com
  * Closing connection 0
  curl: (6) Could not resolve host: example.com

我可以使用 IP 地址连接到 example.com。我截断了响应,因为它不相关。关键是我绝对连接到互联网。我的问题是 DNS 出错了。

curl -H "Host: example.com" "http://93.184.216.34"
<!doctype html>
<html>
<head>
    <title>Example Domain</title>

    <meta charset="utf-8" />
    <meta http-equiv="Content-type" content="text/html; charset=utf-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1" />
    <style type="text/css">
    body {
        background-color: #f0f0f2;
        margin: 0;
        padding: 0;

这是我的 DNS 服务器:

nmcli dev show | grep DNS
IP4.DNS[1]:                             172.16.217.2

这似乎有效:

dig @172.16.217.2 example.com

; <<>> DiG 9.10.3-P4-Ubuntu <<>> @172.16.217.2 example.com
; (1 server found)
;; global options: +cmd
;; Got answer:
;; ->>HEADER<<- opcode: QUERY, status: NOERROR, id: 42927
;; flags: qr rd ra; QUERY: 1, ANSWER: 1, AUTHORITY: 0, ADDITIONAL: 2

;; OPT PSEUDOSECTION:
; EDNS: version: 0, flags:; MBZ: 0005 , udp: 1220
;; QUESTION SECTION:
;example.com.           IN  A

;; ANSWER SECTION:
example.com.        5   IN  A   93.184.216.34

;; ADDITIONAL SECTION:
example.com.        5   IN  TXT "ETPA"

;; Query time: 184 msec
;; SERVER: 172.16.217.2#53(172.16.217.2)
;; WHEN: Tue Mar 09 14:45:02 EST 2021
;; MSG SIZE  rcvd: 84

我的 resolve.conf 文件可能有问题:

root@ubuntu:/etc/dhcp# ls -latr /etc/resolv.conf 
lrwxrwxrwx 1 root root 37 Jan  5 12:21 /etc/resolv.conf -> /run/systemd/resolve/stub-resolv.conf
root@ubuntu:/etc/dhcp# ls -latr /run/systemd/resolve/stub-resolv.conf
ls: cannot access '/run/systemd/resolve/stub-resolv.conf': No such file or directory

“主机”命令失败

root@ubuntu:/etc/dhcp# host -v -d example.com
Trying "example.com"
;; connection timed out; no servers could be reached

那么,为什么 curl 或我的浏览器或任何无法使用主机名的东西?我应该如何诊断和修复?

这是关键问题; resolv.conf 指向一个不存在的文件。

root@ubuntu:/etc/dhcp# ls -latr /etc/resolv.conf 
lrwxrwxrwx 1 root root 37 Jan  5 12:21 /etc/resolv.conf ->   /run/systemd/resolve/stub-resolv.conf
root@ubuntu:/etc/dhcp# ls -latr /run/systemd/resolve/stub-resolv.conf
ls: cannot access '/run/systemd/resolve/stub-resolv.conf': No such file or  directory

修复方法是将其指向现有文件:

ln -s /run/systemd/resolve/resolv.conf /etc/resolv.conf

根据您发布的结果,名称服务器 @ 172.16.217.2 工作正常,但不清楚它是否用于地址 resolution.That,这就是我询问 /etc/resolve.conf 的原因系统查找要使用的名称服务器的地方。 看起来有些 systemd 服务破坏了这个文件(我在 Kubuntu 20.04 上有 /etc/resolv,conf -> /var/run/resove.conf)。

软件包 resolveconfresolveconf-admin 可能有助于解决此类问题。