如何在 Linux 上查看和刷新 DNS 缓存

通过刷新本地 DNS 缓存,您可以解决 HTTP 错误并保护自己免受 DNS 欺骗的影响。以下是在 Linux 上执行此操作的方法。

当您使用域名访问网站时,您的系统会向 DNS 服务器发送请求以获取该域的 IP 地址。此域 IP 地址对保存在 DNS 缓存中供以后使用,因此您不必每次都向 DNS 服务器发送请求以建立连接。

但有时,本地 DNS 缓存会损坏并导致 HTTP 错误。值得庆幸的是,在 Linux 操作系统中刷新和重建 DNS 缓存非常容易。这是如何做到的。

如何在 Linux 上查看和刷新 DNS 缓存

为什么要在 Linux 上刷新 DNS 缓存?

您可能想要重建存储在系统上的 DNS 缓存的原因有多种。如果您的DNS记录过时了,您可能想要从DNS服务器重新获取它。另外,如果您担心系统受到威胁了,您可能需要确保DNS缓存未被篡改,也被称为DNS欺骗。

当您刷新 DNS 缓存时,系统必须再次 ping DNS 服务器并从中获取新的域 IP 地址记录,从而在此过程中删除任何过时或受损的数据。

如何在 Linux 上查看本地 DNS 缓存

在systemd之前,大多数Linux发行版都没有系统范围的DNS缓存,除非像dnsmasq或nscd这样的程序是手动设置的。systemd 附带 systemd-solved,这是一项将域名解析为 IP 地址并缓存 DNS 条目的服务。

以下各节将指导您如何查看由 systemd 解析、nscd 和 dnsmasq 生成的 DNS 缓存内容,以便您在决定刷新缓存数据之前了解缓存的数据。

查看系统解析的 DNS 缓存

要查看 systemd 解析的缓存记录,您需要先暂时终止服务,然后将其日志导出到文件中。

首先发送 SIGUSR1 信号以终止 systemd 解析的服务:

linuxmi@linuxmi ~/www.linuxmi.com % sudo killall -USR1 systemd-resolved[sudo] linuxmi 的密码: 登录后复制

linuxmi@linuxmi ~/www.linuxmi.com % sudo journalctl -u systemd-resolved > ~/cache.txtlinuxmi@linuxmi ~/www.linuxmi.com登录后复制

然后,您可以使用 Vim 等文本编辑器查看文件的内容:

如何在 Linux 上查看和刷新 DNS 缓存

在文件中,搜索“CACHE:”,方法是按 Escape,键入“/CACHE:”,然后按 Enter 键。在“CACHE:”下方列出的所有 DNS 记录都包含在本地 DNS 缓存中。若您在使用 Vim,请按下 n 键以跳转至下一组 DNS 条目。

如何在 Linux 上查看和刷新 DNS 缓存

查看 nscd 的本地 DNS 缓存

要查看 nscd 生成的本地缓存,您需要使用 string 命令读取 nscd 主机数据库的内容。

在基于 Debian 和 Ubuntu 的发行版上,此文件位于 /var/cache/nscd/hosts。运行以下命令以查看文件:

linuxmi@linuxmi ~/www.linuxmi.com % sudo strings /var/cache/nscd/hosts | uniq登录后复制

要查看有关 nscd DNS 高速缓存的一般统计信息,请使用 -g 标志:

linuxmi@linuxmi ~/www.linuxmi.com % sudo nscd -g登录后复制

显示由 dnsmasq 生成的 DNS 缓存

获取确切的记录并不容易,因为 dnsmasq 在内存中存储 DNS 缓存。您可以发送终止信号给 dnsmasq 并记录其输出,以获取处理的 DNS 查询数量。

为此,首先,使用 systemctl 命令确保 dnsmasq 已启动并正在运行:

linuxmi@linuxmi ~/www.linuxmi.com % sudo systemctl status dnsmasq登录后复制

如果状态显示“活动 Active”,请运行以下命令以终止该服务:

linuxmi@linuxmi ~/www.linuxmi.com % sudo pkill -USR1 dnsmasq登录后复制

使用 journalctl 命令,提取 dnsmasq 日志并将它们保存到文本文件中:

linuxmi@linuxmi ~/www.linuxmi.com % sudo journalctl -u dnsmasq > ~/cache.txt登录后复制

linuxmi@linuxmi ~/www.linuxmi.com % cat ~/cache.txt登录后复制

如何在 Linux 上刷新 DNS 缓存

刷新 DNS 缓存意味着从计算机中删除缓存的 DNS 记录。这将迫使它向DNS服务器发送请求,以获取新的DNS条目。

以下是在 Linux 上刷新 DNS 缓存的方法:

使用 systemd 解析

您可以使用 resolvectl 命令刷新 systemd 解析存储的 DNS 缓存:

linuxmi@linuxmi ~/www.linuxmi.com % sudo resolvectl flush-caches登录后复制

如果您运行的是 Ubuntu 17.04 或 18.04,请使用 systemd 解析的命令刷新缓存:

sudo systemd-resolved --flush-caches登录后复制