9. 使用队列异步处理耗时任务
队列系统的必要性
队列处理耗时任务,可以降低服务器响应时间,提高用户体验。这里分享一个小故事:
作者早年在一家公司就职,我们在运营一款时尚社交网站。此项目有一个用户注册入口,产品经理统计到注册提交页面的跳出率非常高,用户注册量骤减。经调查后发现,原来是用户使用新浪微博注册,确认好注册信息提交时,服务器会有一个新浪微博用户头像抓取并转存本地的动作,刚好那段时间内网 DNS 解析有问题,导致抓取头像的动作超时,最终用户在多次尝试未果后放弃了注册。
最终的解决方案是利用队列系统,将「获取新浪微博头像」这个 耗时且不稳定 的动作放到后台执行,实施后用户注册量恢复稳定。
请注意,所有的外网请求 ,因为网络的复杂度(DNS 污染、网络被挖掘机掐断等)以及第三方服务的不可控,都应该被视为 耗时且不稳定。