域名是我们的服务的主要入口,请求一个域名时,首先需要通过 DNS 将域名解析成 IP。但是太频繁请求 DNS 的话,会影响服务响应速度,所以很多客户端、ISP 服务商都会对 DNS 做缓存,不过这种多层级缓存,直接导致了刷新域名解析变得很难。 即使花钱刷新多个带宽服务商的缓存,我们个别区域仍旧需要等待至少 48 小时,才能完成大部分用户的缓存刷新。 如果我们因为网站故障等特殊原因必须切换 IP 时,带来的影响将是灾难性的,好在近几年我们可以通过 CDN、GTM、HttpDNS 来强化我们多机房的流量调度。 但 CDN、GTM 都是针对机房的调度,对业务方是透明的。所以,在更重视用户体验的高并发场景中,我们会自己实现一套调度系统。 在这种自实现方案中,你会发现自实现里的思路和 HttpDNS 和 GSLB 的很类似,区别在于之前的服务只是基础服务,我们自实现的服务还可以快速地帮助我们调度用户流量。 而通过 HttpDNS 来实现用户切机房,切视频流的实现无疑是十分方便简单的,只需要在我们 App 发送请求的封装上更改链接的 IP,即可实现业务无感的机房切换。
相关推荐
Victor3561 小时前
MongoDB(95)如何在MongoDB中使用加密存储引擎?Victor3561 小时前
MongoDB(96)如何使用MongoDB的高级聚合功能?IT利刃出鞘2 小时前
Spring工具类--ObjectUtils的使用2601_949816682 小时前
Spring boot启动原理及相关组件GetcharZp8 小时前
告别 jq 噩梦!这款 JSON 神器 fx 让你在终端体验“丝滑”的数据操作小码哥_常9 小时前
告别臃肿!Elasticsearch平替Manticore登场苍何10 小时前
万字保姆级教程:Hermes+Kimi K2.6 打造7x24h Agent军团我叫黑大帅10 小时前
为什么map查找时间复杂度是O(1)?FreeCultureBoy12 小时前
用 phpbrew 管理 php 环境:从安装到多版本切换FreeCultureBoy13 小时前
用 jenv 管理 Java 环境:从安装 JDK 到多版本切换