路由

本页使用了标题或全文手工转换
维基百科,自由的百科全书

路由形式

单播

任播

多播

广播

地域性广播

路由routing)是任何网路中选取路径的程序,在此"程序"是指一组在电脑中执行的程式。电脑网路由称为节点的许多机器(例如电脑)以及连线至这些节点的路径或连结所组成。网路中相互连接的两个节点之间的通讯可以透过许多不同的路径进行。路由是使用一些预定规则选取最佳路径的程序。

设置与发展路由的原因是路由建立了网路通讯的效率。网路通讯失败会导致使用者载入网站页面需要长时间等待。因为无法处理大量使用者,它也可能会导致网站伺服器失败。路由可以管理资料流量,来协助将网路故障降至最低,让网路尽可能使用其容量而不会产生拥塞。

其目的是通过互联的网络信息从源地址以有效率的方式传输到目的地址的活动。路由发生在OSI网络参考模型中的第三层即网络层

路由引导分组转送,经过一些中间的节点后,到它们最后的目的地。作成硬体的话,则称为路由器。路由通常根据路由表——一个储存到各个目的地的最佳路径的表——来引导分组转送。因此为了有效率的转送分组,建立储存在路由器记忆体内的路由表是非常重要的。

路由与桥接的不同,在于路由假设位址相似的节点距离相近。这使得路由表中的一项纪录可以表示到一群位址的路径。因此,在大型网路中,路由优于桥接,且路由已经成为网际网路上寻找路径的最主要方法。

较小的网路通常可以手动设定路由表,但较大且拥有复杂拓扑的网路可能常常变化,若要手动建立路由表是不切实际的。尽管如此,大多数的公共交换电话网路(PSTN)仍然使用预先计算好的路由表,在直接连线的路径断线时才使用预备的路径;见公共交换电话网路由。“动态路由”尝试按照由路由协定所携带的资讯来自动建立路由表以解决这个问题,也让网路能够近自主地避免网路断线或失败。

动态路由目前主宰了整个网际网路。然而,设定路由协定常须要经验与技术;目前的网路技术还没有发展到能够全自动地设定路由。

分组交换网路(例如网际网路)将资料分割成许多带有完整目的地位址的分组,每个分组单独转送。而电路交换网路(例如公共交换电话网路)同样使用路由来找到一条路径,让接下来的资料能够抵达正确的目的地。

动态路由[编辑]

若某个设定好的路径无法使用时,现存的节点必须决定另一个传送资料到目的地的路径。他们通常使用以下两种形式的路由协定来达成:距离向量演算法与连线状态演算法。所有路由演算法几乎都可以分类到这两种演算法中。

距离向量演算法[编辑]

距离向量演算法使用Bellman-Ford演算法。对于每一条网路上节点间的路径,演算法指定一个“成本”给它们。节点会选择一条总成本(经过路径的所有成本总和)最低的路径,用来把资料从节点甲送到节点乙。

此演算法非常的简单。当某节点初次启动时,将只知道它的邻居节点(直接连接到该节点的节点)与到该节点的成本。(这些资讯、目的地列表、每个目的地的总成本,以及到某个目的地所必须经过的“下一个节点”,构成路由表,或称距离表。)每个节点定时地将目前所知,到各个目的地的成本的资讯,送给每个邻居节点。邻居节点则检查这些资讯,并跟目前所知的资讯做比较;如果到某个目的地的成本比目前所知的低,则将收到的资讯加入自己的路由表。经过一段时间后,网路上的所有节点将会了解到所有目的地的最佳“下一个节点”与最低的总成本。

当某个节点断线时,每个将它当作某条路径的“下一个节点”的节点会将该路由资讯舍弃,再建立新的路由表资讯。接著,他们将这些资讯告诉所有相邻的节点,再找出到所有可抵达的目的地之新路径。

连线状态演算法[编辑]

连线状态演算法中,每个节点拥有网路的图谱(一个)。每个节点将自己可以连接到的其他节点资讯传送到网路上所有的节点,而其他节点接著各自将这个资讯加入到图谱中。每个路由器即可根据这个图谱来决定从自己到其它节点的最佳路径。

完成这个动作的演算法——Dijkstra演算法——建立另一种资料结构——。节点产生的树将自己视为根节点,且最后这棵树将会包含了网路中所有其他的节点。一开始,此树只有根节点(节点自己)。接著在树中已有的节点的邻居节点且不存在树中的节点集合中,选取一个成本最低的节点加入此树,直到所有节点都存入树中为止。

这棵树即用来建立路由表、提供最佳的“下一个节点”等,让节点能跟网路中其它节点通讯。

路由演算法的比较[编辑]

在小型网路中,距离向量路由协定十分简单且有效率,且只需要一些管理。然而,它们的规模性不好,且 收敛性质也十分差,因此促进了较复杂但规模性较好的连线状态路由协定的开发,以使用在较大型的网路。距离向量路由协定也有无限计数问题[1]

连线状态路由协定的主要优点是在限制的时间内,对于连线改变(例如断线)的反应较快。而且连线状态路由协定在网路上所传送的封包也比距离向量路由协定的封包小。距离向量路由协定必须传送一个节点的整个路由表,但连线状态路由协定的封包只需要传输该节点的邻居节点资讯即可。因此,这些封包小到不会占用可观的网路资源。连线状态路由协定的主要缺点则是比距离向量路由协定需要较多的储存空间与较强的计算能力。

路由协定与可被绕送协定[编辑]

有时路由协定与可被绕送协定常会令人混淆:

  • 可被绕送协定:任何一个提供足够的网路层位址资讯让封包可被从一个装置转送到另一个,而不需要知道来源到目的地的整条路径的网路通讯协定。“可被绕送协定”定义了封包的格式与封包栏位的使用方式。封包通常从一个终端系统被递送到另一个。IP是一个可被绕送协定,而乙太网路是一个不可被绕送协定的例子。
  • 路由协定:在网路间交换路由资讯,让路由器可动态建立路由表的通讯协定。传统的IP路由十分简单,因为它使用下一个节点路由方法,也就是路由器只需要考虑将封包送到哪一个“下一个节点”,而不需考虑到目的地的整条路径。

虽然动态路由可能非常复杂,但它使得网际网路十分有弹性,且让网际网路的规模自从采用IP以后成长了超过八个数量级

路由度量(routing metric)包含了被路由演算法使用来决定哪一条路径较另一条路径好的所有数值。度量可能包括许多资讯,例如频宽延迟经过节点数、路径成本、负载、MTU、可靠性及传输成本等。路由表只储存最佳的可能路径,但连线状态或拓扑资料库可能储存其他相关的资讯。

当路由器从不同的路由协定里发现有多个能抵达相同目的地的不同路径时,它们使用称为管理距离(administrative distance)的特性来选择最佳的路径。管理距离定义了路由协定的可靠程度。每个路由协定按照管理距离值,由最可靠到最不可靠排列来区分优先顺序。

依照路由器与其他自治系统的关系,有许多种类的路由协定:

  • 内部闸道协定IGPs)在单一的自治系统中交换路由资讯。常见的范例包括:
    • IGRP(Interior Gateway Routing Protocol)
    • EIGRP(Enhanced Interior Gateway Routing Protocol)[2]
    • OSPF(Open Shortest Path First)
    • RIP(Routing Information Protocol)
    • IS-IS(Intermediate System to Intermediate System)
  • 外部闸道协定EGPs)在不同的自治系统中交换路由资讯。EGP包括:
    • EGP(原本用来连接网际网路骨干的外部闸道协定,现在已不再使用)
    • BGP(Border Gateway Protocol:大约从1995年开始使用目前的版本,BGPv4)

注释[编辑]

  1. ^ Count-To-Infinity Problem. (原始内容存档于2006-12-09). 
  2. ^ 在许多思科的广告文件中,EIGRP 不是一种连线状态路由协定,也不是任何一种混合式的协定。

参见[编辑]

参考资料[编辑]

外部链接[编辑]