无线APP时代HTTP请求DNS优化-通用

缘起:无线时代,网络稳定性差,应用流量敏感,APP与server之间每次HTTP请求都需要DNS解析,有没有优化方法呢?

一、PC时代,HTTP请求处理过程

(1)浏览器、或者PC客户端访问DNS服务器,由域名拿到IP(一般来说是个nginx的IP)

(2)浏览器、或者PC客户端用IP访问nginx

(3)nginx将请求分发给实际处理HTTP请求的web-server

二、无线APP时代的特点

(1)DNS解析的时间不能忽略

(2)一旦DNS被劫持,整个APP就挂了(还记得N年前baidu的域名被劫持的事情么?)

三、一种不需要DNS解析的HTTP请求优化方案

(1)第一次访问时,先拉取server的ip-list保存到本地,访问过程与普通HTTP访问过程相同

(2)未来访问时,客户端直接使用ip-list中的IP来访问server,不再需要DNS

(3)如果DNS被劫持,直接尝试使用ip-list中的IP访问

四、潜在的问题

(1)虽然少了一步DNS查询和一步nginx中转,那怎么做负载均衡呢?

答:APP随机访问ip-list中的IP

(2)使用nginx可以方便的增加后端的服务,不使用nginx如何做水平扩展呢?

答:直接在ip-list中增加ip即可

(3)每次访问都要访问ip-list,还是挺废流量的,还有其他优化方案么?

答:增加一个版本号,第一次拉取ip-list时,不但把ip-list放到APP本地,并把版本号也拿到。未来不用每次都拿ip-list,而是先拿版本号,如果版本号不变,直接使用本地的ip-list。只有版本号变化时,才需要重新拉取ip-list

(4)还有其他什么好处?

答:使用nginx不好做异构服务器的负载均衡,即难以根据后端服务的处理能力来分配负载。使用ip-list,只要加上一个权重参数,即可实现异构服务器的负载均,例如:

192.168.1.1, 10

192.168.1.2, 10

192.168.1.3, 20

可以看到,第三个后端服务的处理能力是前两个的两倍,APP做负载均衡时考虑上第二个参数即可

五、再次总结这种方案的好处

(1)不需要每次请求做DNS解析,节省时间

(2)不需要每次请求做nginx转发,节省时间

(3)不需要每次拉取拉取ip-list,节省流量

(4)DNS被劫持时仍可以使用本地ip

原文发布于微信公众号 - 架构师之路(road5858)

原文发表时间:2015-10-20

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏FreeBuf

某开源框架从注入到Getshell

0x00 前言 SemCms是一套开源外贸企业网站管理系统,主要用于外贸企业,兼容IE、Firefox 等主流浏览器。SemCms使用vbscript语言编写,...

22460
来自专栏猛牛哥的博客

Thinkphp5.1验证码错误Class ‘think\captcha\Captcha’ not found的解决方法

今天使用thinkphp5.1遇到个问题,验证码功能在本地环境调试正常,放到服务器上却无法显示,给出的错误信息是:致命错误: Class 'think\capt...

3K10
来自专栏公有云大数据平台弹性 MapReduce

简单了解公平调度器的一些队列设置

在腾讯云EMR的用户日常反馈中,经常会遇到因为YARN的队列配置不合理导致资源利用率不高,任务提交不上的问题,所以有了以下的文章,方便用户在日常按照一定的需求将...

24520
来自专栏开源优测

2000行代码,再不学习就老了

22350
来自专栏杨建荣的学习笔记

批量部署zabbix agent (r6笔记第55天)

zabbix作为系统级的监控还是非常给力,它总是在后台孜孜不倦的进行反反复复的检查和校验,然后通过邮件,短信,图形等方式来把系统的预警表达出来。 zabbix ...

32250
来自专栏极客生活

基于python flask详述 OAuth 2.0 的运作流程

OAuth2 对于我来说是一个神秘的东西,我想初步的弄懂中间的整个流程,于是就去google搜索相关的文档资料。

28340
来自专栏腾讯DevOps

Git远程库操作1

选择SSH方式,请先配置好公钥私钥,参见:https://code.tencent.com/help/productionDoc/profile#ssh

45340
来自专栏黑白安全

常见的爬虫的攻防策略

从网络开始的那一刻起,爬虫就肩负了她的使命,数据收集!尤其是大数据时代的到来,越来越多的企业认识到数据的重要性,数据成了一个企业的重要资产,数据的多样性给了爬虫...

9820
来自专栏黑白安全

信息搜集阶段可快速getshell的一些方式

2、各远程执行类漏洞,如,Struts2,iis,tomcat,proftp,elasticsearch...

16130
来自专栏FreeBuf

教你如何和使用这款强大的渗透平台-Xerosploit

写在前面的话 在这篇教程中,我们将教会大家如何使用Xerosploit。Xerosploit是一款渗透测试工具包,它的主要功能就是执行中间人攻击。它本身自带有多...

29090

扫码关注云+社区

领取腾讯云代金券