• 首页 首页 icon
  • 工具库 工具库 icon
    • IP查询 IP查询 icon
  • 内容库 内容库 icon
    • 快讯库 快讯库 icon
    • 精品库 精品库 icon
    • 问答库 问答库 icon
  • 更多 更多 icon
    • 服务条款 服务条款 icon

阿里云云DNS核心概念和应用

武飞扬头像
Jiangxl~
帮助1

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我们的域名,并且从此以后可以直接在浏览器中通过域名访问我们的程序。

学新通

这篇好文章是转载于:学新通技术网

  • 版权申明: 本站部分内容来自互联网,仅供学习及演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,请提供相关证据及您的身份证明,我们将在收到邮件后48小时内删除。
  • 本站站名: 学新通技术网
  • 本文地址: /boutique/detail/tanhiahgeb
系列文章
更多 icon
同类精品
更多 icon
继续加载