域名是我们的服务的主要入口,请求一个域名时,首先需要通过 DNS 将域名解析成 IP。但是太频繁请求 DNS 的话,会影响服务响应速度,所以很多客户端、ISP 服务商都会对 DNS 做缓存,不过这种多层级缓存,直接导致了刷新域名解析变得很难。 即使花钱刷新多个带宽服务商的缓存,我们个别区域仍旧需要等待至少 48 小时,才能完成大部分用户的缓存刷新。 如果我们因为网站故障等特殊原因必须切换 IP 时,带来的影响将是灾难性的,好在近几年我们可以通过 CDN、GTM、HttpDNS 来强化我们多机房的流量调度。 但 CDN、GTM 都是针对机房的调度,对业务方是透明的。所以,在更重视用户体验的高并发场景中,我们会自己实现一套调度系统。 在这种自实现方案中,你会发现自实现里的思路和 HttpDNS 和 GSLB 的很类似,区别在于之前的服务只是基础服务,我们自实现的服务还可以快速地帮助我们调度用户流量。 而通过 HttpDNS 来实现用户切机房,切视频流的实现无疑是十分方便简单的,只需要在我们 App 发送请求的封装上更改链接的 IP,即可实现业务无感的机房切换。
相关推荐
东方小月4 分钟前
Claude Code Skill 完全指南:一个 markdown 文件,就是一个专家分身DianSan_ERP20 分钟前
抖店订单接口中消费者信息加密解密机制与安全履约全解析紫洋葱_popo1 小时前
一文吃透 LangChain 流式输出:同步、异步、LCEL 链式穿透全解析松就是我902981 小时前
LLM 代理服务实现原理文档fliter1 小时前
Rust 的承诺:不是没有复杂性,而是把复杂性放到你能看见的地方fliter1 小时前
Rust 模块和文件不是一回事:一次讲清 `mod`、`use`、`pub use`绯雾sama1 小时前
易扣AI (Go + CloudWeGo) 企业级AI智能体项目教程 第2章:后端项目用户模块搭建fliter1 小时前
半小时读懂 Rust:从语法符号到所有权思维fliter1 小时前
深入 Rust enum 的内存世界