拯救流量爆炸的 Vercel——使用Cloudflare Workers做负载均衡
九月 17, 2023
事情起因
这两天,把我的某个网站的评论系统换成了 Twikoo,过了几天一看,因为网站访问量比较高(日 2k+),Vercel 的云函数使用量直接爆炸
我这一想,嘶~这到时候 Vercel 给我封了咋整。随即,我就开始查找相关负载均衡的资料。因为我之前完全没有做过这方面的功课,所以光是查资料就用了半天。瞎找半天,发现结果 Cloudflare 支持基于 DNS 的负载均衡方案,但是我定睛一看,只有 A 记录和 AAAA 记录支持,各种云函数平台基本上都是 CNAME 的,这可难办啊。
再看 Cloudflare 的动态负载均衡方案,5 刀,死贵,当即放弃。
一线曙光
当我在吃饭的时候,突然想到 Cloudflare 有 Workers 这个功能,那我是不是可以去薅 cf 的羊毛呢?
Cloudflare Workers 每天有 100k 次的请求次数,对于我这种每天全站最大请求次数只有 31k 的小站足够了,何况我目前要分流的仅仅是一个 Twikoo!
解决方案
于是乎,我当即就让一个朋友(无中生友)帮我写了 Workers 代码。这个代码能够将发送到 Workers 的流量根据权重分流到不同的 URL。(是的你没听错,它甚至支持配置权重!)
下面是完整代码
1 | // 要分流的url,支持添加多条url |
查看评论