你了解DNS吗?

你了解DNS吗?

      • [一. 介绍](#一. 介绍)
      • [二. DNS的工作原理](#二. DNS的工作原理)
      • [三. DNS查询流程示意图](#三. DNS查询流程示意图)
      • [四. DNS 记录类型](#四. DNS 记录类型)
      • [五. DNS的安全问题与 DNSSEC](#五. DNS的安全问题与 DNSSEC)

前言

这是我在这个网站整理的笔记,有错误的地方请指出,关注我,接下来还会持续更新。

作者:神的孩子都在歌唱

一. 介绍

DNS (Domain Name System,域名系统)是互联网的"电话簿",负责将人类可读的域名(如 www.example.com)转化为机器能理解的 IP 地址(如 192.0.2.1)。由于网络通信依赖于 IP 地址,而我们更习惯于使用域名,DNS 就是为了这个目的而设计的,提供了高效的域名解析服务。

二. DNS的工作原理

当你在浏览器中输入一个网址时,背后发生的过程其实是通过 DNS 进行域名解析。DNS 查询过程大致可以分为以下几个步骤:

  1. 用户发起请求

    用户在浏览器中输入域名(如 www.example.com)。此时,计算机会检查本地缓存,看看是否已经存储了该域名对应的 IP 地址。如果缓存有结果,直接返回;否则,会开始查询过程。

  2. 本地 DNS 服务器的角色

    如果本地缓存中没有对应的 IP 地址,操作系统会将请求发送给配置的 本地 DNS 服务器(通常由互联网服务提供商(ISP)提供)。此时,本地 DNS 服务器会尝试找到该域名对应的 IP 地址。如果本地 DNS 服务器本身没有记录,它会继续向其他 DNS 服务器查询。

  3. 递归查询

    如果本地 DNS 服务器没有缓存该域名的解析结果,它将向上级的 DNS 服务器发起 递归查询 。首先,查询会被发送到 根域名服务器

  4. 根域名服务器

    根域名服务器负责管理整个 DNS 系统的最顶层。它并不直接保存域名和 IP 地址的映射,而是指引 DNS 查询到 顶级域名服务器(TLD 服务器) 。例如,查询 www.example.com 时,根域名服务器会指向 .com 顶级域名的服务器。

  5. TLD 服务器

    顶级域名服务器负责管理特定顶级域(如 .com, .org 等)。TLD 服务器会将查询进一步转发到负责该域名的 权威 DNS 服务器

  6. 权威 DNS 服务器

    权威 DNS 服务器是最终的"答案源",它保存了特定域名的确切解析记录,包括域名与 IP 地址的映射。它会将查询结果返回给发起请求的 DNS 服务器。

  7. 返回结果

    最后,DNS 服务器将解析到的 IP 地址返回给用户的浏览器,浏览器便可以使用该 IP 地址与目标网站的服务器建立连接,加载网页内容。

三. DNS查询流程示意图

下面是简化后的 DNS 查询流程 图示,帮助更好地理解 DNS 是如何工作的:

四. DNS 记录类型

DNS 服务器保存了多种类型的记录,最常见的包括:

  • A 记录:将域名映射到一个 IPv4 地址。
  • AAAA 记录:将域名映射到一个 IPv6 地址。
  • CNAME 记录:为一个域名指定别名。
  • MX 记录:指定邮件服务器地址。
  • TXT 记录:存储任意文本数据,用于验证等目的。
  • NS记录:域名服务器记录,指明该域名由那台服务器来解析
  • PTR指针:用于将一个IP地址映为一个主机名

五. DNS的安全问题与 DNSSEC

虽然 DNS 是一个强大且高效的系统,但它也面临一定的安全风险,如 DNS 欺骗 (DNS Spoofing)和 DNS 解析劫持 。为了加强 DNS 安全,DNSSEC(DNS Security Extensions)应运而生,它通过为 DNS 响应提供数字签名,确保数据的完整性和真实性,防止恶意篡改。

作者:神的孩子都在歌唱

本人博客:https://blog.csdn.net/weixin_46654114

转载说明:务必注明来源,附带本人博客连接

相关推荐
廋到被风吹走6 小时前
【AI】从 OpenAI Codex 到 GitHub Copilot:AI 编程助手的技术演进脉络
人工智能·github·copilot
本地化文档9 小时前
rustdoc-book-l10n
rust·github·gitcode
第一程序员9 小时前
Python 4.0正式发布:新特性与学习建议
python·github
irpywp10 小时前
HolyClaude:一行命令,随时随地运行 Claude Code
开源·github·claude code
darkb1rd12 小时前
OpenSpace:让智能体低成本自进化与经验共享框架
开源·github·好物分享
coderYYY16 小时前
git push报错Authentication failed for ‘xxx’也不会弹要求输入用户名密码的最终解决方法
前端·git·gitee·github
用户928172673901619 小时前
Android Apk 找代码 只需秒级别
github
第一程序员19 小时前
Python高级特性详解:从基础到进阶
python·github
蒸汽求职19 小时前
【蒸汽教育求职分享】美国IT面试的Behavioral Question:STAR法则人人都知道,但90%的人用错了
人工智能·面试·职场和发展·github·求职招聘·留学生求职
人工智能研究所19 小时前
字节开源 DeerFlow 2.0——登顶 GitHub Trending 1,让 AI 可做任何事情
人工智能·深度学习·开源·github·ai agent·字节跳动·deerflow2.0