域名是我们的服务的主要入口,请求一个域名时,首先需要通过 DNS 将域名解析成 IP。但是太频繁请求 DNS 的话,会影响服务响应速度,所以很多客户端、ISP 服务商都会对 DNS 做缓存,不过这种多层级缓存,直接导致了刷新域名解析变得很难。 即使花钱刷新多个带宽服务商的缓存,我们个别区域仍旧需要等待至少 48 小时,才能完成大部分用户的缓存刷新。 如果我们因为网站故障等特殊原因必须切换 IP 时,带来的影响将是灾难性的,好在近几年我们可以通过 CDN、GTM、HttpDNS 来强化我们多机房的流量调度。 但 CDN、GTM 都是针对机房的调度,对业务方是透明的。所以,在更重视用户体验的高并发场景中,我们会自己实现一套调度系统。 在这种自实现方案中,你会发现自实现里的思路和 HttpDNS 和 GSLB 的很类似,区别在于之前的服务只是基础服务,我们自实现的服务还可以快速地帮助我们调度用户流量。 而通过 HttpDNS 来实现用户切机房,切视频流的实现无疑是十分方便简单的,只需要在我们 App 发送请求的封装上更改链接的 IP,即可实现业务无感的机房切换。
相关推荐
duapple2 小时前
Golang基于反射的ioctl实现my_styles5 小时前
docker-compose部署项目(springboot服务)以及基础环境(mysql、redis等)ruoyi-ry免檒6 小时前
go语言协程调度器 GPM 模型不知道写什么的作者7 小时前
Flask快速入门和问答项目源码caihuayuan57 小时前
生产模式下react项目报错minified react error #130的问题一只码代码的章鱼7 小时前
Spring Boot- 2 (数万字入门教程 ):数据交互篇不再幻想,脚踏实地11 小时前
Spring AOP从0到1编程乐学(Arfan开发工程师)11 小时前
07、基础入门-SpringBoot-自动配置特性会敲键盘的猕猴桃很大胆11 小时前
Day11-苍穹外卖(数据统计篇)极客智谷11 小时前
Spring Cloud动态配置刷新:@RefreshScope与@Component的协同机制解析