今天很多人都在讲域名系统和互联网作为一个整体是如何工作的,域名系统---也就是大家所熟知的DNS。不幸的是,对于天龙人和普通人来说,他们并不了解DNS到底是什么鬼。今天就来聊聊DNS,和那些想了解DNS工作原理的人聊一聊它是如何工作的。
什么是DNS?
DNS(Domain Name System,域名系统),因特网上作为域名和IP地址相互映射的一个分布式数据库,能够使用户更方便的访问互联网,而不用去记住能够被机器直接读取的IP数串。通过域名,最终得到该域名对应的IP地址的过程叫做域名解析(或主机名解析)。DNS协议运行在UDP协议之上,使用端口号53。
看到了上面百度百科的解释,好像大概知道了DNS有什么用,至少我们可以对如下问题做出回答了。
为什么需要DNS?
因为人的脑力有限,我们无法记住每个我们使用的网站的每个IP地址,记住一些有含义的字符串(如:百度网址)貌似容易的多,DNS把域名和IP做了一个映射,我们在浏览器输入域名,DNS就可以帮我们把对应的域名解析成真实的IP地址,从而请求IP地址对应的网站。这就是DNS的作用。
但是工作原理是什么?是不是还不清楚,那么就看看下面通俗的解释吧。
DNS无无疑是互联网中最重要也最容易被忽略的部分。如果没有DNS,我们今天互联网的使用体验肯定会很糟糕,因为我们得记住我们使用网站的IP地址(淘宝、微信、支付宝、钉钉等),这么多的IP地址,想想自己是不是很头大,毕竟你现在连你不常用的账号密码都已经忘了qwq!。
我们都知道或者都应该知道电脑组成了互联网,组成了大型网络,并且通过地下电缆或水下电缆相互通信。并且通过一串数字相互识别,这串数字也就是IP地址。由于大部分人脑力有限,无法对成百上千个数字系列进行分类并且一一记住,DNS的实际作用就是将域名翻译成对应的IP地址。
但是DNS究竟是如何工作的呢???
当你在浏览器的地址栏输入,你实际上访问的是,没错,在域名后面还有一个点(.),你从来不会看到,也从来不会输入。当你输入你实际上访问的是 。 的页面,真的是这样的,不信你可以试一下。总之,最后的那个点代表着互联网命名空间的根。为什么这个点这么重要?因为它是一切开始的地方。当你第一次搜索时,你的浏览器和操作系统会首先判断它们知不知道这个域名对应的IP地址是啥,它可能会在你的计算机里配置也可能在内存里,很多人称之为cache。总之,你的浏览器会问操作系统,如果它们都不知道是什么,然后会怎么样呢? 操作系统会配置为当它不知道某个IP地址时去询问解析域名服务器,解析域名服务器就是承担DNS查询重任的,它会在你的操作系统里进行手动或自动配置。你的操作系统会向解析域名服务器询问的IP地址。解析域名服务器的内存或者缓存里可能有这个IP地址,也可能没有。为了这次说明,假如它没有这个IP地址,所有解析域名服务器必须知道的一件事就是知道去哪里查找根域名服务器。是的,这个神秘的点会出现在你输入的地址栏的每一个域名的最后,根域名服务器回复到:“我也不知道,但我知道去哪里找com的域名服务器,去哪里问一下吧”。com域名服务器叫做顶级域名服务器,也就是TLD域名服务器。解析域名服务器会记住根域名服务器提供的所有信息,并且添加到缓存里,然后直接去找TLD域名服务器。当解析域名服务器询问时,TLD域名服务器回答说:“我不知道,但我知道去哪里找example.com域名服务器,你去那里问一下“。下一组域名服务器叫做主域名服务器,那么TLD域名服务器怎么知道用哪个主域名服务器呢,这得借助于域名注册公司了。当一个域名被购买时,域名注册公司就会被告知那个域名应该使用哪一个主域名服务器,注册公司就会将这次注册信息告知负责根域名的机构,并且告诉它更新TLD域名服务器。总之,解析域名服务器记下TLD域名服务器的回复,存储到缓存里,然后去询问example.com域名服务器,这个时候,主域名服务器就会说:“哈,我知道他在哪里”。告诉你的浏览器去访问192.168.1.1这个IP地址。解析域名服务器记下了主域名服务器提供的信息添加到缓存里,然后回复给操作系统,操作系统就会告诉浏览器,浏览器就会连接到请求页面,的IP地址。很有意思,对不对?这个过程看起来好像很复杂,但是相信我,整个过程在你眨眼之间就能完成,建立DNS就是为了快速高效的工作,它是互联网必须的组成部分。一旦你理解了这一点,你会清楚的看到一次DNS查询就会由多个层面和多个机构负责。仅仅是一次DNS查询啊!由解析域名服务器、根域名服务器、TLD域名服务器、还有主域名服务器。如果任何人改变或者去除了这个过程中的任意一个部分,这会导致一场灾难。