网络应用简记(2):CDN与P2P的概念

(1)cdn是什么

cdn是一个基于已有的internet网络而进行扩展的网络系统,叫作内容分发网络,content delivery network。

搭建cdn网络的思路,是在网络边缘,也就是接入网络的设备(用户)的地方,增加服务结点,再通过各种策略,把用户划分到不同的cdn结点,并让用户能在最短的时间获取到数据。

cdn的基本意图,是让用户更快更稳地取得数据。cdn最基本的作用是加速,但随着时代的发展,cdn提供的服务已经远不仅加速的功能,还有预缓存、支持https等诸多功能。

为了提升服务体验,还基于其它考虑,很多公司都接入了cdn,或自建cdn。

cdn服务商有很少,比如阿里云cdn、百度、腾讯、七牛、网宿等。

这时,不可避免要考虑一个问题,cdn的使用,是占用带宽的(当然,不使用cdn而使用缓存服务器,也一样占用带宽),而这个带宽的使用,相当使用了运营商修建的道路,是要给钱的。一般来说,按带宽的使用来计费(具体可能按月的带宽峰值,也可能按实际使用来分摊到月,等等。),而在某些场景,比如直播、视频播放等,在客户端从cdn或缓存服务器获取数据时,服务器占用了很大的带宽。

加一个题外话,怎么从流量换算出带宽?一般来说,很容易统计到文件下载(或被试听)的次数,根据文件的大小与一天的下载的次数,就可以算出一天产生的流量,比如小程的服务器的一个语音文件是250kB,如果一天有100次播放,那一天的流量就是(250100)=25000kB。再把流量分摊到每一秒,就是带宽(bps):2500010248/(2460*60) = 204800000/86400=2370bps,也就是一天占用的带宽是2.3k左右。这是一天的带宽,一般来说,一个月内会产生峰值(比如活动日或周末等),这时的带宽可能是正常的几倍,比如3倍,那就是6.9k。然后,根据这个6.9k来计算要给多少钱(先问一下运营商或cdn服务商,1m带宽要多少钱)。

那么,有没有办法,减少服务器带宽的占用,从而节省费用的开销呢?

(2)p2p是什么

p2p,peer to peer,是点到点的数据交换的网络技术。

对比cdn跟p2p的网络结构,很容易看出它们的差别。对于cdn,客户端之间的数据交换,需要经过cdn服务器来转发,因此,服务器带宽成本是一个问题(如上所述)。对于p2p,客户端之间可以直接交换数据而不经cdn服务器,所以理论上可以大幅节省带宽成本。

所以,如果为了节省cdn的带宽成本,p2p是一个可以考虑的技术。

一个简单的p2p应用的结构图是这样的:

更多p2p或网络知识后续再作分享。

原文发布于微信公众号 - 广州小程(gh_3e79faa8a715)

原文发表时间:2018-11-01

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

扫码关注云+社区

领取腾讯云代金券