1. 域名系统DNS

1.1 主机名和域名的关系

(1)完全限定域名(Fully Qualified Domain Name, FQDN) = 主机名 + 域名

  ①一个域名下可以有多个服务器/主机(如上图中有3台服务器/主机)。

  ②主机名更多的代表一个服务或应用,它物理服务器并有没有一一对应的关系。如www、blog、bbs三个服务网站位于同一台服务器,而edu在一个独立的服务器上。

  ③通常所说的网站域名,严格来说是完全限定域名

(2)域名的层次结构

  ①所有的域名都是以英文“.”开始,是域名的根,根下面是顶级域名,然后依次是二级、三级域名、…。如www.cctv.com.(注意com后面有一个“.”,代表根域名,可以省略)

  ②企业申请域名后,可以在该域名下添加多个主机名,也可以根据需要创建子域名,子域名下又可以有多个主机名。

1.2 域名的解析过程

(1)域名服务器

  ①每台域名服务器并不知道其上一级DNS是谁?但他们都知道根域名服务器

  ②DNS服务器可以创建委派,将其下的某个子域名委派给其他DNS服务器来解析

(2)解析过程(以Client1查询www.sohu.com为例)

  ①Client1向DNS服务器(13.2.1.2)发送域名解析请求

  ②B服务器只负责net域名解析,并不知道哪个DNS服务器负责com域名解析,但它知道根DNS服务器,于是将域名解析的请求转发给根DNS服务器

  ③根DNS服务器返回查询结果,告诉B去查询C服务器

  ④B服务器将域名解析请求转发到C服务器

  ⑤C服务器只负责com名称解析,但sohu.com名称解析委派给了E服务器,于是C服务器告诉B去查询E服务器

  ⑥B服务器将域名解析请求转发到了E服务器。

  ⑦E服务器上有sohu.com域名下的www主机记录,于是www.sohu.com的IP返回给B服务器

  ⑧B服务器将费尽周析查找到的结果缓存一份到本地将解析到的www.sohu.com的IP地址返回给Client1。这个查询结果是B服务器从其他服务器查询得到的(非权威应答)缓存解析的结果。

  ⑨Client2的DNS也指向了13.2.1.2,现在Client2也需要解析www.sohu.com的地址,将域名解析请求发送给B服务器。

  ⑩B服务器将刚刚缓存www.sohu.com的查询结果直接返回给Client2。

(3)其它

  ①权威应答和非权威应答:当Client1向B服务器查询www.inhe.net时,由于B服务器本身存在这条主机记录,这时它向Client1返回的结果被称为权威应答。否则,如果B服务器对域名的解析是从其他服务器查询到的,则为非权威应答(如client查询sohu网站的过程)

  ②client3向E服务器查询www.xueit.com域名时,由于E服务器不存在这条主机记录,因此会向根服务器查询(不是C服务器)。因为对于E来说他只知道根服务器,而并不知道其上一级(C)服务器的存在!

1.3 实战:在Win2003系统上搭建DNS服务器

(1)网络拓扑图

(2)测试环境的搭建

  ①将xp主机和Win2003服务器放入VMNnet8网络。xp的DNS服务器设置192.168.80.20。

  Win2003服务器的“首选的DNS服务器”也设置为192.168.80.20,即Win2003服务器除了为局域网内的其他主机提供DNS解析,本身所需要的DNS解析也由自己提供

  ②创建DNS正向查找区域:如www.abc.com→192.168.80.10→www.abc.com(注意:要选启用DNS服务:“控制面板”→“管理工具”→“服务”→启动“DNS Server”)

    A.正向查找区域:“新建区域”→输入区域名称“abc.com”→选择“创建新文件”(一个区域用一个文件记录),然后一直next。

    B.新建主机:右键“abc.com” →“新建主机”→在主机名中填入“www”,IP为192.168.80.10。

  ③创建DNS反向查找区域:(如192.168.80.10→www.abc.com)

    A.反向查找区域:“新建区域”→“主要区域”→在“网络ID”填入“192.168.80” →选择“创建新文件”。

    B.“新建指针(ptr)” →在主机IP号中填入“10”,主机名为www。

(3)查看和设置DNS服务器的“根服务器”: DNS管理器中选择服务器名→“属性”→“根提示”

(4)测试域名解析

  ①使用ping命令:如ping www.abc.com

  ②查看缓存中的域名解析结果:ipconfig /displaydns

  ③清空DNS缓存:ipconfig /flushdns

  ④nslookup测试域名解析:如nslookup www.baidu.com。或输入nslookup,然后在交互模式下输入想要查询的域名,exit退出。

【测试结果】

C:\Documents and Settings\Administrator>nslookup
*** Can't find server name for address 192.1
*** Default servers are not available
Default Server: UnKnown
Address: 192.168.80.20 > www.abc.com //正向查找
Server: UnKnown
Address: 192.168.80.20 Name: www.abc.com
Address: 192.168.80.10 > 192.168.80.10 //反向查找
Server: UnKnown
Address: 192.168.80.20 Name: www
Address: 192.168.80.10 > www.baidu.com //查找外网的baidu
Server: UnKnown
Address: 192.168.80.20 Non-authoritative answer:
Name: www.a.shifen.com
Addresses: 163.177.151.110, 163.177.151.109
Aliases: www.baidu.com >exit

1.4 实战:抓包分析域名解析过程

(1)在Win2003上运行抓包工具,然后在XP主机ping www.51cto.com

(2)Internet上DNS返回的结果

  ①DNS解析的4种数据包:域名解析请求(第3个数据包)、域名解析请求转发(第4个数据包)、转发包的应答(第7个数据包)及最终查询结果(第9个数据包)

  ②Authoritative nameservers字段中列举了负责解析51cto.com的DNS服务器域名,其IP在Additional record字段中。

(3)返回给客户端的域名解析最终结果

第9章 应用层(1)_域名系统DNS的更多相关文章

  1. [A Top-Down Approach][第二章 应用层]

    [A Top-Down Approach][第二章 应用层] 标签(空格分隔): 未分类 网络应用是计算机网络存在的理由 首先从定义几个关键的应用层概念开始 应用程序所需要的网络服务,客户和服务器,进 ...

  2. 关于域名系统DNS解析IP地址的一些总结

    关于域名系统DNS(Domain Name System) 从域名中解析出IP地址. DNS主要由3部分组成: ① 名称解析器(resolver) ② 域名空间(domain name space) ...

  3. 套接字和域名系统DNS

    套接字产生的原因: 当应用进程通过传输层进行通信时 ,TCP和 UDP将面临同时为多个应用进程提供并行通信的问题.多个TCP连接或多个应用程序进程可能需要通过同一个TCP协议端口传输数据. 为了区别每 ...

  4. 计算机网络之域名系统DNS

    域名系统DNS 域名系统DNS(Domai NameSystem)是因特网使用的命名系统,用于把便于人们使用的机器名字转换为IP地址. 许多应用层软件经常直接使用域名系统,但计算机的用户只是间接而不是 ...

  5. 域名系统-DNS

    域名系统DNS 域名系统DNS(Domain Name System)是互联网使用的命名系统,用来把便于人们使用的机器名转化为IP地址,域名系统就是名字系统. 很多应用层的软件经常直接使用DNS.DN ...

  6. 域名系统DNS和FTP

    域名系统概述 域名系统DNS(Domain Name System)是英特网使用的命名系统,用于把便于人们使用机器名字转化为IP地址. 为什么机器在处理IP数据报时要使用IP地址而不使用域名呢?IP地 ...

  7. 域名系统DNS

    一.域名系统是什么 域名系统其实就是一个把主机名解析为IP地址的名字系统. 因特网使用层次树状结构的命名方法,并使用分布式的域名系统DNS.因特网的域名系统DNS被设计成一个联机分布式数据库系统,并采 ...

  8. 带你简单了解域名系统DNS

    带你简单了解域名系统DNS 一.域名简介 1.1.DNS服务的作用 负责解析域名,将域名解析成IP地址. 1.2.域名系统概述 由于32位的IP地址并不容易记忆,人们往往喜欢记忆网站的域名.所以当我们 ...

  9. 第六章 应用层(DNS和http协议详解)

    序言 这是计算机网络基础的最后一篇博文了,大体的从物理层到最上层的应用层做了一个大概的了解,花了也有快1个月的时间了,在本章结尾会给你们我学习该课程的视频资料,我希望能帮到所有想学习想提高自己技术的同 ...

随机推荐

  1. madlib 集成 hasura graphql-engine 试用

    madlib 可以让我们直接在sql 中进行机器学习,集成了强大的sql 能力,以及分析能力,后边会尝试 集成graphql engine ,让功能更强大 docker 镜像准备 使用了一个别人的写好 ...

  2. Gravitee.io alert 引擎架构

    alert 在我们的实际开发中应用的场景很多,我们需要进行系统状态的查看,以及特殊异常请求的处理 参考架构图 从下图可以看出,还是很方便的,同时支持slack email... 的实时消息通知,而且我 ...

  3. Gravitational Teleport简单使用

    使用官方提供的二进制包进行快速启动测试,详细细节还需要在学习 下载软件包 mac 系统 https://gravitational.com/teleport/download/ wget https: ...

  4. 02C++namespace命名空间

    一.C++命名空间基本常识 所谓namespace,是指标识符的各种可见范围.C++标准程序库中的所有标识符都被定义于一个名为std的namespace中. 1.<iostream>和&l ...

  5. operator <<”不明确

    在声明重载的输出运算符<< 时,如果声明时的返回类型是std::ostream,而不是std::ostream&,但是定义的时候又加了引用的话,那么就会报“operator < ...

  6. linux shell创建目录、遍历子目录

    1.创建目录 代码1: #!/bin/bash#如果没有tmp_dir目录则创建static_dir="/web/fyunw.com/static"if [ ! -d $staic ...

  7. Golang 操作mysql使用举例---连接本地数据库

    连接数据库的方式有两种:TCP和Unix域socket. 本文使用Unix domain sockets连接数据库.关于TCP连接数据库可以参考Go 操作mysql使用举例 下面例子中,演示了使用sh ...

  8. 电信版华为MATE7 EMUI4.0回退3.1和3.0教程与中转包

    mate7升级6.0后遇到很多问题,想回退版本,找了很多教程,现在总结一下用中转包回退.EMUI4.0回退3.1,先下载B500中转包,将dload复制到2G以上内存卡根目录,不要三键强刷,会卡在开机 ...

  9. windows 下 Anaconda 安装 TensorFlow

    转自: https://www.cnblogs.com/nosqlcoco/p/6923861.html 什么是 Anaconda? Anaconda is the leading open data ...

  10. python cntl使用

    import sys 2 import time 3 import fcntl 4 5 class FLOCK(object): 6 7 def __init__(self, name): 8 sel ...