刷新本地 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](https://file1.elecfans.com//web2/M00/9D/DD/wKgaomTn-TWAGSq0AAEQGfUhuSs841.png)
![d43abb2a-1367-11ee-962d-dac502259ad0.png](https://file1.elecfans.com//web2/M00/9D/DD/wKgaomTn-TWAZ3wDAAKYJGHeAuU872.png)
![d4532958-1367-11ee-962d-dac502259ad0.png](https://file1.elecfans.com//web2/M00/9D/DD/wKgaomTn-TWAdrQYAALdbetI0qo033.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](https://file1.elecfans.com//web2/M00/9D/DD/wKgaomTn-TWAHK6mAAHs034CL9A364.png)
linuxmi@linuxmi ~/www.linuxmi.com % sudo nscd -g
![d4ce3094-1367-11ee-962d-dac502259ad0.png](https://file1.elecfans.com//web2/M00/9D/DD/wKgaomTn-TWAIYYOAAH56bQIzDo400.png)
顯示由 dnsmasq 生成的 DNS 緩存
dnsmasq 將 DNS 緩存存儲在內存中,因此獲取確切的記錄并不容易。但是您可以向 dnsmasq 發送終止信號并記錄其輸出以獲取處理的 DNS 查詢數。 為此,首先,使用 systemctl 命令確保 dnsmasq 已啟動并正在運行:
linuxmi@linuxmi ~/www.linuxmi.com % sudo systemctl status dnsmasq
![d4e06476-1367-11ee-962d-dac502259ad0.png](https://file1.elecfans.com//web2/M00/9D/DD/wKgaomTn-TaADhE4AAKexzvKYus278.png)
linuxmi@linuxmi ~/www.linuxmi.com % sudo pkill -USR1 dnsmasq
![d50b98ee-1367-11ee-962d-dac502259ad0.png](https://file1.elecfans.com//web2/M00/9D/DD/wKgaomTn-TaATQhUAAB2ivprrbk876.png)
linuxmi@linuxmi ~/www.linuxmi.com % sudo journalctl -u dnsmasq > ~/cache.txt最后,使用文件查看實用程序(如 cat 或更少)查看文件的內容:
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
![d579f500-1367-11ee-962d-dac502259ad0.png](https://file1.elecfans.com//web2/M00/9D/DD/wKgaomTn-TaAQSHIAADh0ZLx3sM380.png)
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](https://file1.elecfans.com//web2/M00/9D/DD/wKgaomTn-TaAfbhNAADb3xVgOeU237.png)
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鍵: 單擊清除主機緩存 Clear host cache以清除存儲在谷歌瀏覽器中的DNS條目。
-
Linux
+關注
關注
87文章
11345瀏覽量
210385 -
緩存
+關注
關注
1文章
241瀏覽量
26757 -
DNS
+關注
關注
0文章
219瀏覽量
19926
原文標題:你真的會在 Linux 上查看和刷新 DNS 緩存嗎?
文章出處:【微信號:magedu-Linux,微信公眾號:馬哥Linux運維】歡迎添加關注!文章轉載請注明出處。
發布評論請先 登錄
相關推薦
![](https://file1.elecfans.com/web2/M00/85/47/wKgZomRmKAuALTdcAABZTnh4_NY871.png)
【Raspberry Pi 3試用體驗】+ 搭建本地DNS服務器
基于DNS緩存中毒的Webmail攻擊及防護
Linux基礎教程之如何在linux不解壓tar.gz文件查看的文件大小資料概述
如何在Windows,Linux和MacOS操作系統清除或刷新DNS緩存
如何在Linux中查看隱藏文件
如何在SpringBoot中解決Redis的緩存穿透等問題
聊聊本地緩存和分布式緩存
![聊聊<b class='flag-5'>本地</b><b class='flag-5'>緩存</b>和分布式<b class='flag-5'>緩存</b>](https://file1.elecfans.com/web2/M00/89/79/wKgZomSFdEmASFnfAAA2r5uJbrA027.png)
緩存之美——如何選擇合適的本地緩存?
![<b class='flag-5'>緩存</b>之美——如何選擇合適的<b class='flag-5'>本地</b><b class='flag-5'>緩存</b>?](https://file1.elecfans.com//web2/M00/0C/47/wKgaomcyxP6Adt0qAABfE5AgeRg699.png)
評論