记一次DNS解析js失败而阻塞渲染的问题及解决方案

事情的起因

在渲染某页面时, 引入了一个地图插件的js, 由于这个js在加载时会出现加载失败的情况, 加载失败时就会阻塞整个页面的渲染从而导致页面空白

原因分析 - 什么情况会出现加载js失败

  • 不是完全能复现, 排查下来发现只有chrome有这个问题
  • 而且chrome在连接浏览器代理时不会出现加载失败的情况
  • 在连接公司vpn的情况下不会出现加载失败的情况
  • 北京同事连公司内网也不会出现这个问题

整体看下来只有在使用chrome直接连接公司上海的有线, 不走浏览器代理, 就会精准复现

为什么会出现这种情况

由于只有在chrome浏览器上出现这个问题 - 考虑是浏览器问题
由于走代理就不会出现这个问题 - 考虑是域名解析的问题
由于连接公司有线就会出现这个问题 - 考虑是不同网络走的dns服务器不同

最后, 定位到, 是由于chrome浏览器中默认开启了使用安全DNS
image

关闭之后, 就可以正常访问了

chrome使用安全DNS

所有使用Chrome 85版本的用户,都将在浏览器的设置中看到一个名为“安全DNS”的新选项。 所有用户都将默认启用安全DNS选项,一旦打开,Chrome将尝试以加密的形式(通过DoH)进行DNS查询,并使用传统的纯文本DNS作为应急计划。

DNS over HTTPS (DoH)是什么

使用 HTTPS 发送和检索加密的DNS查询和响应的协议

为什么要使用DoH

参考链接 - 告别DNS劫持,一文读懂DoH
参考链接 - 基于DoH的隐蔽通信的机理与防御

在日常上网中,如果用户输入

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值