Linux Mint 18.1下/etc/hosts不被浏览器读取的问题求助
嘿,我来帮你搞定这个hosts解析的怪事!浏览器不认本地域名但curl正常,大概率是浏览器自身缓存、DNS设置或者系统DNS服务的问题,咱们一步步排查解决:
排查与解决步骤
1. 先清浏览器DNS缓存
浏览器会自己存DNS缓存,哪怕系统hosts改了,它可能还抱着旧缓存不放:
- Chrome/Edge:地址栏敲
chrome://net-internals/#dns,点「Clear host cache」就能清空 - Firefox:地址栏输
about:networking#dns,点「Clear DNS Cache」 - 其他浏览器:找「隐私与安全」设置,清除缓存时记得勾选「DNS缓存」选项
2. 关掉浏览器的自定义DNS
很多浏览器默认开了安全DNS/DoH,会绕过系统hosts直接走自己的DNS服务器:
- Chrome:设置→隐私和安全→安全→把「使用安全DNS」的开关关掉
- Firefox:设置→常规→网络设置→设置→取消勾选「启用DNS over HTTPS」
3. 检查系统nsswitch.conf配置
你提到了/etc/nsswitch.conf,这文件决定了系统读取域名解析的顺序,必须确保files(也就是优先读hosts)在dns前面:
正常的hosts行应该是这样的:
hosts: files dns mdns4_minimal [NOTFOUND=return] mdns4
如果你的配置里dns在files前面,修改后保存,然后重启nscd服务(装了的话):
sudo service nscd restart
没装nscd的话,直接重启系统也能生效。
4. 重启本地DNS缓存服务
Linux Mint可能跑着dnsmasq或者systemd-resolved这类本地缓存服务,它们有时候会忽略hosts的更新:
- 重启dnsmasq:
sudo service dnsmasq restart
- 重启systemd-resolved:
sudo systemctl restart systemd-resolved
也可以手动清空系统DNS缓存:
# 针对systemd-resolved sudo systemctl restart systemd-resolved # 针对dnsmasq的话,清空缓存文件再重启 sudo rm -rf /var/cache/dnsmasq/* && sudo service dnsmasq restart
5. 用隐私模式测试
打开浏览器的无痕/隐私模式访问本地域名,如果能正常解析,说明是普通模式下的扩展或者缓存搞的鬼。这时候可以逐个禁用扩展,排查哪个在干扰DNS解析。
6. 确认hosts文件格式没问题
你给的hosts开头是正常的,但要确保本地域名条目格式正确,比如:
127.0.0.1 mydevsite.local 127.0.0.1 anotherdevsite.local
IP和域名之间至少要有一个空格或制表符,注释要放在#后面,别加多余的特殊字符。
内容的提问来源于stack exchange,提问作者khusseini




