不要成为理想的巨人,行动的矮子
写在前面
为了更好地学习和掌握《计算机网络》这门课程,打算把自己的学习笔记转化为博客,以便于更好地复习,也便于大家一起学习与交流。
参考课程:中科大-郑老师《计算机网络》
参考书籍:《计算机网络自顶向下方法》原书第七版
什么是Internet?
因特网是一个世界范围的计算机网络,即它是一个互联了遍及全世界数计算设备的网络。
具体构成及描述
[HTML_REMOVED] 计算设备 [HTML_REMOVED]: 主机(端系统)、运行的网络应用程序
节点:
- 主机及其上运行的应用程序
- 路由器、交换机等网络交换设备
例如:手机、平板、电视、游戏机… 这一些设备都称为主机 ,也可以叫做端系统。
边 : 通信链路
- 接入网链路:主机连接到互联网的链路
- 主干链路:路由器间的链路
端系统通过通信链路(communication link)和分组交换机(packet switch)连接到一起。 链路的传输速率以比特/秒(bit/s, bps)度量。
[HTML_REMOVED] 通信链路 [HTML_REMOVED] :
- 光纤、同轴电缆、无线电、卫星
- 传输速率 = [HTML_REMOVED] 带宽(bps) [HTML_REMOVED]
[HTML_REMOVED] 分组交换机 [HTML_REMOVED]: 转发分组(packets)
- 路由器和交换机
端系统通过因特网服务提供商(Internet Service Provider, ISP)接入因特网,例如:本地住宅区ISP,公司ISP,大学ISP…
协议 :控制发送、接收消息, 例如 TCP、IP、HTTP、FTP、PPP都是协议
- 定义:协议(protocol)定义了在两个或多个通信实体之间交换的报文的格式和顺序,以及报文发送和/或接收一条报文或其他时间所采取的动作。
- 网络协议
- 类似人的协议 : “几点了?”,“我有个问题?”, “你好”(若对面回应,则说明发送成功)
- 机器之间的协议而非人与人之间的协议
- Internet中所有的通信行为都受协议制约
什么是Internet: 从服务角度
使用通信设施进行通信的分布式应用:WEB、Voip、email、分布式游戏、电子商务、社交网络…
通信基础设施为apps提供编程接口(通信服务)
- 将发送和接收数据的apps与互联网连接起来
- 为app应用提供服务选择,类似于邮政服务
- 无连接不可靠服务
- 面向连接的可靠服务
网络边缘
端系统(主机):
- 运行应用程序
- 如Web、email
- 在“网络的边缘”
客户/服务器模式
- 客户端向服务器请求、接收服务
- 如Web浏览器/服务器:email客户端/服务器
对等(peer-peer)模式 - 很少(甚至没有)专门的服务器
- 如Gnutella、KnZaA、Emule
网络边缘:采用网络设施的面向连接服务
目标:在端系统之间传输数据
- 握手:在数据传输之前做好准备
- 类似人类协议中:你好、你好
- 两个通信主机之间为[HTML_REMOVED]连接建立状态[HTML_REMOVED]
TCP-传输控制协议(Transmission Control Protocol):TCP向它的应用程序提供了面向连接的服务。这种服务包括了应用层报文向目的地的确保传递和流量控制(即发送方/接收方速率匹配)。TCP也将长报文划分为短报文,并提供无连接服务,因此当网络拥塞时,源抑制其传输速率。
- Internet上面向连接的服务
- 可靠地、按顺序地传送数据
- 确认和重传
- 流量控制
- 发送方不会淹没接收方
- 拥塞控制
- 当网络拥塞时,发送方降低发送速率
网络边缘:采用基础设施的无连接服务
目标:在端系统之间传输数据
- 无连接服务
UDP-用户数据报协议(User Datagram Protocol): UDP协议向它的应用程序提供无连接服务。这是一种不提供不必要服务的服务,没有可靠性,没有流量控制,也没有拥塞控制。
- 无连接
- 不可靠数据传输
- 无流量控制
- 无拥塞控制
[HTML_REMOVED]使用TCP的应用[HTML_REMOVED]:HTTP(Web)、FTP(文件传送)、Telnet(远程登录)、SMTP(email)
[HTML_REMOVED]使用UDP的应用[HTML_REMOVED]:流媒体、远程会议、DNS、Internet电话
网络核心
网络核心:路由器的网状结构
基本问题:数据怎么通过网络进行传输?
- [HTML_REMOVED]电路交换[HTML_REMOVED]:为每个呼叫预留一条专有电路:如电话网
- [HTML_REMOVED]分组交换[HTML_REMOVED]:
- 将要传送的数据分为一个个单位:分组
- 将分组从一个路由器传到响铃路由器(hop), 一段段最终从源端传到目标端
- 每段:采用链路的最大传输能力(带宽)
网络核心:电路交换
在电路交换网络中,在端系统间通信会话期间,预留了端系统间沿路径通信所需要的资源(缓存,链路传输速率)。在分组交换网络中,这些资源则不是预留的。
[HTML_REMOVED]端到端的资源被分配给源端到目标端的呼叫(call)[HTML_REMOVED]
如上图中, 每段链路有4条线路:
- 该呼叫采用了上面链路的第2个线路,右边链路的第1个线路(piece)
- 独享资源:不同享
- 每个呼叫一旦建立起来就能够保证性能
- 如果呼叫没有数据发送,被分配的资源就会被浪费(no sharing)
- 通常被传统电话网络采用
如上图,每台主机(例如PC和工作站)都与一台交换机直接相连,当两台主机要通信时,该网络在两台主机之间创建一条专用的端到端连接(end-to-end connection)。因此,主机A为了向主机B发送报文,网络必须在两条链路的每条上先预留一条电路。
[HTML_REMOVED]为呼叫预留端-端资源[HTML_REMOVED]
- 链路带宽、交换能力
- 专用资源:不共享
- 保证性能
- 要求建立呼叫链接
电路交换网络中的复用
网络资源(如带宽)被分成片
- 为呼叫分配片
- 如果某个呼叫没有数据,则其资源片处于[HTML_REMOVED]空闲状态[HTML_REMOVED](不共享)
- 将带宽分成片
- 频分(Frequency-division multiplexing, FDM)
- 时分(Time-division multiplexing, TDM)
- 波分(Wave-division multiplexing)
电路交换:FDM与TDM
计算举例
[HTML_REMOVED]电路交换不适合计算机之间的通信[HTML_REMOVED]
- 连接建立时间长
- 计算机之间的通信有突发性,如果使用线路交换,则浪费的片较多
- 即使这个呼叫没有数据传递,其所占据的片也不能够被别的呼叫使用
网络核心:分组交换
在各种网络应用中,端系统彼此交换报文(message)。
为了从源端系统向目的端系统发送一个报文,源将长报文划分为较小的数据块,称之为分组(packet)。
[HTML_REMOVED]以分组为单位存储-转发方式[HTML_REMOVED]
- 网络带宽资源不再分为一个个片,传输时使用全部带宽
- 主机之间传输的数据被分为一个个分组
[HTML_REMOVED]资源共享,按需使用:[HTML_REMOVED]
- 存储-转发:分组每次移动一跳(hop)
- 在转发之前,节点必须收到整个分组
- 延迟比线路交换要大
- 排队时间
分组交换:存储-转发
被传输到下一个链路之前,整个分组必须到达路由器:[HTML_REMOVED]存储-转发[HTML_REMOVED]
一个速率为R bps的链路,一个长度为L bits的分组的存储转发延时:L/R s
考虑一般的情况:通过由N条速率均为R的链路组成的路径(所以,在源和目的地之间有N-1台路由器),从源到目的地发送一个分组,那么端到端的时延是:$d_{text}{端到端} = N\frac{L}{R}$
[HTML_REMOVED]Example[HTML_REMOVED]
L = 7.5 Mbits R = 1.5 Mbps
3次存储转发的延时 = 15 s
分组交换:排队延迟和丢失
排队和延迟:
- 如果到达速率 > 链路的输出速率
- 分组将会排队,等待传输
- 如果路由器的缓存用完了,分组将会被抛弃
数据报网络和虚电路网络
分组的存储转发一段一段从源端传到目标端,按照有无网络层的连接,分成:
数据报网络和虚电路网络。
[HTML_REMOVED]数据报网络[HTML_REMOVED]
- 分组的目的地址决定下一跳
- 在不同的阶段,路由可以改变
- 类似:问路
数据报(datagram)的工作原理
- 在通信之前,无须建立起一个连接,有数据就传输
- 每一个分组都独立路由(路径不一样,可能会失序)
- 路由器根据分组的地址进行路由
[HTML_REMOVED]虚电路网络[HTML_REMOVED]
- 每个分组都带标签(虚电路标识VCID), 标签决定下一跳
- 在呼叫建立时决定路径,在整个呼叫中路径保存不变
- 路由器维持每个呼叫的状态信息
分组交换和电路交换的对比
[HTML_REMOVED]同样的网络资源,分组交换允许更多用户使用网络![HTML_REMOVED]
[HTML_REMOVED]Example[HTML_REMOVED]:
假设多个用户共享一条1Mbps链路,再假定每个用户活跃周期是变化的,某用户时而100kbps恒定速率产生数据,时而静止——这时用户不产生数据,假设该用户仅有10%时间活跃。
对于电路交换,能支持10(=1Mbps/100kbps)个并发的用户。
对于分组交换,假如有35个用户,有>=10个用户活动的概率为0.0004
计算公式:$1 - \sum\limits_{n = 0}^9 \begin{pmatrix} 35\\ a\end{pmatrix} p^n(1-p)^{35-n}$
[HTML_REMOVED] 分组交换是“突发数据的胜利者”[HTML_REMOVED]
- 适合于突发式数据传输
- 资源共享
- 简单,不必建立呼叫
- 过度使用会造成网络拥塞:分组延时和丢失
- 对可靠地数据传输需要协议来约束:拥塞控制
- 怎样提供类似电路交换的服务
- 保证音频/视频应用需要的带宽
接入网和物理媒体
[HTML_REMOVED]Q:怎样将端系统和边缘路由器连接?[HTML_REMOVED]
- 住宅接入网络
- 单位接入网络(学校、公司)
- 无线接入网络
家庭接入:DSL、电缆、FTTH、拨号和卫星
宽带住在接入有两种最流行的类型:数字用户线(Digital Subscriber Line, DSL) 和电缆。住宅通常从提供本地电话接入的本地电话公司处获得DSL因特网接入。
modem :
- 将上网数据[HTML_REMOVED]调制[HTML_REMOVED]加载音频信号上,在电话线上传输,在局端将其中的数据[HTML_REMOVED]解调[HTML_REMOVED]出来;反之亦然。
- 调频
- 调幅
- 调相位
- 综合调制
- 拨号调制解调器
- 56kbps的速率直接接入路由器(通常更低)
- 不能同时上网和打电话:不能总是在线
DSL:
- 采用现存的到交换局DSLAM的电话线
- DSL线路上的数据被传到互联网
- DSL线路上的语音被传到电话网
- < 2.5 Mbps上行传输速率(typically < 1 Mbps)
- < 24 Mbps下行传输速率(typically < 10 Mbps)
线缆网络:
有线电视信号线缆双向改造
[HTML_REMOVED]FDM[HTML_REMOVED]: 在不同频段传输不同信道的数据,数字电视和上网数据(上下行)
- HFC: hybrid fiber coax (混合光纤同轴系统)
- 非对称: 最高30Mbps的下行传输速率, 2 Mbps 上行传输
速率 - 线缆和光纤网络将个家庭用户接入到ISP 路由器
- 各用户[HTML_REMOVED]共享[HTML_REMOVED]到线缆头端的接入网络
- 与DSL不同, DSL每个用户一个专用线路到CO(central
office)
企业接入网络(Ethernet)
以太网(Ethernet)是目前为止,公司、大学和家庭网络中最为流行的接入技术。
- 经常被企业或者大学等机构采用
- 10Mbps, 100Mbps, 1Gbps, 10Gbps传输率
- 现在,端系统经常直接接到以太网络交换机上
无线接入网络
- 各无线端系统共享无线接入网络(端系统到无线路由器)
- 通过基站或者叫接入点
物理媒体
对于每个发射器-接收器对,通过跨越一种物理媒体(physical medium)传播电磁波或光脉冲来发送该比特。
- Bit: 在发送-接受对间传播
- 物理链路:连接每个发送-接收对之间的物理媒体
- 引导型媒体:
- 信号沿着固体媒介被导引:同轴电缆、光纤、双绞线
- 非导引型媒体:
- 开放的空间传播电磁波或者光信号,在电磁或者光信号中承载数字数据。
- 双绞线(TP)
- 两根绝缘铜导线拧合
- 5类:100Mbps以太网Gbps千兆位以太网
- 6类:10Gbps万兆以太网
物理媒体:同轴电缆、光纤
同轴电缆:
- 两根同轴的铜导线
- 双向
- 基带电缆:
- 电缆上一个单个信道
- Ethernet
- 宽带电缆:
- 电缆上有多个信道
- HFC
光纤和光缆
- 光脉冲,每个脉冲表示一个
bit,在玻璃纤维中传输
- 高速:
- 点到点的高速传输(如10 Gps-100Gbps传输速率)
- 低误码率:在两个中继器之间可以有很长的距离,不受电磁噪声的干扰
- 安全
物理媒介:无线链路
- 开放空间传输电磁波,携带要传输的数据
- 无需物理“线缆”
- 双向
- 传播环境效应:
- 反射
- 吸收
- 干扰
[HTML_REMOVED]无线链路类型[HTML_REMOVED]
- 地面微波
- e.g. up to 45 Mbps channels
- LAN (e.g., WiFi)
- 11Mbps, 54 Mbps,540Mbps…
- wide-area (e.g., 蜂窝)
- 3G cellular: ~ 几Mbps
- 4G 10Mbps
- 5G 数Gbps
- 卫星
- 每个信道Kbps 到45Mbps (或者多个聚集信道)
- 270 msec端到端延迟
- 同步静止卫星和低轨卫星
Internet结构和ISP
网络的网络
- 端系统通过接入ISP(Internet Service Providers)连接到互联网
- 住宅,公司和大学的ISP
- 接入ISP相应的必须是互联的
- 因此任何两个端系统可相互发送分组到对方
- 导致的“网络的网络”非常复杂
- 发展和演化是通过经济的和国家的政策来驱动的
- 采用渐进方法来描述当前互联网的结构
如何建立“网络的网络”: 将每个接入ISP都连接到全局ISP(全局范围内覆盖)?
- 客户ISPs和提供者ISPs有经济合约
-
但是,如果全局ISP是可行的业务,那会有竞争者有利可图,一定会有竞争
-
竞争:但如果全局ISP是有利可为的业务,那会有竞争者;合作:通过ISP之间的合作可以完成业务的扩展,肯定会有互联,对等互联的结算关系。
-
然后业务会细分(全球接入和区域接入),区域网络将出现,用与将接入ISPs连接到全局ISPs。
-
然后内容提供商网络(Internet Content Providers,e.g., Google,Microsoft, Akamai)可能会构建它们自己的网络,将它们的服务、内容更加靠近端用户,向用户提供更好的服务,减少自己的运营支出。
-
在网络的最中心,一些为数不多的充分连接的大范围网络(分布广、节点有限、
但是之间有着多重连接) - [HTML_REMOVED]“tier-1” commercial ISPs [HTML_REMOVED] (e.g., Level 3, Sprint, AT&T, NTT), 国家或者国际范围的覆盖。
- [HTML_REMOVED]provider network[HTML_REMOVED] (e.g., Google): 将它们的数据中心接入ISP,方便周边用户的访问;通常私有网络之间用专网绕过第一层ISP和区域ISPs.
[HTML_REMOVED]总结[HTML_REMOVED]
- 松散的层次模型
- [HTML_REMOVED]中心:第一层ISP[HTML_REMOVED](如UUNet, BBN/Genuity, Sprint,AT&T)国家/国际覆盖,速率极高。
- 直接与其他第一层ISP相连
- 与大量的第二层ISP和其他客户网络相连
- [HTML_REMOVED]第二层ISP: 更小些的(通常是区域性的) ISP[HTML_REMOVED]
- 与一个或多个第一层ISPs,也可能与其他第二层ISP
- [HTML_REMOVED]第三层ISP与其他本地ISP[HTML_REMOVED]
-
接入网(与端系统最近)
-
[HTML_REMOVED]一个分组要经过许多网络[HTML_REMOVED]
ISP之间的连接
- POP: 高层ISP面向客户网络的接入点,涉及费用结算
- 如一个低层ISP接入多个高层ISP,多宿(multi home)
- 对等接入:2个ISP对等互接,不涉及费用结算
- IXP:多个对等ISP互联互通之处,通常不涉及费用结算
- 对等接入
- ICP自己部署专用网络,同时和各级ISP连接
分组延时、丢失和吞吐量
分组丢失和延时是怎样发生的?
在路由器缓冲区的分组队列
- 分组到达链路的速率超过了链路输出的能力
- 分组等待排到队头、被传输
四种分组延时
节点处理延时:
- 检查bit级差错
- 检查分组首部和决定将分组导向何处
排队延时:
- 在输出链路上等待传输的时间
- 依赖于路由器的拥塞程度
传输延时:
- R = 链路带宽(bps)
- L = 分组长度(bits)
- 将分组发送到链路上的时间 = L/R
- 存储转发延时
传播延时:
- d = 物理链路的长度
- s = 在媒体上的传播速度(~$2\times 10 ^8 m/sec$
- 传播延时 = d / s
[HTML_REMOVED]传输时延和传播时延的比较[HTML_REMOVED]
传输时延是路由器推出分组所需要的时间,它是分组长度和链路传输速率的函数,而与两台路由器之间的距离无关。
传播时延是一个比特从一台路由器传播到另一台路由器所需要的时间,它是两台路由器之间距离的函数。
节点延时
$d_{nodal} = d_{proc} + d_{queue} + d_{trans} + d_{prop}$
- $d_{proc}$ = 处理延时
- 通常是微妙数量级或更少
- $d_{queue}$ = 排队延时
- 取决于拥塞程度
- $d_{trans}$ = 传输延时
- = L/ R, 对低速率的链路而言很大(如拨号), 通常为微秒级到毫秒级
- $d_{prop}$ = 传播延时
- 几毫秒到几百毫秒
排队延时
- R = 链路带宽(bps)
- L = 分组长度(bits)
- a = 分组到达对列的平均速率
[HTML_REMOVED]流量强度 = La/R[HTML_REMOVED] - La / R ~ 0: 平均排队延时很少
- La / R -> 1: 延时变得很大
- La / R > 1:比特到达队列的速率超过了从该队列输出的速率,平均排队延时将趋向无穷大!
Internet的延时和路由
Traceroute 诊断程序: 提供从源端,经过路由器,到目的的延时测量。
- For all i:
- 沿着目的的路径,向每个路由器发送3个探测分组
- 路由器i 将向发送方返回一个分组
- 发送方对发送和回复之间间隔计时
分组丢失
- 链路的队列缓冲区容量有限
- 当分组到达一个满的队列时,该分组将会丢失
- 丢失的分组可能会被前一个节点或源端系统重
传,或根本不重传
吞吐量
吞吐量:在源端和目标端之间传输的速率(数据量/单位时间)
- 瞬间吞吐量: 在一个时间点的速率
- 平均吞吐量: 在一个长时间内平均值
$R_s$:表示服务器于路由器之间的链路速率
$R_c$: 表示路由器于客户端之间的链路速率
例如上图,对于两链路网络,其吞吐量为:$\min{R_s, R_c}$.
瓶颈链路: 端到端路径上,限制端到端吞吐的链路。
对于N条链路的网络,其吞吐量为$\min{R_1, R_2, \cdots, R_N}$。
[HTML_REMOVED] 互联网场景 [HTML_REMOVED]
对于10个连接(公平地)共享Rbps的瓶颈链路
其每个连接上的端到端的吞吐量为 $\min{R_c, R_s, R/10}$
协议层次及服务模型
网络是一个复杂的系统!
- 网络功能繁杂:数字信号的物理信号承载、点到点、路由、rdt、进
程区分、应用等 - 现实来看,网络的许多构成元素和设备:
- 主机
- 路由器
- 各种媒体的链路
- 应用
- 协议
- 硬件, 软件
[HTML_REMOVED]Q:如何组织和实现这个复杂的网络功能[HTML_REMOVED]
层次化方式时延复杂网络功能:
- 将网络复杂的功能分层功能明确的[HTML_REMOVED]层次[HTML_REMOVED],每一层实现了其中一个或一组[HTML_REMOVED]功能[HTML_REMOVED],功能中有其上层可以使用的功能:[HTML_REMOVED]服务[HTML_REMOVED]
- 本层协议实体相互交互执行本层的[HTML_REMOVED]协议动作[HTML_REMOVED],目的是实现本层功能,通过接口为上层提供更好的服务
- 在实现本层协议的时候,直接[HTML_REMOVED]利用了下层所提供的服务[HTML_REMOVED]
- 本层的服务:借助下层服务实现的本层协议实体之间交互带来的新功能(上层可以利用的)+更下层所提供的服务
服务和服务访问点
服务( Service):低层实体向上层实体提供它们之间的通信的能力
- 服务用户(service user)
- 服务提供者(service provider )
原语(primitive):上层使用下层服务的的形式,高层使用低层提供的服务,以及低层向高层提供服务都是通过服务访问原语来进行交互的—形式。
服务访问点SAP (Services Access Point):上层使用下层提供的服务通过层间的接口—地点;
- 例子:邮箱
- 地址(address):下层的一个实体支撑着上层的多个实体,SAP有标志不同上层实体的作用
- 可以有不同的实现,队列
- 例子:传输层的SAP: 端口(port)
服务的类型:
[HTML_REMOVED]面向连接的服务[HTML_REMOVED] 和 [HTML_REMOVED]无连接的服务[HTML_REMOVED] 方式
面向连接的服务( Connection-oriented Service)
- 连接(Connection):两个通信实体为进行通信而建立的一种结合
- 面向连接的服务通信的过程:建立连接,通信,拆除连接
- 面向连接的服务的例子:网络层的连接被成为虚电路
- 适用范围:对于大的数据块要传输; 不适合小的零星报文
- 特点:保序
- 服务类型:
- 可靠的信息流传送页面(可靠的获得,通过接收方的确认)
- 可靠的字节流远程登录
- 不可靠的连接数字化声音
无连接的服务(Connectionless Service)
- 无连接服务:两个对等层实体在通信前不需要建立一个连接,不预留资源;不需要通信双方都是活跃;(例:寄信)
- 特点:不可靠、可能重复、可能失序
- IP分组,数据包;
- 适用范围:适合传送零星数据;
- 服务类型:
- 不可靠的数据报电子方式的函件
- 有确认的数据报挂号信
- 请求回答信息查询
服务和协议
服务与协议的区别:
- 服务(Service):低层实体向上层实体提供它们之间的通信的能力,是通过原语(primitive)来操作的,垂直
- 协议(protocol) :对等层实体(peer entity)之间在相互通信的过程中,需要遵循的规则的集合,水平
服务与协议的联系
- 本层[HTML_REMOVED]协议的实现[HTML_REMOVED]要靠下层提供的服务来实现
- 本层实体通过协议为上层提供[HTML_REMOVED]更高级的服务[HTML_REMOVED]
数据单元
PDU:协议数据单元
[HTML_REMOVED]PDU包含来自上层的信息和当前层的实体附加的信息,这个PDU会被传送到下一较低的层。[HTML_REMOVED]
Internet协议栈
协议栈有5个层次组成:物理层、链路层、网络层、运输层、应用层
- 应用层: 网络应用 (应用层的信息分组称为报文)
- 为人类用户或者其他应用进程提供网络应用服务
- FTP, SMTP, HTTP,DNS
- 运输层: 主机之间的数据传输 (运输层的分组称为报文段)
- 在网络层提供的端到端通信基础上,细分为进程到进程,将不可靠的通信变成可靠地通信
- TCP, UDP
- 网络层: 为数据报从源到目的选择路由 (网络层的分组称为数据报(无连接))
- 主机主机之间的通信,端到端通信,不可靠
- IP, 路由协议
- 链路层: 相邻网络节点间的数据传输 (链路层的分组称为帧指)
- 2个相邻2点的通信,点到点通信,可靠或不可靠
- 点对对协议PPP, 802.11(wifi), Ethernet
- 物理层: 在线路上传送bit
ISO/OSI 参考模型:物理层、链路层、网络层、运输层、会话层、表示层、应用层
- 表示层: 允许应用解释传输的数据, e.g., 加密,压缩,机器相关的表示转换
- 会话层: 数据交换的同步,检查点,恢复
[HTML_REMOVED] 封装和解封装 [HTML_REMOVED]
互联网历史
早期(1960以前)计算机网络
- 线路交换网络
- 线路交换的特性使得其不适合计算机之间的通信
- 线路建立时间过长
- 独享方式占用通信资源,不适合突发性很强的计算机之间的通信
- 可靠性不高:非常不适合军事通信
- 三个小组独立地开展分组交换的研究
- 1961: Kleinrock(MIT),排队论,展现了分组交换的有效性
- 1964: Baran(美国兰德公司) – 军用网络上的分组交换
- 1964:Donald(英国)等,NPL
1961-1972: 早期的分组交换概念
- 1967: 美国高级研究计划研究局考虑ARPAnet
- Kleinrock在MIT的同事
- 1969: 第一个ARPAnet节点开始工作,UCLA
- IMP:接口报文处理机
- 1969年底: 4个节点
- 1972:
- ARPAnet 公众演示
- 网络控制协议是第一个端系统直接的主机-主机协议
- NCP协议:相当于传输层和网络层在一起,支持应用开发
- 第一个e-mail 程序(BBN)
- ARPAnet有15个节点
1972-1980: 专用网络和网络互联
- 出现了很多对以后来说重要的网络形式,雨后春笋
- 1970: ALOHAnet,夏威夷上的微波网络
- 1973: Metcalfe在博士论文中提出了Ethernet
- ATM网络
- ALOHAnet,Telenet,Cyclades法国等
- 1970后期,网络体系结构的必要性
- 专用的体系结构: DECnet, SNA, XNA
- 标准化的体系结构
- 1974: 网际互联的Cerf and Kahn 体系结构
- 1979: ARPAnet的规模在持续增加,体系结构也在酝酿着变化,以支持网络互联和其他目的(性能)需求
- 节点数目增加,有200个节点
1980-1990: 体系结构变化, 网络数量激增,应用丰富
- 1983: TCP/IP部署,标记日
- NCP分化成2个层次,TCP/IP,从而出现UDP
- 覆盖式IP解决网络互联问题
- 主机设备和网络交换设备分开
- 1982: smtp e-mail协议定义
- 1983: DNS 定义,完成域名到IP地址的转换
- 1985: ftp 协议定义
- 1988: TCP拥塞控制
- 其他网络形式的发展
- 新的国家级网络: Csnet,BITnet, NSFnet, Minitel
- 1985年:ISO/OSI提出,时机不对且太繁琐,
- 100,000主机连接到网络联邦
1990, 2000’s: 商业化, Web, 新的应用
- 1990年代初: NSF对ARPAnet 的访问网,双主干,ARPAnet退役
- 1991: NSF放宽了对NSFnet用于商业目的的限制(1995退役),ASFNET非盈利性机构维护,后面叫Internet
- UNIX 中TCP/IP的免费捆绑
- 1990年代初: Web
- hypertext [Bush 1945, Nelson 1960’s]
- HTML, HTTP: Berners-Lee
- 1994: Mosaic (Netscape,and reesen)
- 1990年代后期: Web的商业化
- 1990后期– 21世纪:
- TCP/IP体系结构的包容性,在其上部署应用便捷,出现非常多的应用
- 新一代杀手级应用(即时讯息,P2P 文件共享,社交网络等)更进一步促进互联网的发展
- 安全问题不断出现和修订(互联网的补丁对策)
- 2001网络泡沫,使得一些好公司沉淀下来(谷歌,微软,苹果,Yahoo,思科)
- 主干网的速率达到Gbps
2005-现在
- ~50+亿主机:包括智能手机和平板
- 宽带接入的快速部署
- 高速无线接入无处不在:移动互联时代
- 4G部署,5G蓄势待发
- 带宽大,终端性能高,价格便宜,应用不断增多
- 在线社交网络等新型应用的出现:
- Facebook: 10亿用户
- 微信,qq:数十亿用户
- 内容提供商(Google, Microsoft)创建他们自己的网络
- 通过自己的专用网络提供对搜索、视频内容和电子邮件的即刻访问
- 电子商务,大学,企业在云中运行他们的服务(eg, Amazon EC2)
- 体系结构酝酿着大的变化,未来网络蠢蠢欲动
结尾: 这篇博客整理了好久,大概花了接近一天的时间,这篇博客是计算机网络第一章,打算每周学习一章的进度,并记入学习笔记,转化博客。目前本人已经大四,希望自己能沉浸下来,认认真真学点东西,Fighting。