cdn负载均衡怎样实现?
曾见到知乎上有人问“为何像facebook这类的网站需要上千个工程师保护?”,下面的回答多种多样,但总结起来就是:一个高性能的web系统需要从无数个角度去斟酌他,大到服务器的布局,小到软件中某个文件的实现,乃至于某个循环内的运算如果出现不严谨都可能致使全盘崩溃。
上面提到web性能优化需要多个角度去斟酌,我们没法斟酌到所有的优化细节,但可以从我们已知的层面去优化,我们就先从网络层面说起。
①网络要求路径:
(客户端输入URL定位符)→(DNS服务器寻觅映照)→(进入服务器,处理数据)→(返回数据至客户端)
在这个用例中我们可以很清晰的看出网络要求到返回的进程,虽然非常抽象,但足够我们以他为基础来进行优化了。
1.负载均衡
BOSS一次给了小明好多项任务,小明发现怎样安排时间也做不完,因而乎他盯上了在旁边偷偷看电影的小强,小强突然觉得背后有一股冷气,一回头小明一脸坏笑看着他,“这几个任务交给你,晚上请你吃饭,要不然...嘿嘿嘿”,小强虽然不甘心,但是在小明的要求(威胁)下,只能服从。第二天,小明顺利的完成了任务,给小强买了袋辣条。
在计算机上负载均衡也类似如此,我们的大BOSS客户端将要求发送至服务器,但是一台服务器是没法承受很高的并发量的,我们就会将要求转发到其他服务器,固然真实的负载均衡架构其实不是由一台server转发的另外一台server,而在客户端与服务器端中间加入了一个负责分配要求的负载均衡硬件(软件)。
〓DNS
名词:DNS是客户端发送要求中一个非常重要的中转,他的作用是将用户要求的URL映照为具体的IP地址,全球有13台根服务器,但通常为我们进行域名解析的其实不是根服务器,而是直接访问我们的 LDNS(Local DNS Server),通常由网络运营商保护。
最早的负载均衡就是利用搭建本地DNS服务器实现的,实现方式简单易懂,为同一个主机名分配多个映照 ,可采取轮循,随机等方式分配要求。看上去没甚么问题,但是在使用进程中会发现,如果其中一个地址down机,我们是没法及时发现的,如果有用户被分配到这个主机就会出现访问失败的状态,同时我们也没法判断每一个server的负载,可能会出现,某个server几近闲置,另外一个server负载压力极高的情况。
〓硬件装备
名词:负载均衡器(Load Balancer),负载均衡器通常作为独立的硬件置于客户端与服务器之间。
负载均衡装备具有非常好的负载均衡性能,他具有众多的负载均衡策略(权重,动态比率,最快模式,最小连接数等),可以保证以相对较优的方式分配要求,不过好的东西总是有代价的,那就是价格,一台负载均衡器的售价常常高达十几万乃至几十万,许多企业其实不愿意为它买单。
〓反向代理
名词:Nginx。高性能,轻量级,已成了人们对Nginx的第一印象,Nginx可作为HTTP服务器,在处理高并发要求的时候具有比现在主流的Apache服务器更高的性能,同时Nginx也是一个优秀的反向代理服务器。
第一次听到“反向代理”,可能有些陌生,但如果了解与之对应的正向代理就很好理解了,正向代理通常由客户端主动链接,比如我们的科学上网方式就是使用正向代理,以到达间接访问网站的目的,而反向代理在服务器端,无需主动链接,当我们访问具有反向代理的网站时,实际访问的是其反向代理服务器,而非真实的服务器,当要求到达反向代理服务器时,反向代理服务器再将要求转发至服务器。反向代理是实现负载均衡的主流手段之一,通常使用Nginx等服务器搭建,Nginx一样具有众多的分配策略,以保证平均分配压力。
Nginx反向代理:
BIGIP(硬件)负载均衡:
2.CDN
视频总在缓冲,图片各种加载不出来,几年前是再正常不过的事了,在当时大家也没觉得是回事,但把这类情况放在现在,我想人们绝对直接就小红叉了吧,那末我们如何避免这样的情况呢?这就是我要说的,内容分发网络(Content Delivery Network),简称:CDN。
CDN简单的来讲就是存储一些静态文件的一台或多台服务器,通过复制,缓存等方式,将文件保存其中。
〓哪些是静态文件?
css,html,图片,媒体都属于静态文件,也就是说用户发送的要求不会影响静态文件的内容,而jsp,php等文件就不属于静态文件,由于他们的内容会因我们的要求而产生改变。
〓CDN怎么实现加速?
通常情况下,我们所要的数据都是从主服务器中获得,但假设我们的主服务器在南方,而访问用户在北方,那末访问速度就会相对变慢,变慢的缘由有很多,例如传输距离,运营商,带宽等等因素,而使用CDN技术的话,我们会将CDN节点散布在各地,当用户发送要求到达服务器时,服务器会根据用户的区域信息,为用户分配最近的CDN服务器。
〓CDN数据从哪里来?
复制,缓存,CDN服务器可以在用户要求后缓存文件,也能够主动抓取主服务器内容。
TikTok千粉号购买平台:https://tiktokusername.com/
TOP