全球智能DNS解析实践

身不由己

一、什么是智能DNS解析

以下是百度的解释:

DNS策略解析最基本的功能是可以智能的判断访问您网站的用户,然后根据不同的访问者把您的域名分别解析成不同的IP地址。如访问者是网通用户,DNS策略解析服务器会把你的域名对应的网通IP地址解析给这个访问者。如访问者是电信用户,DNS策略解析服务器会把您域名对应的电信IP地址解析给这个访问者。

举个例子,我们有个域名:ab.com,服务器部署在2个机房:中国、美国;当前访问用户的IP为中国,DNS解析会返回一个中国的IP;换之是海外用户,DNS会返回海外地址,这样保证每次用户都可以就近访问,加快访问速度。

二、为什么要使用智能DNS解析

智能DNS解析使用条件如下:

1、对外统一域名访问

即所有用户访问的都是统一域名。

2、用户分散在多地域,并且网络差异很大

可能是中国南、北,也可能是中国、海外。

这样在使用智能DNS解析后,用户可以就近访问,明显提高访问速度。

三、智能DNS解析的范围

既然是DNS,就得和域名有关,那智能DNS需要将哪些域名做智能解析呢?

1、前端页面

主要指前端页面,即用户直接在浏览器里输入的地址,但不包括里面的js/css,图片内容,因为这些可以通过CDN的方式处理。

2、后端接口

因为前端页面做了DNS解析,因此后端接口至少和前端页面的主域保持一致,因为涉及到登录状态的检测,具体来说就是cookie的传递,因为http是无状态的,所以通过cookie来保存状态。

四、具体实践

下面我们以一个具体的案例来分析智能DNS解析来如何实现。

设想我们网站用户主要是中国、美国用户,因此服务器部署在中国、美国机房,域名为ab.com。

首先我们来分析具体有哪些需求:

1、访问链路

A、中国用户访问中国服务

B、中国用户访问美国服务

      因为中国用户也可能需要访问海外的站点

C、外国用户访问外国服务

D、外国用户访问中国服务

      同上面的B一样

2、url规划

     中国和海外的页面都是同一域名,那最终区别也只能通过域名了,一般是不同的地区加不同的前缀,像我们这个案例中,可以这样规划:

ab.com/cn

ab.com/us

     如果web服务器使用的是nginx,在中国机房配一个ab.com的server,再配2个location,大概如下:

location /us{
   proxy_pass {美国服务器集群地址}
}

location /cn{
   proxy_pass {中国服务器集群地址}
}

这里要注意集群地址配置,现在大多数公司前面有个大的负载均衡器,负载均衡器的IP可能是不固定,如果是这种情况,则需要一种机制能够在负载均衡器更改IP的情况下能自动更新集群IP,不然可能出现无法访问的情况,我们线上就发生过样的问题。

海外机房也可以参考中国机房配置。

3、自动跳转

     如果用户每次都要输入ab.com/us或ab.com/cn,体验就差别差,所以我们需要根据用户的IP自动跳转到相应的机房中。

 
 即如果一个美国用户输入ab.com,会跳转到ab.com/us,还包括具体一个页面的跳转,即访问 ab.com/abc,自动跳转到ab.com/us/abc

如果使用的nginx服务器,可以使用GEOIP模块获取用户IP所在国家,然后写上lua脚本做相应的跳转。

五、踩过的坑

1、URL不标准化

     标准化如果没有做到,做起来会很麻烦;

     具体来说,如果美国的部分页面在中国没有,或者中国某个页面在美国服务器上没有,则会出现有的URL需要跳,有的不需要,则要在代码中做大量的特别处理;

    另外就是要考虑爬虫之类的请求,这类请求不管当前用户来自哪里,都不应该做跳转。

2、URL规范很重要

     如果仅仅是几个机房之间跳转的需求还好,实际情况是有的公司可能有多商城的需求,两者混在一起,URL的规范就很重要了,建议以机房为前缀,机房后再加上商城的标识。

      如 ab.com/global/us,ab.com/globl/uk

3、不要和现有业务逻辑耦合在一起

     这块的代码一般是在nginx上用lua实现的,如果在nginx上还有其它相关代码,建议两者分开,不然调试、维护起来会很麻烦。

从一次线上故障来看redis删除机制

PHP内存池分析

一次线上Mysql死锁分析

阅读 2.7k
30 声望
4 粉丝
0 条评论
30 声望
4 粉丝
文章目录
宣传栏