Algoritmos de Enrutamiento
-
Upload
alex-fernando-ldu -
Category
Documents
-
view
22 -
download
0
Transcript of Algoritmos de Enrutamiento
![Page 1: Algoritmos de Enrutamiento](https://reader030.fdocuments.es/reader030/viewer/2022032623/55cf9dd1550346d033af56c1/html5/thumbnails/1.jpg)
LABORATORIO DE PROGRAMACIÓN DE REDES Área de Ingeniería Telemática
Tipos de algoritmos de enrutamiento
Area de Ingeniería Telemática http://www.tlm.unavarra.es
Laboratorio de Programación de Redes 3º Ingeniería Técnica en Informática de Gestión
![Page 2: Algoritmos de Enrutamiento](https://reader030.fdocuments.es/reader030/viewer/2022032623/55cf9dd1550346d033af56c1/html5/thumbnails/2.jpg)
LAB
OR
ATO
RIO
DE
PR
OG
RA
MA
CIÓ
N D
E R
EDES
Á
rea
de In
geni
ería
Tel
emát
ica Objetivo
• Características de los tipos de algoritmos de enrutamiento
![Page 3: Algoritmos de Enrutamiento](https://reader030.fdocuments.es/reader030/viewer/2022032623/55cf9dd1550346d033af56c1/html5/thumbnails/3.jpg)
LAB
OR
ATO
RIO
DE
PR
OG
RA
MA
CIÓ
N D
E R
EDES
Á
rea
de In
geni
ería
Tel
emát
ica Contenido
• Introducción • Algoritmos Link-State • Algoritmos Distance-Vector
– Descripción – Bellman-Ford
• Algoritmos Path-Vector
![Page 4: Algoritmos de Enrutamiento](https://reader030.fdocuments.es/reader030/viewer/2022032623/55cf9dd1550346d033af56c1/html5/thumbnails/4.jpg)
LAB
OR
ATO
RIO
DE
PR
OG
RA
MA
CIÓ
N D
E R
EDES
Á
rea
de In
geni
ería
Tel
emát
ica
Tipos de Protocolos de Enrutamiento
Enrutamiento jerárquico • Sistemas Autónomos (AS) • Dentro de un AS:
– IGP = Interior Gateway Protocol
• Entre ASs: – EGP = Exterior Gateway Protocol
AS 1
AS 2
AS 3
![Page 5: Algoritmos de Enrutamiento](https://reader030.fdocuments.es/reader030/viewer/2022032623/55cf9dd1550346d033af56c1/html5/thumbnails/5.jpg)
LAB
OR
ATO
RIO
DE
PR
OG
RA
MA
CIÓ
N D
E R
EDES
Á
rea
de In
geni
ería
Tel
emát
ica
Tipos de Algoritmos de Enrutamiento
• Deben informar de la topología y los cambios en la misma
• Según cómo diseminan la información
Link State: • Comunican qué vecinos tienen
y el coste • Inundan la red • Cada nodo conoce la topología
entera
Distance Vector: • Comunican estimación de
distancia a destinos • Informan a vecinos Path Vector: • Comunican estimación de
caminos preferidos a destinos
AS 1
AS 2
AS 3
![Page 6: Algoritmos de Enrutamiento](https://reader030.fdocuments.es/reader030/viewer/2022032623/55cf9dd1550346d033af56c1/html5/thumbnails/6.jpg)
LAB
OR
ATO
RIO
DE
PR
OG
RA
MA
CIÓ
N D
E R
EDES
Á
rea
de In
geni
ería
Tel
emát
ica
Tipos de Algoritmos de Enrutamiento
A B
C D
1 2
3 1
A B
C D
1 2
3 1 A
B
C D
1 2
3 1 A
B
C D
1 2
3 1
Link
Sta
te
Dis
tanc
e Ve
ctor
Pa
th V
ecto
r
0
0
1
3
A B
C D
1 2
3 1 A
B
C D
1 2
3 1 A
B
C D
1 2
3 1
D
D
B,D
C,D
No me gusta “B”
A: [B, 2], [C, 1] B: [A, 2], [D, 1] C: [A, 1], [D, 3] D: [B, 1], [C, 3]
![Page 7: Algoritmos de Enrutamiento](https://reader030.fdocuments.es/reader030/viewer/2022032623/55cf9dd1550346d033af56c1/html5/thumbnails/7.jpg)
LAB
OR
ATO
RIO
DE
PR
OG
RA
MA
CIÓ
N D
E R
EDES
Á
rea
de In
geni
ería
Tel
emát
ica Link State
Tres pasos 1. Descubrir a los vecinos 2. Diseminar la información sobre los
enlaces – Flooding (… …) – Todos conocen la topología (…)
3. Calcular las rutas – Caminos de menor coste – Todos calculan los mismos – Algoritmo de Dijkstra
• OSPF, IS-IS
AS 2
A B D
E
C
![Page 8: Algoritmos de Enrutamiento](https://reader030.fdocuments.es/reader030/viewer/2022032623/55cf9dd1550346d033af56c1/html5/thumbnails/8.jpg)
LAB
OR
ATO
RIO
DE
PR
OG
RA
MA
CIÓ
N D
E R
EDES
Á
rea
de In
geni
ería
Tel
emát
ica Link State
Tres pasos 1. Descubrir a los vecinos 2. Diseminar la información sobre los
enlaces – Flooding (… …) – Todos conocen la topología (…)
3. Calcular las rutas – Caminos de menor coste – Todos calculan los mismos – Algoritmo de Dijkstra
• OSPF, IS-IS
AS 2
A B D
E
C 1 1 1
1
1
1 1 1
1
1
1 1 1
1
1
1 1 1
1
1
1 1 1
1
1
(etc…)
![Page 9: Algoritmos de Enrutamiento](https://reader030.fdocuments.es/reader030/viewer/2022032623/55cf9dd1550346d033af56c1/html5/thumbnails/9.jpg)
LAB
OR
ATO
RIO
DE
PR
OG
RA
MA
CIÓ
N D
E R
EDES
Á
rea
de In
geni
ería
Tel
emát
ica
• Cada nodo llega a conocer la distancia desde él a todos los destinos – D(X,di)
• Inicialmente cada nodo solo conoce distancia a sus vecinos (…) – D(X,d)=c(X,d)
• Periódicamente comunica D(X,d) a todos sus vecinos – Informan con un vector con las distancias a los destinos
( D(X,d1), D(X,d2), D(X,d3), D(X,d4)…) – Asíncrono
• Al recibir información actualiza (… …): – D(X,d)!mínj/c(X,j)<"{c(X,j)+D(j,d)}
• Algoritmo de Bellman-Ford distribuido • Empleado desde los comienzos de la ARPANET
Distance Vector
X!D(X,di)
![Page 10: Algoritmos de Enrutamiento](https://reader030.fdocuments.es/reader030/viewer/2022032623/55cf9dd1550346d033af56c1/html5/thumbnails/10.jpg)
LAB
OR
ATO
RIO
DE
PR
OG
RA
MA
CIÓ
N D
E R
EDES
Á
rea
de In
geni
ería
Tel
emát
ica
• Cada nodo llega a conocer la distancia desde él a todos los destinos – D(X,di)
• Inicialmente cada nodo solo conoce distancia a sus vecinos (…) – D(X,d)=c(X,d)
• Periódicamente comunica D(X,d) a todos sus vecinos – Informan con un vector con las distancias a los destinos
( D(X,d1), D(X,d2), D(X,d3), D(X,d4)…) – Asíncrono
• Al recibir información actualiza (… …): – D(X,d)!mínj/c(X,j)<"{c(X,j)+D(j,d)}
• Algoritmo de Bellman-Ford distribuido • Empleado desde los comienzos de la ARPANET
Distance Vector
j!
X!
c(X,j) j’!
D(X,j)=c(X,j) D(X,j’)=c(X,j’)
c(X,j’)
![Page 11: Algoritmos de Enrutamiento](https://reader030.fdocuments.es/reader030/viewer/2022032623/55cf9dd1550346d033af56c1/html5/thumbnails/11.jpg)
LAB
OR
ATO
RIO
DE
PR
OG
RA
MA
CIÓ
N D
E R
EDES
Á
rea
de In
geni
ería
Tel
emát
ica
• Cada nodo llega a conocer la distancia desde él a todos los destinos – D(X,di)
• Inicialmente cada nodo solo conoce distancia a sus vecinos (…) – D(X,d)=c(X,d)
• Periódicamente comunica D(X,d) a todos sus vecinos – Informan con un vector con las distancias a los destinos
( D(X,d1), D(X,d2), D(X,d3), D(X,d4)…) – Asíncrono
• Al recibir información actualiza (… …): – D(X,d)!mínj/c(X,j)<"{c(X,j)+D(j,d)}
• Algoritmo de Bellman-Ford distribuido • Empleado desde los comienzos de la ARPANET
Distance Vector
j!
X!
d!
D(j,d)
c(X,j) j’!
D(j’,d)
c(X,j’) psst... D(j,d)
psst... D(j’,d)
![Page 12: Algoritmos de Enrutamiento](https://reader030.fdocuments.es/reader030/viewer/2022032623/55cf9dd1550346d033af56c1/html5/thumbnails/12.jpg)
LAB
OR
ATO
RIO
DE
PR
OG
RA
MA
CIÓ
N D
E R
EDES
Á
rea
de In
geni
ería
Tel
emát
ica
• Cada nodo llega a conocer la distancia desde él a todos los destinos – D(X,di)
• Inicialmente cada nodo solo conoce distancia a sus vecinos (…) – D(X,d)=c(X,d)
• Periódicamente comunica D(X,d) a todos sus vecinos – Informan con un vector con las distancias a los destinos
( D(X,d1), D(X,d2), D(X,d3), D(X,d4)…) – Asíncrono
• Al recibir información actualiza (… …): – D(X,d)!mínj/c(X,j)<"{c(X,j)+D(j,d)}
• Algoritmo de Bellman-Ford distribuido • Empleado desde los comienzos de la ARPANET
Distance Vector
j!
X!
d!
D(j,d)
c(X,j) j’!
D(j’,d)
c(X,j)+D(j,d) c(X,j’)+D(j’,d)
c(X,j’)
![Page 13: Algoritmos de Enrutamiento](https://reader030.fdocuments.es/reader030/viewer/2022032623/55cf9dd1550346d033af56c1/html5/thumbnails/13.jpg)
LAB
OR
ATO
RIO
DE
PR
OG
RA
MA
CIÓ
N D
E R
EDES
Á
rea
de In
geni
ería
Tel
emát
ica
Dest Next Cost
A A 1 B B 4 C - " D D 1
Dest Next Cost
A - " B B 3 C - " E E 1
Dest Next Cost
A - " B B 1 D - " E - "
Dest Next Cost
A A 1 C C 1 D D 3 E E 4
Dest Next Cost
B B 1 C - " D - " E E 1
Algoritmo de Bellman-Ford • Comienzo
A! B! D!
E!
C!1
1 3
1 1 4
![Page 14: Algoritmos de Enrutamiento](https://reader030.fdocuments.es/reader030/viewer/2022032623/55cf9dd1550346d033af56c1/html5/thumbnails/14.jpg)
LAB
OR
ATO
RIO
DE
PR
OG
RA
MA
CIÓ
N D
E R
EDES
Á
rea
de In
geni
ería
Tel
emát
ica
Dest Next Cost
A A 1 B B 4 C - " D D 1
Dest Next Cost
A - " B B 3 C - " E E 1
Dest Next Cost
A - " B B 1 D - " E - "
Dest Next Cost
A A 1 C C 1 D D 3 E E 4
Dest Next Cost
B B 1 C - " D - " E E 1
A envía D(E,d)!mín{c(E,A)+D(A,d)} D(B,d)!mín{c(B,A)+D(A,d)} (…)
Algoritmo de Bellman-Ford
A! B! D!
E!
C!1
1 3
1 1 4
![Page 15: Algoritmos de Enrutamiento](https://reader030.fdocuments.es/reader030/viewer/2022032623/55cf9dd1550346d033af56c1/html5/thumbnails/15.jpg)
LAB
OR
ATO
RIO
DE
PR
OG
RA
MA
CIÓ
N D
E R
EDES
Á
rea
de In
geni
ería
Tel
emát
ica
Dest Next Cost
A A 1 B A (B) 2 (4) C - " D D 1
Dest Next Cost
A - " B B 3 C - " E E 1
Dest Next Cost
A - " B B 1 D - " E - "
Dest Next Cost
A A 1 C C 1 D D 3 E A (E) 2 (4)
Dest Next Cost
B B 1 C - " D - " E E 1
A envía D(E,d)!mín{c(E,A)+D(A,d)} D(B,d)!mín{c(B,A)+D(A,d)}
Algoritmo de Bellman-Ford
A! B! D!
E!
C!1
1 3
1 1 4
![Page 16: Algoritmos de Enrutamiento](https://reader030.fdocuments.es/reader030/viewer/2022032623/55cf9dd1550346d033af56c1/html5/thumbnails/16.jpg)
LAB
OR
ATO
RIO
DE
PR
OG
RA
MA
CIÓ
N D
E R
EDES
Á
rea
de In
geni
ería
Tel
emát
ica
Dest Next Cost
A A 1 B A 2 C - " D D 1
Dest Next Cost
A - " B B 3 C - " E E 1
Dest Next Cost
A - " B B 1 D - " E - "
Dest Next Cost
A A 1 C C 1 D D 3 E A 2
Dest Next Cost
B B 1 C - " D - " E E 1
D envía D(E,d)!mín{c(E,D)+D(D,d)} D(B,d)!mín{c(B,D)+D(D,d)} No hay cambios
Algoritmo de Bellman-Ford
A! B! D!
E!
C!1
1 3
1 1 4
![Page 17: Algoritmos de Enrutamiento](https://reader030.fdocuments.es/reader030/viewer/2022032623/55cf9dd1550346d033af56c1/html5/thumbnails/17.jpg)
LAB
OR
ATO
RIO
DE
PR
OG
RA
MA
CIÓ
N D
E R
EDES
Á
rea
de In
geni
ería
Tel
emát
ica
Dest Next Cost
A A 1 B A 2 C - " D D 1
Dest Next Cost
A - " B B 3 C - " E E 1
Dest Next Cost
A - " B B 1 D - " E - "
Dest Next Cost
A A 1 C C 1 D D 3 E A 2
Dest Next Cost
B B 1 C - " D - " E E 1
B envía D(A,d)!mín{c(A,B)+D(B,d)} D(C,d)!mín{c(C,B)+D(B,d)} D(D,d)!mín{c(D,B)+D(B,d)} D(E,d)!mín{c(E,B)+D(B,d)} (…)
Algoritmo de Bellman-Ford
A! B! D!
E!
C!1
1 3
1 1 4
![Page 18: Algoritmos de Enrutamiento](https://reader030.fdocuments.es/reader030/viewer/2022032623/55cf9dd1550346d033af56c1/html5/thumbnails/18.jpg)
LAB
OR
ATO
RIO
DE
PR
OG
RA
MA
CIÓ
N D
E R
EDES
Á
rea
de In
geni
ería
Tel
emát
ica
Dest Next Cost
A A 1 B A 2 C B (-) 5 (") D D 1
Dest Next Cost
A B (-) 4 (") B B 3 C B (-) 4 (") E E 1
Dest Next Cost
A B (-) 2 (") B B 1 D B (-) 4 (") E B (-) 3 (")
Dest Next Cost
A A 1 C C 1 D D 3 E A 2
Dest Next Cost
B B 1 C B (-) 2 (") D B (-) 4 (") E E 1
B envía D(A,d)!mín{c(A,B)+D(B,d)} D(C,d)!mín{c(C,B)+D(B,d)} D(D,d)!mín{c(D,B)+D(B,d)} D(E,d)!mín{c(E,B)+D(B,d)}
Algoritmo de Bellman-Ford
A! B! D!
E!
C!1
1 3
1 1 4
![Page 19: Algoritmos de Enrutamiento](https://reader030.fdocuments.es/reader030/viewer/2022032623/55cf9dd1550346d033af56c1/html5/thumbnails/19.jpg)
LAB
OR
ATO
RIO
DE
PR
OG
RA
MA
CIÓ
N D
E R
EDES
Á
rea
de In
geni
ería
Tel
emát
ica
Dest Next Cost
A A 1 B A 2 C B 5 D D 1
Dest Next Cost
A B 4 B B 3 C B 4 E E 1
Dest Next Cost
A B 2 B B 1 D B 4 E B 3
Dest Next Cost
A A 1 C C 1 D D 3 E A 2
Dest Next Cost
B B 1 C B 2 D B 4 E E 1
C envía D(B,d)!mín{c(B,C)+D(C,d)} No hay cambios
Algoritmo de Bellman-Ford
A! B! D!
E!
C!1
1 3
1 1 4
![Page 20: Algoritmos de Enrutamiento](https://reader030.fdocuments.es/reader030/viewer/2022032623/55cf9dd1550346d033af56c1/html5/thumbnails/20.jpg)
LAB
OR
ATO
RIO
DE
PR
OG
RA
MA
CIÓ
N D
E R
EDES
Á
rea
de In
geni
ería
Tel
emát
ica
Dest Next Cost
A A 1 B A 2 C B 5 D D 1
Dest Next Cost
A B 4 B B 3 C B 4 E E 1
Dest Next Cost
A B 2 B B 1 D B 4 E B 3
Dest Next Cost
A A 1 C C 1 D D 3 E A 2
Dest Next Cost
B B 1 C B 2 D B 4 E E 1
E envía D(A,d)!mín{c(A,E)+D(E,d)} D(B,d)!mín{c(B,E)+D(E,d)} D(D,d)!mín{c(D,E)+D(E,d)} (…)
Algoritmo de Bellman-Ford
A! B! D!
E!
C!1
1 3
1 1 4
![Page 21: Algoritmos de Enrutamiento](https://reader030.fdocuments.es/reader030/viewer/2022032623/55cf9dd1550346d033af56c1/html5/thumbnails/21.jpg)
LAB
OR
ATO
RIO
DE
PR
OG
RA
MA
CIÓ
N D
E R
EDES
Á
rea
de In
geni
ería
Tel
emát
ica
Dest Next Cost
A A 1 B A 2 C B 5 D D 1
Dest Next Cost
A E (B) 2 (4) B B 3 C B 4 E E 1
Dest Next Cost
A B 2 B B 1 D B 4 E B 3
Dest Next Cost
A A 1 C C 1 D D 3 E A 2
Dest Next Cost
B B 1 C B 2 D E (B) 2 (4) E E 1
E envía D(A,d)!mín{c(A,E)+D(E,d)} D(B,d)!mín{c(B,E)+D(E,d)} D(D,d)!mín{c(D,E)+D(E,d)}
Algoritmo de Bellman-Ford
A! B! D!
E!
C!1
1 3
1 1 4
![Page 22: Algoritmos de Enrutamiento](https://reader030.fdocuments.es/reader030/viewer/2022032623/55cf9dd1550346d033af56c1/html5/thumbnails/22.jpg)
LAB
OR
ATO
RIO
DE
PR
OG
RA
MA
CIÓ
N D
E R
EDES
Á
rea
de In
geni
ería
Tel
emát
ica
Dest Next Cost
A A 1 B A 2 C B 5 D D 1
Dest Next Cost
A E 2 B B 3 C B 4 E E 1
Dest Next Cost
A B 2 B B 1 D B 4 E B 3
Dest Next Cost
A A 1 C C 1 D D 3 E A 2
Dest Next Cost
B B 1 C B 2 D E 2 E E 1
A envía D(E,d)!mín{c(E,A)+D(A,d)} D(B,d)!mín{c(B,A)+D(A,d)} (…)
Algoritmo de Bellman-Ford
A! B! D!
E!
C!1
1 3
1 1 4
![Page 23: Algoritmos de Enrutamiento](https://reader030.fdocuments.es/reader030/viewer/2022032623/55cf9dd1550346d033af56c1/html5/thumbnails/23.jpg)
LAB
OR
ATO
RIO
DE
PR
OG
RA
MA
CIÓ
N D
E R
EDES
Á
rea
de In
geni
ería
Tel
emát
ica
Dest Next Cost
A A 1 B A 2 C A (B) 3 (5) D D 1
Dest Next Cost
A E 2 B B 3 C B 4 E E 1
Dest Next Cost
A B 2 B B 1 D B 4 E B 3
Dest Next Cost
A A 1 C C 1 D D 3 E A 2
Dest Next Cost
B B 1 C B 2 D E 2 E E 1
A envía D(E,d)!mín{c(E,A)+D(A,d)} D(B,d)!mín{c(B,A)+D(A,d)}
Algoritmo de Bellman-Ford
A! B! D!
E!
C!1
1 3
1 1 4
![Page 24: Algoritmos de Enrutamiento](https://reader030.fdocuments.es/reader030/viewer/2022032623/55cf9dd1550346d033af56c1/html5/thumbnails/24.jpg)
LAB
OR
ATO
RIO
DE
PR
OG
RA
MA
CIÓ
N D
E R
EDES
Á
rea
de In
geni
ería
Tel
emát
ica
Dest Next Cost
A A 1 B A 2 C A 3 D D 1
Dest Next Cost
A E 2 B B 3 C B 4 E E 1
Dest Next Cost
A B 2 B B 1 D B 4 E B 3
Dest Next Cost
A A 1 C C 1 D D 3 E A 2
Dest Next Cost
B B 1 C B 2 D E 2 E E 1
D envía No hay cambios
B envía No hay cambios
C envía No hay cambios
E envía No hay cambios
A envía No hay cambios
Algoritmo de Bellman-Ford
A! B! D!
E!
C!1
1 3
1 1 4
![Page 25: Algoritmos de Enrutamiento](https://reader030.fdocuments.es/reader030/viewer/2022032623/55cf9dd1550346d033af56c1/html5/thumbnails/25.jpg)
LAB
OR
ATO
RIO
DE
PR
OG
RA
MA
CIÓ
N D
E R
EDES
Á
rea
de In
geni
ería
Tel
emát
ica Distance Vector
• Cálculo distribuido • Iterativo e incremental • Asíncrono • Converge a los caminos de menor
coste • Protocolos: RIP, IPX-RIP, DECnet,
IGRP, EIGRP, DSDV
![Page 26: Algoritmos de Enrutamiento](https://reader030.fdocuments.es/reader030/viewer/2022032623/55cf9dd1550346d033af56c1/html5/thumbnails/26.jpg)
LAB
OR
ATO
RIO
DE
PR
OG
RA
MA
CIÓ
N D
E R
EDES
Á
rea
de In
geni
ería
Tel
emát
ica Path Vector
• Similar a Distance Vector • Cálculo distribuido • Informan a sus vecinos de las rutas calculadas • Incluyen todo el camino hasta el destino para cada
ruta • Protocolos: BGP
A!B!
C!D!
1 2
3 1 A!
B!
C!D!
1 2
3 1 A!
B!
C!D!
1 2
3 1
0
0
B,D
C,D
No me gusta “B”