DNS协议

参考链接:https://blog.csdn.net/fenfei_zqh/article/details/79665434

1、IP地址是面向主机的,而域名则是面向用户的。

2、一个组织的系统管理机构, 维护系统内的每个主机的IP和主机名的对应关系

如果新计算机接入网络,将这个信息注册到数据库中

用户输入域名的时候,会自动查询DNS服务器,由DNS服务器检索数据库,得到对应的IP地址 

3、域名系统必须要保持唯一性。 
为了达到唯一性的目的,因特网在命名的时候采用了层次结构的命名方法: 
       每一个域名都是一个标号序列(labels),用字母(A-Z,a-z,大小写等价)、数字(0-9)和连接符(-)组成 
      标号序列总长度不能超过255个字符,它由点号分割成一个个的标号(label) 
     每个标号应该在63个字符之内,每个标号都可以看成一个层次的域名。 
     级别最低的域名写在左边,级别最高的域名写在右边。 
     域名服务主要是基于UDP实现的,服务器的端口号为53。 

4、

有了域名结构,还需要有一个东西去解析域名,域名需要由遍及全世界的域名服务器去解析,域名服务器实际上就是装有域名系统的主机。

由高向低进行层次划分,可分为以下几大类:

5、域名解析过程

域名解析总体可分为一下过程: 
(1) 输入域名后, 先查找自己主机对应的域名服务器,域名服务器先查找自己的数据库中的数据. 
(2) 如果没有, 就向上级域名服务器进行查找, 依次类推 
(3) 最多回溯到根域名服务器, 肯定能找到这个域名的IP地址 
(4) 域名服务器自身也会进行一些缓存, 把曾经访问过的域名和对应的IP地址缓存起来, 可以加速查找过程 
具体可描述如下: 
1. 主机先向本地域名服务器进行递归查询 
2. 本地域名服务器采用迭代查询,向一个根域名服务器进行查询 
3. 根域名服务器告诉本地域名服务器,下一次应该查询的顶级域名服务器的IP地址 
4. 本地域名服务器向顶级域名服务器进行查询 
5. 顶级域名服务器告诉本地域名服务器,下一步查询权限服务器的IP地址 
6. 本地域名服务器向权限服务器进行查询 
7. 权限服务器告诉本地域名服务器所查询的主机的IP地址 
8. 本地域名服务器最后把查询结果告诉主机 


递归查询和迭代查询 
(1)递归查询:本机向本地域名服务器发出一次查询请求,就静待最终的结果。如果本地域名服务器无法解析,自己会以DNS客户机的身份向其它域名服务器查询,直到得到最终的IP地址告诉本机 
(2)迭代查询:本地域名服务器向根域名服务器查询,根域名服务器告诉它下一步到哪里去查询,然后它再去查,每次它都是以客户机的身份去各个服务器查询。
 

6、反向DNS

反向DNS(reverse DNS)是已经知道IP的前提下,想要查询域名。反向DNS也是采用分层查询方式,对于一个IP地址(比如106.10.170.118),依次查询in-addr.arpa节点(如果是IPv6,则为ip6.arpa节点),106节点,10节点,170节点,并在该节点获得106.10.170.118对应的域名。

7、报文分析

其具体的流程可描述如下:

  1. 主机10.74.36.90先向本地域名服务器10.74.1.11进行递归查询
  2. 本地域名服务器采用迭代查询,向一个根域名服务器进行查询
  3. 根域名服务器告诉本地域名服务器,下一次应该查询的顶级域名服务器 dns.me的IP地址
  4. 本地域名服务器向顶级域名服务器 dns.me进行查询
  5. 顶级域名服务器me告诉本地域名服务器,下一步查询权限服务器dns.jocent.me 的IP地址
  6. 本地域名服务器向权限服务器 dns.jocent.me进行查询
  7. 权限服务器 dns.jocent.me告诉本地域名服务器所查询的主机的IP地址
  8. 本地域名服务器最后把查询结果告诉 10.74.36.90

8、快捷

  • Windows环境下清空DNS缓存的命令是 ipconfig/flushdns 也可以通过重启DNS client 和 DHCP client 两项服务清空DNS缓存
  • Windows环境下可以用命令 ipconfig /displaydns  来查看DNS缓存的内容
  • nslookup 命令可以用来查看域名对应的IP地址,比如 nslookup jocent.me
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
DNS(Domain Name System)协议是一种用于将域名解析为IP地址的协议,它是互联网中最重要的基础设施之一。在Java中,我们可以使用 InetAddress 类来实现 DNS 协议的模拟。 使用 InetAddress 解析域名 Java 提供了 InetAddress 类来实现 DNS 协议的解析。通过 InetAddress 类,我们可以将一个域名解析为 IP 地址。 例如: ```java String domainName = "www.baidu.com"; InetAddress[] addresses = InetAddress.getAllByName(domainName); for (InetAddress address : addresses) { System.out.println(address.getHostAddress()); } ``` 这个例子会输出百度的所有 IP 地址。 使用 DatagramSocket 发送 DNS 请求 DNS 请求是通过 UDP 协议发送的,我们可以使用 Java 的 DatagramSocket 类来发送 DNS 请求。 例如: ```java String domainName = "www.baidu.com"; byte[] requestData = new byte[1024]; InetAddress dns = InetAddress.getByName("8.8.8.8"); DatagramSocket socket = new DatagramSocket(); DatagramPacket requestPacket = new DatagramPacket(requestData, requestData.length, dns, 53); // 构造 DNS 请求报文 requestData[0] = 1; // 标识一个 DNS 请求 requestData[1] = 0; requestData[2] = 0x01; // 包含一个问题 requestData[3] = 0; requestData[4] = 0; requestData[5] = 0; requestData[6] = 0; requestData[7] = 0; requestData[8] = 0; requestData[9] = 0; requestData[10] = 0; requestData[11] = 0; requestData[12] = 3; // 域名 www requestData[13] = 'w'; requestData[14] = 'w'; requestData[15] = 'w'; requestData[16] = 5; // 域名 baidu requestData[17] = 'b'; requestData[18] = 'a'; requestData[19] = 'i'; requestData[20] = 'd'; requestData[21] = 'u'; requestData[22] = 3; // 域名 com requestData[23] = 'c'; requestData[24] = 'o'; requestData[25] = 'm'; requestData[26] = 0; // 结束符 // 发送 DNS 请求报文 socket.send(requestPacket); // 接收 DNS 响应报文 byte[] responseData = new byte[1024]; DatagramPacket responsePacket = new DatagramPacket(responseData, responseData.length); socket.receive(responsePacket); // 处理 DNS 响应报文 // ... ``` 这个例子会发送一个 DNS 请求到 Google 的 DNS 服务器(IP 地址为 8.8.8.8),请求解析百度的域名。我们构造了一个 DNS 请求报文,并使用 DatagramSocket 发送它。接着,我们等待 DNS 响应报文的到来,并处理它。 注意:这个例子中构造的 DNS 请求报文是比较简单的,真实的 DNS 请求报文可能会更加复杂。在实际使用中,我们应该使用专业的 DNS 库来发送和处理 DNS 请求和响应。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值