除了解析域名,DNS还能干吗?

一个http请求,典型的执行流程是怎么样的呢?

除了解析域名,DNS还能干吗?
可以看到,典型流程为:
(1)客户端请求dns-server,发起域名解析
(2)dns-server返回域名对应的外网ip(1.2.3.4);
(3)客户端通过外网ip(1.2.3.4),访问反向代理;
(4)反向代理通过内网ip(192.168.x.x),将请求分发给web-server;
(5)web-server对请求进行处理;
 
其中,第一个步骤,将域名转化ip的过程,发生在应用系统的外部,是通过DNS实现的。
除了域名解析,在架构设计时,还能利用DNS做一些什么事情呢?
一、用户就近访问
除了解析域名,DNS还能干吗?
DNS可以实现,用户所需资源的就近访问:
(1)电信用户想要访问某一个服务器资源;
(2)浏览器向dns-server发起域名解析请求;
(3)dns-server识别出访问者是电信用户;
(4)dns-server将电信机房的nginx外网ip返回给访问者;
(5)访问者就近访问;
根据用户ip来返回最近的服务器ip,称为“智能DNS”,CDN以及多机房多活中最常用。
 
二、反向代理水平扩展
除了解析域名,DNS还能干吗?
典型的互联网架构中,可以通过增加web-server来扩充web层的性能,但反向代理nginx仍是整个系统的唯一入口,如果系统吞吐超过nginx的性能极限,难以扩容,此时就需要dns-server来配合水平扩展。
除了解析域名,DNS还能干吗?
具体做法是:在dns-server对于同一个域名可以配置多个nginx的外网ip,每次DNS解析请求,轮询返回不同的ip,这样就能实现nginx的水平扩展,这个方法叫“DNS轮询”。
 
三、web-server负载均衡
除了解析域名,DNS还能干吗?
既然“dns轮询”可以将同一个域名的流量均匀分配到不同的nginx,那么也可以利用它来做web-server的负载均衡:
(1)架构中去掉nginx层;
(2)将多个web-server的内网ip直接改为外网ip;
(3)在dns-server将域名对应的外网ip进行轮询解析;
 
通过DNS来实施负载均衡有什么优缺点呢?
 
优点
(1)利用第三方DNS实施,服务端架构不用动;
(2)少了一层网络请求;
 
不足
(1)DNS只具备解析功能,不能保证对应外网ip的可用性,而nginx做反向代理时,与web-server之间有保活探测机制,当web-server挂掉时,能够自动迁移流量;
(2)当web-server需要扩容时,通过DNS扩容生效时间长,而nginx是服务端完全自己可控的部分,web-server扩容更实时更方便;
 
因为上面两个原因,架构上一般都使用高可用反向代理。

 

总结

架构设计中,除了域名解析,DNS还有其他用武之地:

(1)智能DNS,根据用户ip来就近访问服务器;

(2)DNS轮询,水平扩展反向代理层;

(3)利用DNS实施负载均衡;

希望大家有收获。

除了解析域名,DNS还能干吗?

扫码关注“架构师之路”视频

视频号要有100个关注,才能开通认证,希望大家成为前100个朋友感谢,感恩。

发布者:糖太宗,转载请注明出处:https://www.qztxs.com/archives/science/technology/6539

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022年5月14日 上午12:49
下一篇 2022年5月14日 上午12:51

相关推荐

  • 阿里云OSS Bucket 劫持

    对象存储OSS 阿里云对象存储OSS(Object Storage Service)是一款海量、安全、低成本、高可靠的云存储服务,提供99.9999999999%(12个9)的数据持久性,99.995%的数据可用性。多种存储类型供选择,全面优化存储成本。 劫持利用 访问某域名,提示 NoSuchBucket   获取信息,这个桶不存在 HostId...

    2022年6月13日
    13600
  • 什么是单机 集群 热备 磁盘阵列raid

    单机部署(stand-alone):只有一个饮水机提供服务,服务只部署一份。   集群部署(cluster):有多个饮水机同时提供服务,服务冗余部署,每个冗余的服务都对外提供服务,一个服务挂掉时依然可用。   热备部署(hot-swap):只有一个桶提供服务,另一个桶stand-by,在水用完时自动热替换,服务冗余部署,只有一个主服务对外提供服务,影子服务在...

    2022年5月11日
    4400
  • 服务之间通过缓存传递数据,我坚决反对!

    数据的移动,需要载体,DB和cache是常见的数据存储载体。 如上图: (1)service-A将数据放入cache; (2)service-B从cache里读取数据; cache作为数据存储载体的好处是: (1)cache的读取和写入都非常快; (2)service-A和service-B物理上解耦; 那么问题来了: (1)你遇到过这种“服务之间通过缓存传...

    2022年5月12日
    2500
  • OpenRASP 部署

    0x00 前言 上周一台web服务器部署单机版OpenRASP之后感觉还不错,想在公司内部推广一下,准备在一些后台系统的服务器上安装agent,单机版部署报警日志查看不是很方便,遂部署管理后台方便管理   0x01 准备 OpenRASP使用了 ElasticSearch 和 MongoDB 两种数据库。前者用来存储报警和统计信息,后者用来存储应用...

    2022年6月13日
    13700
  • MyISAM与InnoDB的索引,究竟有什么差异?

    数据库的索引分为主键索引(Primary Inkex)与普通索引(Secondary Index)。InnoDB和MyISAM是怎么利用B+树来实现这两类索引,其又有什么差异呢?这是今天要聊的内容。   一,MyISAM的索引 MyISAM的索引与行记录是分开存储的,叫做非聚集索引(UnClustered Index)。 其主键索引与普通索引没有本质差异: ...

    2022年5月11日
    2400

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注

联系我们

400-800-8888

在线咨询: QQ交谈

邮件:admin@example.com

工作时间:周一至周五,9:30-18:30,节假日休息

关注微信