0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

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

马哥Linux运维 来源:马哥Linux运维 2023-06-26 10:52 次阅读

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

当您使用域名访问网站时,您的系统会向 DNS 服务器发送请求以获取该域的 IP 地址。此域 IP 地址对保存在 DNS 缓存中供以后使用,因此您不必每次都向 DNS 服务器发送请求以建立连接。 但有时,本地 DNS 缓存会损坏并导致 HTTP 错误。幸运的是,在 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 的密码:
使用journalctl 命令和标准输出运算符将输出保存到文本文件: 相关:如何使用 journalctl 查看和分析 Systemd 日志https://www.linuxmi.com/journalctl-systemd-logs.html

linuxmi@linuxmi ~/www.linuxmi.com
 % sudo journalctl -u systemd-resolved > ~/cache.txt
linuxmi@linuxmi ~/www.linuxmi.com
d4027828-1367-11ee-962d-dac502259ad0.png 然后,您可以使用 Vim 等文本编辑器查看文件的内容: d43abb2a-1367-11ee-962d-dac502259ad0.png 在文件中,搜索“CACHE:”,方法是按 Escape,键入“/CACHE:”,然后按Enter键。“CACHE:”下列出的所有 DNS 记录都是本地 DNS 缓存的一部分。如果您使用的是 Vim,请按n跳转到下一组 DNS 条目。 d4532958-1367-11ee-962d-dac502259ad0.png

查看 nscd 的本地 DNS 缓存

要查看 nscd 生成的本地缓存,您需要使用 string 命令读取 nscd 主机数据库的内容。 在基于 Debian 和 Ubuntu 的发行版上,此文件位于 /var/cache/nscd/hosts。运行以下命令以查看文件:

linuxmi@linuxmi ~/www.linuxmi.com
 % sudo strings /var/cache/nscd/hosts | uniq
d48d06aa-1367-11ee-962d-dac502259ad0.png 要查看有关 nscd DNS 高速缓存的一般统计信息,请使用 -g标志:
linuxmi@linuxmi ~/www.linuxmi.com
 % sudo nscd -g
d4ce3094-1367-11ee-962d-dac502259ad0.png

显示由 dnsmasq 生成的 DNS 缓存

dnsmasq 将 DNS 缓存存储在内存中,因此获取确切的记录并不容易。但是您可以向 dnsmasq 发送终止信号并记录其输出以获取处理的 DNS 查询数。 为此,首先,使用 systemctl 命令确保 dnsmasq 已启动并正在运行:

linuxmi@linuxmi ~/www.linuxmi.com
 % sudo systemctl status dnsmasq
d4e06476-1367-11ee-962d-dac502259ad0.png如果状态显示“活动 Active”,请运行以下命令以终止该服务:


linuxmi@linuxmi ~/www.linuxmi.com
 % sudo pkill -USR1 dnsmasq
d50b98ee-1367-11ee-962d-dac502259ad0.png 使用 journalctl 命令,提取 dnsmasq 日志并将它们保存到文本文件中:
linuxmi@linuxmi ~/www.linuxmi.com
 % sudo journalctl -u dnsmasq > ~/cache.txt
最后,使用文件查看实用程序(如 cat 或更少)查看文件的内容:


linuxmi@linuxmi ~/www.linuxmi.com
 % cat ~/cache.txt

d553d514-1367-11ee-962d-dac502259ad0.png

如何在 Linux 上刷新 DNS 缓存

刷新 DNS 缓存意味着从计算机中删除缓存的 DNS 记录。这会强制它向 DNS 服务器发送请求以检索新的 DNS 条目。 以下是在 Linux 上刷新 DNS 缓存的方法:

使用 systemd 解析

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

linuxmi@linuxmi ~/www.linuxmi.com
 % sudo resolvectl flush-caches
d579f500-1367-11ee-962d-dac502259ad0.png 如果您运行的是 Ubuntu 17.04 或 18.04,请使用 systemd 解析的命令刷新缓存:
sudo systemd-resolved --flush-caches

在 Linux 上刷新 nscd DNS 缓存

删除 nscd 的 DNS 缓存的最便捷方法是重新启动服务。您可以通过运行以下命令来执行此操作:

linuxmi@linuxmi ~/www.linuxmi.com
 % sudo /etc/init.d/nscd restart
d5a7ccf0-1367-11ee-962d-dac502259ad0.png 如果这不起作用,首先,检查存储在PC上的本地缓存是否持久。您可以使用 -g标志进行验证:
sudo nscd -g
如果是这种情况,请使用带有 nscd 命令的-i 标志来清除记录(i代表invalidate):
linuxmi@linuxmi ~/www.linuxmi.com
 % sudo nscd -i hosts

删除 dnsmasq DNS 缓存

刷新 dnsmasq 生成的 DNS 缓存很简单。由于缓存存储在内存中,因此重新启动服务会删除所有存储的条目。 要重新启动 dnsmasq,请运行以下 systemctl 命令:

sudo systemctl restart dnsmasq
或者,发出以下命令:
service dnsmasq restart
如果出现提示,请输入管理员密码。dnsmasq 现在将重新启动,所有现有的 DNS 条目将从缓存中删除。 刷新 DNS 缓存后,最好查看本地缓存条目并验证数据是否已成功删除。您可以使用 dig(许多网络故障排除 Linux 命令之一),并检查输出中的“查询时间”值。如果超过 0 毫秒,则缓存已成功清除(0 毫秒表示域记录仍在缓存中)。
dig google.com

清除谷歌浏览器的DNS缓存

您经常使用的 Web 浏览器也会缓存 DNS 记录。输入 URL 时,系统会在本地浏览器缓存中搜索缓存条目。如果未找到,它将检查本地系统缓存中的记录。清除 Web 浏览器的 DNS 缓存至关重要,因为它的优先级高于系统范围的缓存。 为了演示,让我们刷新谷歌浏览器中的DNS缓存。在其他浏览器上也有一些方法可以做到这一点,所以最好 Google 一下如何使用你使用的浏览器做到这一点。 首先,在URL栏中键入“chrome://net-internals/#dns”并按Enter键d5b6b9a4-1367-11ee-962d-dac502259ad0.png 单击清除主机缓存 Clear host cache以清除存储在谷歌浏览器中的DNS条目。

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • Linux
    +关注

    关注

    87

    文章

    10991

    浏览量

    206735
  • 缓存
    +关注

    关注

    1

    文章

    220

    浏览量

    26441
  • DNS
    DNS
    +关注

    关注

    0

    文章

    199

    浏览量

    19604

原文标题:你真的会在 Linux 上查看和刷新 DNS 缓存吗?

文章出处:【微信号:magedu-Linux,微信公众号:马哥Linux运维】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    如何选择合适的本地缓存

    小编最近在使用系统的时候,发现尽管应用已经使用了 redis 缓存提高查询效率,但是仍然有进一步优化的空间,于是想到了比分布式缓存性能更好的本地缓存,因此对领域内常用的
    的头像 发表于 01-18 11:19 504次阅读
    如何选择合适的<b class='flag-5'>本地</b><b class='flag-5'>缓存</b>?

    怎样清除dns缓存,教程来了 #电脑小技巧

    电脑缓存DNS
    学习硬声知识
    发布于 :2022年11月02日 02:16:59

    【Raspberry Pi 3试用体验】+ 搭建本地DNS服务器

    会首先寻找本地的 /etc/hosts 文件,再去寻找缓存下来的域名, 最后去上游 dns 服务器寻找。所以/etc/hosts才是dnsmasq第一个寻找的地方。
    发表于 04-24 21:39

    如何解决DNS解析错误故障

    :更换本地DNS的方法目前国内电信运营商通过使用DNS劫持的方法,干扰用户正常上网,使得用户无法访问,(例如弹出广告窗口),所以我一直在使用GoogleDNS,不仅可以解决中国的电信运营商的流氓行为,还可
    发表于 09-29 15:14

    linuxDNS缓存清空方法

    LinuxDNS缓存实现通常有两种方式:一种是用DNS缓存程序NSCD(name service cache daemon)负责管理
    发表于 07-25 07:53

    linux的高速缓存DNS怎么设置

    linux 高速缓存DNS
    发表于 08-12 12:06

    基于DNS缓存中毒的Webmail攻击及防护

    针对Webmail 的特性,提出一种基于域名系统(DNS)缓存中毒(Cache Poisoning)的Web 邮箱(Webmail)攻击技术,并对整个攻击流程进行描述,实现了对当前安全性较高的Live Mail 的成功攻击,验证DNS
    发表于 03-23 09:05 24次下载

    Linux文件缓存使用情况和命中率查看的工具详细概述

    这里总结几个Linux文件缓存(page cache)使用情况、命中率查看的工具。
    的头像 发表于 06-18 17:51 8614次阅读
    <b class='flag-5'>Linux</b>文件<b class='flag-5'>缓存</b>使用情况和命中率<b class='flag-5'>查看</b>的工具详细概述

    Linux基础教程之如何在linux不解压tar.gz文件查看的文件大小资料概述

    本文档的主要内容详细介绍的是Linux基础教程之如何在linux不解压tar.gz文件查看的文件大小详细程序资料免费下载。
    发表于 10-31 17:06 2次下载

    虚拟机:Linux查看DNS服务器IP地址的方法

    虚拟机:Linux查看DNS服务器IP地址的方法
    的头像 发表于 06-22 15:12 1.3w次阅读
    虚拟机:<b class='flag-5'>Linux</b><b class='flag-5'>查看</b><b class='flag-5'>DNS</b>服务器IP地址的方法

    探讨DNS服务器解析

    本地 DNS 服务器收到来自客户端的 DNS 请求,它会在其缓存中查找 google.com 的 IP 地址。如果它可以找到对应的条目,它将直接将 IP 地址返回给客户端。否则,
    的头像 发表于 05-05 15:42 1270次阅读

    何在Windows,Linux和MacOS操作系统清除或刷新DNS缓存

    DNS缓存是一个临时数据库,用于存储已解释的DNS查询信息。换句话说,每当您访问网站时,您的操作系统和网络浏览器都会保留域名和相应IP地址的记录。
    的头像 发表于 12-05 16:08 2179次阅读

    何在Linux查看隐藏文件

    在windows可以查看隐藏的文件。在Linux中也可以查看隐藏文件且非常容易。要查看隐藏文件运行`ls -a`命令即可。
    的头像 发表于 01-04 17:31 1.5w次阅读

    何在SpringBoot中解决Redis的缓存穿透等问题

    今天给大家介绍一下如何在SpringBoot中解决Redis的缓存穿透、缓存击穿、缓存雪崩的问题。
    的头像 发表于 04-28 11:35 521次阅读

    聊聊本地缓存和分布式缓存

    本地缓存 :应用中的缓存组件,缓存组件和应用在同一进程中,缓存的读写非常快,没有网络开销。但各应用或集群的各节点都需要维护自己的单独
    发表于 06-11 15:12 581次阅读
    聊聊<b class='flag-5'>本地</b><b class='flag-5'>缓存</b>和分布式<b class='flag-5'>缓存</b>