域名是我们的服务的主要入口,请求一个域名时,首先需要通过 DNS 将域名解析成 IP。但是太频繁请求 DNS 的话,会影响服务响应速度,所以很多客户端、ISP 服务商都会对 DNS 做缓存,不过这种多层级缓存,直接导致了刷新域名解析变得很难。 即使花钱刷新多个带宽服务商的缓存,我们个别区域仍旧需要等待至少 48 小时,才能完成大部分用户的缓存刷新。 如果我们因为网站故障等特殊原因必须切换 IP 时,带来的影响将是灾难性的,好在近几年我们可以通过 CDN、GTM、HttpDNS 来强化我们多机房的流量调度。 但 CDN、GTM 都是针对机房的调度,对业务方是透明的。所以,在更重视用户体验的高并发场景中,我们会自己实现一套调度系统。 在这种自实现方案中,你会发现自实现里的思路和 HttpDNS 和 GSLB 的很类似,区别在于之前的服务只是基础服务,我们自实现的服务还可以快速地帮助我们调度用户流量。 而通过 HttpDNS 来实现用户切机房,切视频流的实现无疑是十分方便简单的,只需要在我们 App 发送请求的封装上更改链接的 IP,即可实现业务无感的机房切换。
相关推荐
JohnYan8 分钟前
工作笔记 - 一个浏览器环境适用的类型转换工具得物技术23 分钟前
0基础带你精通Java对象序列化--以Hessian为例|得物技术Java水解1 小时前
MySQL UPDATE 语句:数据更新操作详解Java水解1 小时前
深入浅出:在 Koa 中实现优雅的中间件依赖注入lssjzmn1 小时前
构建实时消息应用:Spring Boot + Vue 与 WebSocket 的有机融合金銀銅鐵1 小时前
[Java] 浅析可重复注解(Repeatable Annotation) 是如何实现的用户8174413427481 小时前
Kubernetes集群核心概念 Service掘金一周1 小时前
凌晨零点,一个TODO,差点把我们整个部门抬走 | 掘金一周 9.11yeyong1 小时前
日志告警探讨,我问deepseek答,关于elastalertCyan_RA91 小时前
SpringMVC 执行流程分析 详解(图解SpringMVC执行流程)