文章目录
- 1.DNS解析基本概念
- 1.1.DNS基本介绍
- 1.2.域名的分层结构
- 1.3.DNS解析原理
- 1.4.DNS递归查询和迭代查询的区别
- 1.5.DNS常用的解析记录
- 2.使用DNS云解析将域名与SLB公网IP进行绑定
- 2.1.进入云解析DNS控制台
- 2.2.添加域名解析记录
- 2.3.验证解析是否生效
1.DNS解析基本概念
DNS官方文档:https://help.aliyun.com/document_detail/102237.html
1.1.DNS基本介绍
DNS 是域名系统 (Domain Name System) 的缩写,是因特网的一项核心服务,它作为可以将域名和IP地址相互映射的一个分布式数据库,能够使人更方便的访问互联网,而不用去记住能够被机器直接读取的IP数串。
我们在访问一个应用系统时,在没有使用DNS前,都是使用IP去访问的,IP的组成都是数字,难以记忆,DNS可以将IP解析成方便记忆的域名,例如jiangxl.com,在浏览器中输入jiangxl.com就可以跳转到对应的应用服务器,为我们提供服务,域名和IP相比,域名是非常好记忆的。
DNS核心功能
- 记录域名与IP的对应关系
- 通过DNS可以将经常需要变换IP的固定成一个访问入口,即使变换了IP,使用者无感知。
DNS的分类
- 公网DNS(万网)通过此类DNS可以访问任意互联网应用。
- 私网DNS(bind9)此类DNS只能在局域网环境使用。
一个典型使用DNS迁移场景 如下图所示
当我们的MySQL数据库需要进行迁移,数据库从上海迁移到了北京机房,IP肯定是要变的,当更改了IP,连接数据库的程序都需要进行修改成新的IP,如果我们WEB节点较少还可以接收,如果我们的WEB节点有几十台甚至上台,我们一个个的去修改程序连接会变得非常麻烦,即使我们有自动化更新流程,时间也是很长的,也会涉及到WEB程序的重启。
针对这种情况,我们可以将数据库的IP和域名写入到一个本子里,方便程序记忆,这个本子就是/etc/hosts文件,这个文件可以记录域名与IP的对应关系,我们给MySQL服务器设置一个域名,比如叫mysql.example.com,将数据库的IP和域名的对应关系写入到/etc/hosts文件中,当我们需要更换数据库IP时,只需要将每个服务器/etc/hosts中域名对应的IP进行修改即可完成迁移,并且程序也不需要重启。
虽然将IP和域名写入到了一个文件里,修改文件即可,但是如果面对上千台服务器时,过程也会变得繁琐。
针对新的问题,从而就需要应用DNS服务器了,在服务器环境中部署一个DNS服务器,在DNS服务器中记录数据库IP与域名的对应关系,并且在DNS中开启for转发配置,然后在每台WEB服务器中指定本地DNS的地址,当我们程序需要连接数据库时,会通过DNS找到提供MySQL服务的地址,当访问互联网时也会通过for配置转发到公网DNS服务器,当我们需要更换数据库IP时,就可以直接修改DNS的域名解析记录即可完成。
DNS的几个关键的专业术语
-
DNS缓存
- DNS缓存也就是CDN,在使用CDN之前一定要搞清楚DNS,DNS缓存就是将解析的数据存储在距离用户最近的网络节点,最终目的就是让用户减少迭代查询的速度,从而加速网站的访问。
-
TTL
- TTL全称为Time To Live,这个值用于去设定域名解析结果缓存的时间,时间结束后会自动删除解析记录,再次使用时还需要重新进行递归和迭代查询。
-
TLD Server
- 顶级域服务器
-
DNS Resolver
- 本地DNS服务器
-
Root Server
- 根域服务器
1.2.域名的分层结构
在互联网中使用域名的用户非常多,因特网在命名时将域名分为根域、顶级域、主域名、子域名四层。
根域服务器全球只有13台,并且根域只有一个,那就是点".",DNS的解析流程最开始到达的也就是根域。
顶级域就是我们常见的.com、.cn、.edu等等,这类域名统称为顶级域名,所有用户都可以在顶级域的基础上去申请主域名。
主域名也就被称为一级域名,如jiangxl.com这个主域名,每个用户都需要在顶级域的基础上去申请自己的一级域名,每个人每家企业都都独立的主域名。
子域名也就是我们常常说到的二级域名或者主机头,在主域名的基础上申请二级域名,可以为不同的应用程序申请不同的二级域名,例如www.jiangxl.com这个域名就是在主域名的基础上申请的二级域名。
另外还可有三级域名,三级域名就看个人和企业的需求了,可以在二级域名的基础上再申请三级域名,例如cn201212.www.jiangxl.com.cn
这个域名,通常一个应用程序有不同的区域使用,不同的区域可以通过不同的三级域名作为区分的标准。
1.3.DNS解析原理
以用户访问www.jiangxl.com域名为例讲解DNS的解析原理。
1)用户在浏览器中输入"www.jiangxl.com",若在/etc/hosts文件中有域名解析记录,则直接返回给用户,若不存在本地解析记录,则由本地DNS服务器开始递归查询。
2)本地DNS服务器没有域名解析记录,开始采用迭代查询找到根域服务器,并向根域服务起询问"你知道谁是.com吗"。
3)根域服务器向本地DNS服务器说我知道".com"域名是谁,并将.com的服务器信息一并告知本地DNS服务器。
4)本地DNS服务器根据信息找到了."com"的顶级域服务器,开始询问你知道谁是"jiangxl.com"吗。
5)顶级域服务器说我知道谁是"jiangxl.com",并将"jiangxl.com"域名发服务器信息告知本地服务器。
6)本地服务器根据信息找到了"jiangxl.com"主域服务器,开始询问你知道谁是"www.jiangxl.com"吗。
7)主域服务器说我知道谁是"www.jiangxl.com",并将"www.jiangxl.com"域名服务器的信息告知给本地服务器。
8)本地DNS拿到"www.jiangxl.com"域名对应的服务器信息后,将解析记录反馈给客户端。
9)浏览器根据解析记录,向"www.jiangxl.com"对应的WEB服务器发送HTTP请求。
10)该WEB服务器将结果呈现在用户的浏览器中。
1.4.DNS递归查询和迭代查询的区别
DNS查询分为递归查询和迭代查询两种。
-
递归查询
- 是指DNS服务器在收到用户发起的请求时,必须向用户返回一个准确的查询结果。如果DNS服务器本地没有存储与之对应的信息,则该服务器需要询问其他服务器,并将返回的查询结构提交给用户。
- 简而言之,递归查询必须返回给用户一个准确的解析地址,如果查找的服务器不存在该记录就需要询问其他服务器
- 递归查询就好比工作中领导安排一件事情,不管过程,只要最终的结果。
-
迭代查询
- 是指DNS服务器在收到用户发起的请求时,并不直接回复查询结果,而是告诉另一台DNS服务器的地址,用户再向这台DNS服务器提交请求,这样依次反复,直到返回查询结果。
- 简而言之,迭代查询是指当前服务器并不知道这条解析记录,但是这个服务器知道哪个服务器拥有这条记录,并将信息告知。
- 迭代查询就好比是在工作中,你要处理一个问题,询问了你的同事,你同事说我不知道但是领导肯定指定,让你去问领导。
递归查询和迭代查询效果图如下,蓝线表示递归查询,可以看到直接就需要返回给客户端,黑线表示迭代查询,一层层的进行查询。
在DNS的解析过程中,用户与本地服务器直接使用递归查询,本地服务器与其他服务器直接采用迭代查询。
1.5.DNS常用的解析记录
A记录:将域名解析到指定的IPV4地址。
CNAME:将域名解析到另一个域名,由另一个域名提供具体的服务
AAAA:将域名解析到IPV6地址。
NS:将域名指定到另一个DNS服务器进行解析。
MX:将域名解析到邮箱服务器。
2.使用DNS云解析将域名与SLB公网IP进行绑定
2.1.进入云解析DNS控制台
在控制台中找到云解析,点击进入云解析DNS的控制台。
2.2.添加域名解析记录
1)在域名解析这里找到我们的域名,点击解析设置。
2)点击添加记录—>记录类型为A记录—>在主机记录这里填写主机名—>记录值为SLB的公网地址,也就是域名要解析的地址。
2.3.验证解析是否生效
解析添加完成后,就可以在本地cmd中ping我们的域名,并且从此以后可以直接在浏览器中通过域名访问我们的程序。