DNS域名解析

目录

1.概述

1.1产生原因

1.2作用

1.3连接方式

1.4因特网的域名结构

1.4.1拓扑

1.4.2分类

1.4.3域名服务器类型划分

2. DNS域名解析过程

2.1分类

2.2解析图

2.2.2过程分析

3.搭建DNS域名解析服务器

3.1.概述

3.2安装软件

3.3bind服务中三个关键文件

3.4主配置文件分析

3.5区域配置文件

3.5.1作用

3.5.2区域配置文件示例分析

●正向解析​编辑

3.6正向解析资源文件

3.6.1概述

3.6.2模板内容分析

3.6.4域名解析记录分析

3.7反向解析资源文件

3.8实验1:正向解析

3.8.1准备工作

3.8.2DNS解析配置

3.8.3注意:第三步数据配置文件可以进行精简

3.9实验2:反向解析


1.概述


1.1产生原因


●**IP地址:是互联网上计算机唯- -的逻辑地址, 通过IP地址实现不同计算机之间的相互通信,每
台联网计算机都需要通过IP地址来互相联系和分别,但由于IP地址是由一串容易混淆的数字串
构成,人们很难记忆所有计算机的IP地址,这样对于我们日常工作生活访问不同网站是很困难
的。
基于这种背景,人们在IP地址的基础.上又发展出了-种更易识别的符号化标识,这种标识由人
们自行选择的字母和数字构成,相比IP地址更易被识别和记忆,逐渐代替IP地址成为互联网用
户进行访问互联的主要入口。这种符号化标识就是域名
●域名虽然更易被用户所接受积使用,但计算机只能识别纯数字构成的IP地址,不能直接读取域
名。因此要想达到访问效果,就需要将域名翻译成IP地址。而DNS域名解析承担的就是这种翻
译效果


1.2作用


●DNS (Domain Name System)是互联网上的-项服务,用于将域名和IP地址进行相互映射,
使人更方便的访问互联网
正向解析:域名->IP
反向解析: IP->域名
 


1.3连接方式



DNS使用53端口监听网络

●查看方法:
●DNS默认以UDP这个较快速的数据传输协议来查询,但没有查询到完整的信息时,就会再次以
TCP协议重新查询则启动DNS时,会同时启动TCP以及UDP的port53


1.4因特网的域名结构


1.4.1拓扑


●由于因特网的用户数量较多,则因特网命名时采用层次树状结构的命名方法。
域名(domain name): 任何一个连接在因特网上的主机或路由器,都有一个唯一的层次结构的
名称
●域(domain): 是名字空间中-个可被管理的划分结构。

 


1.4.2分类


●国家顶级域名:采用IS03166的规定,如: cn代表中国, us代表美国,uk代表英国, 等等。国
家域名又常记为CCTLD(country code top-level domains, cc表示国家代码contry-code)
●通用顶级域名:最常见的通用顶级域名有7个
com (公司企业)
net (网络服务机构)
org (非营利组织)
int (国际组织)
gov (美国的政府部门)
mil (美国的军事部门)
●基础结构域名(infrastructure domain): 这种顶级域名只有一一个,即arpa,用于反向域名解
析,因此称为反向域名



1.4.3域名服务器类型划分




 


根域名服务器:最高层次的域名服务器,所有的根域名服务器都知道所有的顶级域名服务器的
域名和IP地址。本地域名服务器要对因特网上任何一个域名进行解析,只要自己无法解析,就首
先求助根域名服务器。则根域名服务器是最重要的域名服务器。假定所有的根域名服务器都瘫痪
了,那么整个DNS系统就无法工作。所以根域名服务器并不直接把待查询的域名直接解析出IP地
址,而是告诉本地域名服务器下一步应当找哪一个顶级域名服务器进行查询。

在与现有IPv4根服务器体系架构充分兼容基础上,由我国下一-代互联网国家工程中心领衔发

的"雪人计划”于2016年在美国、日本、印度、俄罗斯、德国、法国等全球16个国家完成25台
IPv6 (互联网协议第六版)根服务器架设,事实上形成了13台原有根加25台IPv6根的新格局,
 


为建立多边、民主、透明的国际互联网治理体系打下坚实基础。中国部署了其中的4台,由1台主
根服务器和3台辅根服务器组成,打破了中国过去没有根服务器的困境。
●顶级域名服务器:负责管理在该顶级域名服务器注册的二级域名
●权限域名服务器:负责-个”区"的域名服务器
●本地域名服务器:本地域名服务器不属于域名服务器的层次结构,当主机发出DNS查询时,这个
查询报文就发送给本地域名服务器
, 为了提高域名服务器的可靠性,DNS域名服务器都把数据复制到几个域名服务器来保存,如:
主服务器:在特定区域内具有唯- -性, 负责维护该区域内的域名与IP地址之间的对应关系
(真正干活的)
, 从服务器:从主服务器中获得域名与IP地址的对应关系并进行维护,以防主服务器宕机等情
况(打下手的)
缓存服务器:通过向其他域名解析服务器查询获得域名与IP地址的对应关系,并将经常查询

的域名信息保存到服务器本地,以此来提高重复查询时的效率, -般部署在企业内网的网关位
置,用于加速用户的域名查询请求
 


2. DNS域名解析过程


2.1分类


●递归解析: DNS服务器在收到用户发起的请求时,必须向用户返回- -个准确的查询结果。如果
DNS服务器本地没有存储与之对应的信息,则该服务器需要询问其他服务器,并将返回的查询结
果提交给用户
●迭代解析(反复) : DNS服务器在收到用户发起的请求时,并不直接回复查询结果,而是告诉另
-台DNS服务器的地址,用户再向这台DNS服务器提交请求,依次反复,直到返回查询结果


2.2解析图



 


2.2.2过程分析


第一步:在浏览器中输入www . google .com域名,本地电脑会检查浏览器缓存中有没有这个
域名对应的解析过的IP地址,如果缓存中有,这个解析过程就结束。浏览器缓存域名也是有限
制的,不仅浏览器缓存大小有限制,而且缓存的时间也有限制,通常情况下为几分钟到几小时不
等,域名被缓存的时间限制可以通过TTL属性来设置。这个缓存时间太长和太短都不太好,如果
时间太长,一旦域名被解析到的IP有变化,会导致被客户端缓存的域名无法解析到变化后的IP
地址,以致该域名不能正常解析,这段时间内有一部分用户无法访问网站。 如果设置时间太短,
会导致用户每次访问网站都要重新解析- -次域名
第二步:如果浏览器缓存中没有数据,浏览器会查找操作系统缓存中是否有这个域名对应的
DNS解析结果。其实操作系统也有一个[域名解析]的过程,在Linux 中可以通过/ etc/hosts文
件来设置,而在windows中可以通过配置C:\Windows\System32\drivers\etc\hosts 文件
来设置,用户可以将任何域名解析到任何能够访问的IP地址。例如,我们在测试时可以将一一个
域名解析到- -台测试服务器上,这样不用修改任何代码就能测试到单独服务器上的代码的业务逻
辑是否正确。正是因为有这种本地DNS解析的规程,所以有黑客就可能通过修改用户的域名来
把特定的域名解析到他指定的IP地址上,导致这些域名被劫持
第三步:前两步是在本地电脑.上完成的,若无法解析时,就要用到我们网络配置中的"DNS服务
器地址"了。操作系统会把这个域名发送给这个本地DNS服务器。每个完整的内网通常都会配
置本地DNS服务器,例如用户是在学校或工作单位接入互联网,那么用户的本地DNS服务器
肯定在学校或工作单位里面。它们- -般都会缓存域名解析结果,当然缓存时间是受到域名的失效
时间控制的。大约80%的域名解析到这里就结束了,后续的DNS迭代和递归也是由本地DNS
服务器负责
第四步:如果本地DNS服务器仍然没有命中,就直接到根DNS服务器请求解析
第五步:根DNS服务器返回给本地DNS域名服务器- -个顶级DNS服务器地址,它是国际顶级
域名服务器,如. com. .cn、 .org等, 全球只有13台左右
第六步:本地DNS服务器再向上- -步获得的顶级DNS服务器发送解析请求
第七步:接受请求的顶级DNS服务器查找并返回此域名对应的Name Server域名服务器的
地址,这个Name Server服务器就是我要访问的网站域名提供商的服务器,其实该域名的解析
任务就是由域名提供商的服务器来完成。比如我要访问 www.baidu.com. 而这个域名是从A
公司注册获得的,那么A公司.上的服务器就会有www.baidu.com的相关信息
第八步: 返回该域名对应的 IP和TTL值,本地DNS服务器会缓存这个域名和 IP的对应关系,
缓存时间由TTL值控制
●第九步: Name Server服务器收到查询请求后再其数据库中进行查询,找到映射关系后将其IP
地址返回给本地DNS服务器
●第十步:本地DNS服务器把解析的结果返回给本地电脑,本地电脑根据TTL值缓存在本地系统缓
存中,域名解析过程结束在实际的DNS解析过程中,可能还不止这10步,如Name Server可
能有很多级,或者有一个GTM来负载均衡控制,这都有可能会影响域名解析过程

 


注意:
从客户端到本地DNS服务器是属于递归查询,而DNS服务器之间使用的交互查询就是迭代查

114.114.114.114是国内移动、电信和联通通用的DNS,手机和电脑端都可以使用,干净无广
告,解析成功率相对来说更高,国内用户使用的比较多,而且速度相对快、稳定,是国内用户
上网常用的DNS。
223.5.5.5和223.6.6.6是阿里提供的免费域名解析服务器地址
8.8.8.8是GOOGLE公司提供的DNS, 该地址是全球通用的,相对来说,更适合国外以及访问
国外网站的用户使用

 


3.搭建DNS域名解析服务器


3.1.概述


●BIND: Berkeley Internet Name Domain,伯克利因特网域名解析服务是- -种全球使用最
广泛的、最高效的、最安全的域名解析服务程序


3.2安装软件


[root@server ~]# yum insta1l bind -y


3.3bind服务中三个关键文件


●/etc/named.conf:主配置文件,共59行,去除注释和空行之和有效行数仅30行左右,用于设置
bind服务程序的运行
●/etc/named.rfc1912.zones :区域配置文件(zone) ,用于保存域名和IP地址对应关系文件
的所在位置,类似于图书目录,当需要修改域名与IP映射关系时需要在此文件中查找相关文件位
●/var/named目录:数据配置文件目录,该目录存储保存域名和!P地址映射关系的数据文件
 

3.4主配置文件分析


●主配置文件共4部分组成
options{}
logging{}
zone{}
include
●常用参数:


●一般需要修改三部分:
listen-on port 53 { 127.0.0.1; };即监听ip及端口
allow-query { localhost; };允许那些客户端访问
recursion yes;是否开启递归查询


3.5区域配置文件


3.5.1作用


●/etc/named.rfc1912.zones文件为bind服务程序的区域配置文件,用来保存域名与IP地址映射
关系文件的位置,是一-系列功能模板的集合


3.5.2区域配置文件示例分析

●正向解析

 

●反向解析


3.6正向解析资源文件


3.6.1概述


●**查看:
[root@server ~]# vim /var/named/named.localhost
●注意:推荐对该模板文件进行局部修改


3.6.2模板内容分析
 




3.6.4域名解析记录分析


A记录: A代表Address,用来指定域名对应的IP地址,如将item.taobao.com指定到
115.238.23.xxx,将switch.taobao.com指定到121.14.24.xxx
MX记录: Mail Exchange,就是可以将某个域名下的邮件服务器指向自己的Mail Server,如
taobao.com域名的A记录IP地址是115.238.25.xxx,如果将MX记录设置为
115.238.25.xx,即xxx@taobao.com的邮件路由,DNS会将邮件发送到115.238.25.xxx
所在的服务器,而正常通过Web请求的话仍然解析到A记录的IP地址
NS记录:为某个包指定DNS解析服务器,也就是这个域名由指定的iP地址的DNS服务器取
解析
CNAME记录: Canonical Name,即别名解析。所谓别名解析就是可以为-一个域名设置- 个或
者多个别名,如将aaa.com解析到bbb.net.将ccc.com也解析到bbb.net,其中bbb.net
分别是aaa.com和cc.com的别名
●TXT记录:为某个主机名或域名设置说明,如可以为ddd.net设置TXT记录为"这是XXX的博
客"这样的说明
 

3.7反向解析资源文件

3.8实验1:正向解析

3.8.1准备工作

3.8.2DNS解析配置



●第一步:服务端操作,配置DNS主配置文件


●第二步:服务端操作,编辑区域配置文件,可以清空后添加,也推荐选择- 个解析模版进行修改


●第三步:服务端操作,编辑数据配置文件,推荐使用cp -a命令完全拷贝- -份正向解析模版

(named.localhost) ,在修改局部


3.8.3注意:第三步数据配置文件可以进行精简


●SOA起始授权记录: openlab.com. IN SOA ns.openlab.com. admin.openlab.com.(),
表示openlab.com.这个域名指定dns服务器为ns.openlab.com.这台主机,以及其它附加信息
●ns记录: openlab.com. IN NS ns.openlab.com. ,声明openlab.com.这个域名的dns服务器为ns.openlab.com.主机
●**以上区别: NS记录仅仅只是声明该域内哪台主机是dns服务器,用来提供名称解析服务, NS
记录不会区分哪台dns服务器是master哪台dns服务器是slave。而SOA记录则用于指定哪个NS
记录对应的主机是master dns服务器,也就是从多个dns服务器中挑选-台任命其为该域内的
master dns服务器,其他的都是slave,都需要从master上获取域相关数据
A记录:表示那台主机解析为什么IP地址
●CNAME记录: 别名
●精简原则:
可以使用@替代域名,如@替代openlab.com.
可以使用空格或tab重复继承上-行第-列的值
可以省略域名,会自动补全,如: www为www.openlab.com.
配置文件可以省略如下:
 


3.9实验2:反向解析

●第一步:服务端操作,基于上例,继续完成,主配置文件按照上例设置不变,编辑区域配置文
件,选择一个反向解析模版进行修改

●第二步:服务端操作,编辑数据配置文件,复制- -份反向解析模版(named.lcvpwwbash
改局部即可

●第三步:服务端重启服务

●第四步:客户端操作,测试

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/141115.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

PNAS | 蛋白质结构预测屈服于机器学习

今天为大家介绍的是来自James E. Rothman的一篇短文。今年的阿尔伯特拉斯克基础医学研究奖表彰了AlphaFold的发明,这是蛋白质研究历史上的一项革命性进展,首次提供了凭借序列信息就能够准确预测绝大多数蛋白质的三维氨基酸排列的实际能力。这一非凡的成就…

堆排序(大根堆、小根堆)

参考视频: 1、数据结构,小根堆的调整!必须熟练掌握! 2、数据结构建堆筛选输出最小值 | 计算机软件考研期末知识点2

Scikit-LLM:一款大模型与 scikit-learn 完美结合的工具!

Scikit-LLM 是文本分析领域的一项重大变革,它将像 ChatGPT 这样强大的语言模型与 scikit-learn 相结合,提供了一套无与伦比的工具包,用于理解和分析文本。 有了 scikit-LLM,你可以发现各种类型的文本数据中的隐藏模式、情感和上下…

【STM32】定时器+基本定时器

一、定时器的基本概述 1.软件定时器原理 原来我们使用51单片机的时候,是通过一个__nop()__来进行延时 我们通过软件的方式来进行延时功能是不准确的,受到很多不确定因素。 2.定时器原理:计数之间的比值 因为使用软件延时受到影响&#xff0c…

Spring中的循环依赖解决方案

前言:测试环境突发BeanCurrentlyInCreationException,导致后端服务启动失败,一看就是Spring的Bean管理中循环依赖。项目中存在Bean的循环依赖,是代码质量低下的表现。多数人寄希望于框架层来给擦屁股,造成了整个代码的…

大数据-玩转数据-Flume

一、Flume简介 Flume提供一个分布式的,可靠的,对大数据量的日志进行高效收集、聚集、移动的服务,Flume只能在Unix环境下运行。Flume基于流式架构,容错性强,也很灵活简单。Flume、Kafka用来实时进行数据收集,Spark、Flink用来实时处理数据,impala用来实时查询。二、Flume…

开放领域对话系统架构

开放领域对话系统是指针对非特定领域或行业的对话系统,它可以与用户进行自由的对话,不受特定领域或行业的知识和规则的限制。开放领域对话系统需要具备更广泛的语言理解和生成能力,以便与用户进行自然、流畅的对话。 与垂直领域对话系统相比…

AIX5.3安装weblogic10.3

目录 1安装IBM JDK 1.6 2图形化准备 3安装weblogic 准备 4图形化界面安装 1安装IBM JDK 1.6 1.1检查操作系统 # oslevel 5.3.0.0 # bootinfo -y (显示AIX机器硬件是64位) 64 # bootinfo -K (显示AIX系统内核是64位) 64 因此,系统需要安装64位的jdk,…

JavaWeb Day09 Mybatis-基础操作01-增删改查

目录 环境准备 ①Emp.sql ②Emp.java 一、删除 ①Mapper层 ②测试类 ③预编译SQL(查看mybatis日志) 1.性能 2.安全 ④总结 二、新增 ①Mapper层 ②测试类 ③结果 ④新增(主键返回) 1.Mapper层 2.测试类 ⑤总结​…

上机4KNN实验4

目录 编程实现 kNN 算法。一、步骤二、实现代码三、总结知识1、切片2、iloc方法3、归一化4、MinMaxScale()5、划分测试集、训练集6、KNN算法 .py 编程实现 kNN 算法。 1、读取excel表格存放的Iris数据集。该数据集有5列,其中前4列是条件属性…

Carla之语义分割及BoundingBox验证模型

参考: Carla系列——4.Cara模拟器添加语义分割相机(Semantic segmentation camera) Carla自动驾驶仿真五:opencv绘制运动车辆的boudingbox(代码详解) Carla官网Bounding Boxes Carla官网创建自定义语义标签…

【QT】飞机大战

0 项目简介 飞机大战是我们大家所熟知的一款小游戏,本教程就是教大家如何制作一款自己的飞机大战 首先我们看一下效果图 玩家控制一架小飞机,然后自动发射子弹,如果子弹打到了飞下来的敌机,则射杀敌机,并且有爆炸的特…

隧道施工工艺流程vr线上虚拟展示成为产品3D说明书

行业内都知道,汽车生产的大部分都需要冲压加工来完成,因此汽车冲压工艺是汽车制造过程中的重要环节,传统的展示方式往往局限于二维图纸和实地操作,难以充分展现工艺的细节和流程。然而,随着技术的进步,汽车…

不同优化器的应用

简单用用,优化器具体参考 深度学习中的优化器原理(SGD,SGDMomentum,Adagrad,RMSProp,Adam)_哔哩哔哩_bilibili 收藏版|史上最全机器学习优化器Optimizer汇总 - 知乎 (zhihu.com) import numpy as np import matplotlib.pyplot as plt import torch # …

优秀智慧园区案例 - 中建科技产业园(中建·光谷之星),万字长文解析先进智慧园区建设方案经验

一、项目背景 中建科技产业园(中建光谷之星),位于武汉光谷中心城、中国(湖北)自贸试验区武汉片区双核心区,光谷发展主轴高新大道北侧,建筑面积108万平米,是中建三局“中建之星”和“…

设计模式—结构型模式之代理模式

设计模式—结构型模式之代理模式 代理模式(Proxy Pattern) ,给某一个对象提供一个代理,并由代理对象控制对原对象的引用,对象结构型模式。 静态代理 比如我们有一个直播平台,提供了直播功能,但是如果不进行美颜,可能就比较冷清…

Adobe Photoshop 2020给证件照换底

1.导入图片 2.用魔法棒点击图片 3.点选择,反选 4.选择,选择并遮住 5.用画笔修饰证件照边缘 6. 7.更换要换的底的颜色 8.新建图层 9.使用快捷键altdelete键填充颜色。 10.移动图层,完成换底。

【ArcGIS Pro微课1000例】0030:ArcGIS Pro中自带晕渲地貌工具的妙用

在ArcGIS中,制作地貌晕渲效果通常的做法是先制作山体阴影效果,然后叠加在DEM的下面,再改变DEM的透明度来实现。而在ArcGIS Pro中自带了效果显著的晕渲地貌工具。 文章目录 一、晕渲地貌工具1. 符号系统2. 栅格函数二、山体阴影效果1. 工具箱2. 栅格函数打开ArcGIS Pro3.0,加…

【C++】类和对象(2)--构造函数

目录 一 概念 二 构造函数特性 三 默认构造函数 一 概念 对于以下Date类&#xff1a; class Date { public:void Init(int year, int month, int day){_year year;_month month;_day day;}void Print(){cout << _year << "-" << _month <…

C语言 每日一题 牛客网 11.13 Day17

找零 Z国的货币系统包含面值1元、4元、16元、64元共计4种硬币&#xff0c;以及面值1024元的纸币。 现在小Y使用1024元的纸币购买了一件价值为N(0 < N≤1024)的商品&#xff0c;请问最少他会收到多少硬币&#xff1f; 思路 运用if语句进行判断分类 代码实现 int main() {…