- Q3 `; e# S/ {& F(不久前,和@范卫锋 聊天,谈到我们作为技术的外行,怎么去了解一些基本的互联网知识,于是计划将一个外行人对技术的理解,写下来。某些概念和原理的解释可能不太准确,另外和投资没有直接关系,供其他转行、跨行同学参考。)# U& R0 C" v" |3 C
7 s2 k" R3 H, K g7 W2 Z; ]第一篇:带宽常识 我家是10兆的宽带,上网为什么巨慢?
5 o* r8 g' B/ c+ e
/ U# N' u0 Y4 b8 z/ s6 L0 k, p1 g S% W1 |8 l
如果问题是“我们小区里面是双向10车道,为什么上班路上还是堵车呢?”答案很明显,小区不堵车,但我们的上班地点,出了小区,还得老远的跑到中心区CBD去。你家里的10兆宽带(如果有的话),只是从你家到网络接入商的带宽,不等于到所有地方都是这个速度。
- Q ^9 H1 Z" n2 V* m
& b( D. B& ]7 N8 n0 P
+ [- @8 V" O+ f4 B2 U# V, b2 b
, Q& S8 J# M# m$ ^4 Z
, G, N+ }' {% |上网快慢,涉及到几个问题:你的电脑;你的网络接入商;你希望使用的互联网服务(简单理解为要访问的目标网站吧);目标网站的系统;目标网站所在网络环境。 % j) Q: `4 \, n- H1 r7 K; d
' E' W& h! v) o r( M5 J# g5 i2 D
1,跑车还是拖拉机?. s! \( C+ X; u9 [; w6 L
" n) d6 J% q- k8 x9 c3 U/ |: C* _' J" T, q
影响网速的因素,首先要看,你的电脑配置是不是太落后,是不是中了木马、流氓软件等。是不是同时使用了太多耗费带宽的服务,比如看视频,下载大文件等。7 Z" ~. x$ w7 Y ]
7 Z& o' t) ]6 P1 c; N7 ~
& F/ w- j+ D; O9 b) g5 M4 C$ `( Z/ ?$ b
2,网络接入商& h, P/ H/ b4 v
" b n& ]# I0 @. U' T( u
; @8 v% v" l Q) {: t6 }1 }简单来说,就是能牵线到你家里,然后让你的电脑上网的那个公司(现在也有无线的方式)。由于历史的原因,以前只有中国电信能为普通用户提供这种服务,所以现在最大的接入商,仍然是中国电信和中国网通。其他大大小小的各种接入商(比如长城宽带、E家宽、歌华有线等),可以看作是前两者的分包商。这些可以统称ISP (Internet Service Provider),互联网服务提供商。
3 {$ T" N- @+ k4 F
3 `' v9 D9 W m% @% t' V) y" _: ]
, O* \9 N2 R# o) W* Q. h; P! f3,目标网站
2 w0 r8 G. O* s6 R; z
4 |- ?# J) V& y4 j9 }8 Y- s9 v' K: P6 H) N2 b5 _+ `/ M
作为上班一族的你,中心区是你经常去的目的地;而上网的话,目标网站的服务器在哪里?同样由于历史原因,绝大多数都在中国电信或者中国网通的机房里,也有部分公司,通过从电信、网通租赁一些带宽,自建了机房,再向外提供服务。这些都叫IDC(Internet Data Center),即互联网数据中心。
* N0 {3 W1 s; b) B& S2 j! X) t$ z0 [: Q% j" d3 ]8 b( z+ @4 f
4 ]( a. L4 F( p9 T1 s4,目的地是小区还是中心区?( g/ h' b R* Q1 e
5 r5 i; v# b P8 i& H# n
2 \6 |: O; O/ U6 t6 T9 p3 C9 l假设你的接入商是长城宽带(简称长宽),10兆(M)入户。或者,从你家到长宽的骨干网,的确有10兆(也就是小区内的10车道)。问题是,你经常访问的是新浪、网易以及雪球等网站,而这些网站的服务器不在长宽。于是,如果长宽的用户越来越多,而长宽与电信、网通之间的接口带宽没有相应增加的话,网速就越来越慢。所以,即使是相同的带宽标准,不同的接入商,与你实际使用到的带宽差别非常大。这里不得不为电信、网通做一下广告,他们的ADSL以及专线等方式要比其他接入商靠谱。
7 c- k# x+ p$ v- k9 N( F7 D
6 `' m2 |& ^% N& Z: h
$ G: Q' t; }# F5 t* u5,上班高峰期/ s7 k& B6 T4 M( N) Z5 V7 L$ U
# B) u- ^+ p; f6 V7 A0 D3 b) o- n1 v- @/ W) X: R" U
虽然,网络接入商,不断的增加自己与电信、网通等骨干网之间的带宽(要钱的),也就是将小区出去的路修得宽一点。但是仍然难解决上班高峰期,大家一起上路的问题。所以,很多你会发现,早上起来觉得网速很快,但到晚上就不灵了。因为对小区宽带用户来说,晚上是使用高峰期。
3 e- X& ]2 m5 V0 {9 A3 l" G( y
/ e4 n, x, _0 N* {7 f- g; }, F: l" \. |+ K9 o; {6 S
6,小车还是火车?
8 U) l9 S7 j' N/ w# ~' {& H
Z& f/ N, C( G( g" o% F& C
2 e$ w/ L5 ?/ }) p如果你的小区有1000辆车需要开到中心区,为了不堵车,是不是得修一条1000车道宽的公路呢?当然不是,因为1000辆车不是并排一起走的,每辆车只占几米长的一小截路面,所以10车道的公路就足够了。
! |6 J* Y$ q5 ~
U$ _8 C6 D+ x2 J$ i" J+ W. S/ p! k$ H
但,如果这些车不是轿车,而是火车(每列车所占的路面很长),恐怕就得要几百条车道,才不会堵车了。+ ?9 h9 O8 H) l% b- E* Q
; K: d" W2 t3 ?3 F8 F
# t3 }. a( y0 N同理,假设小区里有1000户人家开设了10兆接入,接入商并非提供10兆X1000的总出口带宽。因为,多数人的上网行为,比如浏览网页,仅在打开页面极短的时间内产生高流量,而且也不是所有用户约好了一起刷页面,可以实现错峰。如果是QQ聊天之类的活动,所占的带宽也非常小。也就是说,你的10兆带宽,多数时间是闲置的。
! R2 E- A9 x0 P( }) G3 }: Q9 {) k1 r5 U
+ `2 y$ J/ n4 n2 H+ V* n因此,网络接入商不会按理论最大值来配备带宽。如果平时大家都是开小车(浏览网页、聊天)还好,如果开火车,就容易堵了。进行大文件的下载(包括在线看视频)就像开火车,特别是使用P2P的下载软件(比如迅雷、电驴),因为带宽长时间被占据,如果接入商的总带宽冗余不多,少量的火车就会将出口挤爆。: Z+ |& Z5 B/ m% b+ O: c+ a4 V: j
* a% z! S/ c I! c @& j
S' R" T& z; ~, h; e4 M' C/ |, R! \! d" [* a+ m
7,目标网站的系统$ N/ l( E& _! k: N* L
& b6 U: N' ~7 h- P% C5 c" ], Y
9 n' K8 N) ` [1 r1 \
你一路飞车到了中心区,但是里面塞满了车,你只能在路口排队等。用户所能感受的网速,与目标网站所提供的服务及其质量关系极大,主要是受网站的架构、数据库读写、缓存技术、以及前端页面的编码、以及访问压力等影响。一般来说,静态页面抗压能力要比动态页面强很多,换个意思是,同样的条件下,静态页面通常比动态页面快。静态页面(或者是应该静态化的页面)可以简单理解为,所有人看到的几乎都是一样的内容,比如新闻页面;动态页面每个人看到的都是各不相同,比如微博自己的首页,或者对更新频率要求在秒以内的页面。* {; q" N; @8 `" G$ f3 E
( r0 J2 \6 n" Y n7 n) x2 E- H8 b& |& q
, d' m! }% ^: a
8,目标网站的网络环境
# C0 a( ?3 r y1 w# g2 A9 K+ M; o, @' w" I- n# b
2 w" h8 z$ R' a) E3 @) D% ]3 U由于各种原因,中国主要的基础网络提供商电信和联通(前网通)之间,互联互通还存在很大障碍,另外还有教育网、金桥网、中国移动等各种网络环境。如果一台服务器,放在网通的机房,电信的用户跨网访问可能较慢,反之亦然。所以,不少网站将服务器放到双线、甚至BGP机房,以解决用户跨网访问的问题。% p; j3 G( b5 W: r, `0 j( @& x
: ?* k" D C @/ }* c- H0 x0 K6 Z另外,由于中国到境外的出口总带宽瓶颈以及其他原因,国内用户使用境外的互联网服务,速度明显受到影响,哪怕目标服务器是在香港。+ W) B$ D0 c0 z i9 D+ N
: x/ d1 d Y# b9,网络分发和加速服务- W% T3 M8 f0 ]+ o+ V1 q
4 D+ @- M/ S4 \% H' z' Q
( s( U8 H0 v- C# y1 l& m$ [1 o3 ^* n
这个不是针对单个上网用户的服务,是网络内容服务商(简称网站运营方吧),通过网络分发和加速服务,部分地解决用户的访问瓶颈问题。也就是CDN(Content Delivery Network)。
* F) L. U3 n8 q2 j) G- D/ @( @* K# v* u7 i3 R5 ?% ]5 }9 I! M
再看之前的例子,假设目标网站的服务器,是放在北京联通下某个机房,一个海南的电信接入的用户去请求,路途遥远。虽然在光速传输上,从北京到海南的物理距离所耗费的时间几乎可以忽略。但是事实上,由于各个接入商、各地网络环境、跨城市骨干网总带宽、以及互联互不通等问题,确实存在瓶颈。
" S+ G% K% ~6 r+ u l( P4 O1 h6 E
2 e6 v9 i0 X( N
* A# e9 p9 ?5 `; y! v于是有的公司(蓝汛、网宿科技、世纪互联等),在全国各地租用(或者自建)当地的机房和网络,架设了自己的全国分发系统。目标网站最终的服务器可能还是在北京,但是将内容通过他们的CDN网络向全国(全世界)分发,于是,海南的用户,直接请求当地最近的服务器的镜像数据,比以前要快很多。而别的同样在海南的其他用户,需要相同的内容时,也直接从本地最近机房读取。CDN的方式,既提供了访问速度,也节约了带宽成本。有的带宽虚耗大户,干脆组建自己的CDN网络。世界上最大的CDN服务提供商是Akamai(NASDAQ:AKAM)。
( @/ ~! T: p* e3 z! V/ ~# z P" B: z% X- ?& s: Z0 r
0 S" s3 Z* R7 h" s5 C v这方式可以理解为,全国人民本来要去北京朝圣,一睹老人家遗容。按传统的方式,即使将飞机、轮船、火车、手推车等所有交通工具用上,再将北京整个城市腾空来接待,10几亿人民不知道排队到何年何月。现在有个CDN公司,将尸体一摸一样地复制了几万份,分发到全国各地,甚至某些乡镇都有。于是,人民无需背井离乡、长途跋涉远赴京城,奔丧之需又丝毫不受影响。* k, Y* U) G: |2 F
4 }( B* L2 y3 u6 G$ n: R1 C) M# s5 ?/ A% A, W
10,动态CDN
6 l3 i/ n( b# u' x7 \# U
( J: u5 o; ?$ h5 e6 Q
' [) T: ?3 c* l) j& Y8 B' J前面说的CDN目前主要使用在更新频率很低(甚至几乎不作更新)的静态(静态化)内容上。比如,上面的遗体,复制几万次而不影响大家哀悼,是因为复制品和原品一摸一样(至少人民感知不到区别)。如果是个活人,身体、穿着、神态等天天在变,要保证复制品质量的话,就得不停的更新,那样会导致很多运输在途的复制品变成废品。现在的动态CDN技术,能将复制频率以及向全国分发的时间,缩短到用户无法感知的程度,已经有部分公司尝试使用(价格昂贵)。6 `7 o( f7 O' p* L
2 c) M; |/ I% Y( j5 ?" Y- K0 v9 N! s& ?. ]0 J( E
11,带宽的单位+ `0 O& Z2 |/ q1 w( Z. N I7 f
; l8 x- S8 f0 l: _
5 n: y. J, } n3 ~0 K假设上面说的问题都解决了,家里10兆(10M)的带宽,下载东西时,你会发现,怎么最多也只是1.25M/秒?那是因为,服务商说的带宽(字节)单位,是bit,而我们电脑上,使用的单位是byte。1byte=8bit,需要将他们的说的数字,除以8。电脑里显示某个文件的大小时候,使用的也是byte。(雪球 梁剑)
* \. W* x" g) l4 g) U3 ]0 d5 O
6 P4 Z; @9 _& I
8 @3 c( P1 b7 Y: {2011-12-29 18:02 来自雪球 $ d m6 ]# z @
|