计算机网络—— DNS和CDN那些事_nds cdn-程序员宅基地

技术标签: 网络  运维相关  运维  服务器  


前言

DNS:
keyword:域名解析为IP地址。

域名解析协议(DNS)用来把便于人们记忆的主机域名和电子邮件地址映射为计算机易于识别的IP地址。
DNS是一种c/s的结构,客户机就是用户用于查找一个名字对应的地址,而服务器通常用于为别人提供查询服务。 ———百度百科

CDN:
keyword:就近, 降低拥塞。

CDN的全称是Content Delivery Network,即内容分发网络。CDN是构建在现有网络基础之上的智能虚拟网络,依靠部署在各地的边缘服务器,通过中心平台的负载均衡、内容分发、调度等功能模块,使用户就近获取所需内容,降低网络拥塞,提高用户访问响应速度和命中率。CDN的关键技术主要有内容存储和分发技术。———百度百科

一、DNS工作原理?

1.DNS层次结构

DNS域名服务器的层次结构分为:根域名服务器、顶级域名服务器、权限域名服务器、本地域名服务器。

2.一个例子

当用户在浏览器输入一个网址域名,例如www.baidu.com,此时系统到host文件中查找该域名对应的IP地址,并访问该地址。但host文件无法记录所有的域名及其对应的IP地址,这时候,DNS服务器应运而生。

3.DNS的内脏

将域名转换为对应IP地址的过程称为域名解析,而完成该工作的软件叫域名解析器软件。
每一个解析器被配置在一个本地域名服务器上。

  1. 根域名服务器 知道所有的顶级域名服务器IP地址,并为所有顶级域名服务器提供IP地址。
  2. 顶级域名服务器:顶级域和国家域都有顶级服务器。顶级服务器知道所有权限域名服务器IP地址,并为所有权限域名服务器提供IP地址。
  3. 权限域名服务器:所有拥有公开可访问主机的组织机构都必须提供公开可访问DNS记录,而权限域名服务器保存所有DNS记录。
  4. 本地域名服务器 并不属于DNS层次结构。只起到代理作用。负责将DNS请求转发至相应DNS层次结构中。

4.接下来,简单描述一下DNS服务过程:

解析器 ------(将指定域名放入DNS请求报文中)-----> 本地域名服务器 -----(在本地数据库查找)------->有:则直接交付,回复请求。无:本地服务器将请求转发至根域名服务器。----------->顶级域名服务器--------->权限域名服务器。

5.总结:

  • 反复查询解析:在服务器层次间逐步寻找管辖一个域名的服务器的过程,称为反复查询解析。
  • 主机上的解析器软件往往请求递归解析,将一个域名解析为一个对应IP地址。当一个服务器成为另一个服务器的客户时(本地数据库没有找到DNS请求报告中是域名),它可以请求反复解析,在服务器层次间每次一层地逐步查询。

6.顺带附上路由转发的过程:

()(转载自王道计算机考研)

二、从DNS引入CDN

1. 为什么有CDN?

最常规的上线网站方式就是浏览器通过网络访问域名服务器,但有两个致命问题:

  1. 距离问题
    用户离服务器越远,访问速度越慢
  2. 服务器稳定性
    中小型网站因缺少维护,容易宕机后很长时间才被发现。

2.CDN应运而生!

解析过程:
DNS解析设置的后台添加CDN的解析记录---------->CDN网络专用的解析DNS请求的服务器---------->给浏览器返回CDN负载均衡服务器---------->CDN网络中找一台个条件下都适合用户设备提供服务的CDN服务器(例如距离最近的CDN服务器)------>若没有,就继续在CDN网络往上层查找------>拉去资源回来后,在每一层没有记录的CDN服务器都做一次缓存。

3.CDN优点

优点:每次浏览器访问一个网站时,都可以在离自己最近的,有缓存的CDN服务器上获取相应数据,而不必在源站上拉取。这使得用户快速打开一个网站,此外还可以防止宕机。因CDN网络中的一个CDN服务器宕机,还有其他服务器可以正常工作。

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/JingYan_Chan/article/details/122462617

智能推荐

javase之序列化与反序列化_ser 序列化 反射-程序员宅基地

文章浏览阅读406次。3.如果一个可序列化对象包含了某个不可序列化对象的引用,那么整个序列化是会失败的,并且会抛出一个NotSerializableException,我们可以将这个引用标记为transient,表示为短暂的,此时该变量就无法被序列化,然后对象依旧可以被序列化。一个类如果想被序列化,则必须实现java.io.Serializable接口,这个接口没有定义任何方法,是一个标志性接口,当一个类实现了该接口,就表示这个类的对象是可以被序列化的。2.如果一个对象的成员变量是一个对象,那么这个对象的数据成员也会被保存。.._ser 序列化 反射

Zuul_zuul: prefix: /api-程序员宅基地

文章浏览阅读139次。zuul 路由1. zuul:1.1 zuul是什么?Zuul包含了对请求的路由和过滤两个最主要的功能:其中路由功能负责将外部请求转发到具体的微服务实例上,是实现外部访问统一入口的基础而过滤器功能则负责对请求的处理过程进行干预,是实现请求校验、服务聚合等功能的基础.Zuul和Eureka进行整合,将Zuul自身注册为Eureka服务治理下的应用,同时从Eureka中获得其他微服务的消息,也即以后的访问微服务都是通过Zuul跳转后获得。注意:Zuul服务最终还是会注册进Eureka1.2 路由:_zuul: prefix: /api

推荐五款你从未见过的嵌入式电子电路仿真APP-程序员宅基地

文章浏览阅读2.1w次,点赞30次,收藏204次。摘要:在这个人人一部甚至多部智能手机的年代,各种APP充斥在各种应用市场作为一名电子爱好者或者电子工程师,你在为如何选择APP而头痛吗?哪些你正在使用的APP使你在工作、生活、学习中如虎添翼呢?现在,小师弟特意整理了一些电子爱好者和电子工程师能用到的手机APP和你没见过的电脑仿真软件。ElectroDroid电路专家ElectroDroid是一款电路电子器件的学习软件,比较专业化,它能够为你提供各种电路方面的信息查询和计算服务,是电子相关行业人士的必备工具之一。它包括:电阻色码计算器贴片电阻代码_电路仿真app

卷积神经网络的几种模型_卷积神经网络模型-程序员宅基地

文章浏览阅读7.9k次,点赞9次,收藏53次。关于卷积神经网络的模型,我们这里只谈论关于图像分类的卷积神经网络的四种模型。在这里我们就不对卷积神经网络的结构进行阐述,不了解的同学可以参考我之前的博客LeNet-5首先我们先阐述的是1989年提出来的的LeNet-5结构。它其实就是最原始的结构,卷积层后衔接池化层,再接卷积层和其后的池化层,最后一个全连接层。(c1=convolution layer1,s1=subsampling layer1[降采样层,就是池化层])这个模型是实现识别手写数字的功能为目的而提出..._卷积神经网络模型

【Maven教程】(十):使用 Hudson 进行持续集成—— 从Hudson的安装到任务创建 ~_hudson搭建-程序员宅基地

文章浏览阅读1.4k次。优秀的持续集成工具有很多,如老牌的开源工具CruiseControl 、商业的 Bamboo 和 TeamCity 等。这里只介绍 Hudson, 因为它是目前较流行的开源持续集成工具。该项目过去一直托管在 java.net 社区,不过现在已经迁移到。Hudson 主要是由Kohsuke Kawaguchi 开发和维护的,Kohsuke Kawaguchi 自2001年就已经加入 Sun 公司(当然,现在已经是 Oracle 了)。_hudson搭建

计算机网络物理层第一章物理层详解_物理层的过程特性举例-程序员宅基地

文章浏览阅读5.9k次,点赞25次,收藏153次。计算机网络在我们实际项目中可能应用不多,但是学懂它决定了一个人能成长的上限,进来,一起学_物理层的过程特性举例

随便推点

滚动栏范围位置函数(SetScrollRange、SetScrollPos、GetScrollRange、GetScrollPos)-程序员宅基地

文章浏览阅读194次。滚动栏的范围是一对整数,默认情况下,滚动栏的范围是0~100。SetScrollRange(hwnd,iBar,iMin,iMax,bRedraw)这里的iBar參数要么是SB_VERT,要么是SB_HORZ,iMin和iMax分别相应滚动栏范围的最小值和最大值,须要Windows依据新的范围来重绘滚动栏时将bRedraw设为TRUE.SetScrollPos(hwnd..._setscrollerbarpos

【Java基础】之AWT,一篇文章搞懂awt(包含绘图)-程序员宅基地

文章浏览阅读1.3w次,点赞45次,收藏177次。入门awt不错的文章,带你快速上手awt_awt

C++ Primer问题总结(7)_executionpolicy&&-程序员宅基地

文章浏览阅读170次。10.3int main(){ vector<string>v{ "Hello","World" }; auto sum = accumulate(v.begin(), v.end(), string{ "Tim Wu" }); cout << sum << endl;}int main(){ int v1 = 42; auto f ..._executionpolicy&&

《近匠》专访机智云 CTO 刘琰——从 0 到 1 开启智能化硬件开发-程序员宅基地

文章浏览阅读1.1k次。在物联网浪潮之下,智能硬件的火爆程度不断升温。未来十年,全球接入互联网的硬件设备将达到1万亿台。如今的智能硬件产品正成为下一个“台风口”,同时这对于终端市场也是一个机遇。然而从创新走向产品,作为开发者应该如何步步为营?面对传统硬件与智能硬件之间思维理念及技术差异的“鸿沟”,开发者如何提升自己的技能,更加高效地开发?由此,我们带着探索道路上的种种疑问,采访了机智云 CTO ..._机智云科技有限公司刘焱

动态规划 | 完全背包问题 | 组合数、排列数 | leecode刷题笔记_完全背包问题 输出有几种排列-程序员宅基地

文章浏览阅读857次。跟随carl代码随想录刷题语言:python。_完全背包问题 输出有几种排列

Java中的类加载和双亲委派原则_java所有的类的加载都必须遵循双亲委派原则-程序员宅基地

文章浏览阅读361次。Java类加载过程1,加载–》2,验证–》3,准备–,4,解析–》5,初始化加载加载是指将类的class文件读到内存中,并为其创建一个java.lang.Class对象(每个类都有其独一无二的.Class对象),类加载由JVM中的类加载器完成,且其加载一般符合"双亲委派原则",(下文会简单的介绍类加载器和双亲委派原则,不要担心),除此之外,还可以自定义类加载器对类进行初始化;通过不同的类加载器,可以从不同的源加载类的二进制数据文件:1.从本地文件系统加载class文件。2.从JAR包加载cla._java所有的类的加载都必须遵循双亲委派原则