1.
Introduction to Dynamic Routing Protocols
In the real world, and especially in larger environments, companies usually rely on dynamic
routing protocols to keep routing tables updated. Quite simply, it is easier to configure all routers
to use a dynamic routing protocol and have them learn about unconnected networks from
other routers, rather than statically defining a route to each and every network on every
router. Dynamic routing protocols also provide a degree of fault tolerance. If a network or router
fails on a network using dynamic routing protocols, other routers will find out about it, either
through updates from neighboring routers, or via the absence of updates messages. In contrast,
with only static routes defined, neighboring routers do not exchange information. When a network
or router fails in a static routing environment, other routers do nothing to compensate for the
failure.
1.1 Administrative Distances
The administrative distance (AD) is used to rate the trustworthiness of routing information
received on a router from a neighbor router. An administrative distance is an integer from 0 to
255, where 0 is the most trusted and 255 means no traffic will be passed via this route.
If a router receives two updates listing the same remote network, the first thing the router checks
is the AD. If one of the advertised routes has a lowest AD than the other, then the route with the
lowest AD will be placed in the routing table.
If both advertised routes to the same network have the same AD, then routing protocol metrics
(such as hop count or bandwidth of the lines) will be used to find the best path to the remote
network. The advertised route with the lowest metric will be place in the routing table. If both
advertised routes have the same AD as well as the same metrics, then the routing protocol will
load-balance to the remote network (which means that it sends packets down each link).
                          Table 1  Default Administrative Distances
Route Source                                   Default AD
Connected interface                            0
Static route                                   1
EIGRP                                          90
IGRP                                           100
OSPF                                           110
RIP                                            120
Unknown                                        255 (this route will never be used)
1.2 Dynamic Routing Protocols
There are three classes of routing protocols.
 Distance Vector Routing Protocols
 Link State Routing Protocols
 Hybrid Routing Protocols
1.2.1 Distance Vector Routing Protocols
The distance-vector protocols find the best path to a remote network by judging distance. Each
time a packet goes through a router that is called a hop. The route with the least number of hops
to the network is determined to be the best route. The vector indicates the direction to the remote
network. Both RIP and IGRP are distance-vector routing protocols. The distance-vector routing
algorithm passes complete routing table contents to neighboring routers, which then combine the
received routing table entries with their own routing tables to complete the routers routing table.
This is called routing by rumor, because a router receiving an update from a neighbor router
believes the information about remote networks without actually finding out for itself.
1.2.1.1 Routing Information Protocol (RIP)
Routing Information Protocol (RIP) is a true distance-vector routing protocol. It sends the
complete routing table out to all active interfaces every 30 seconds. RIP only uses hop count to
determine the best way to a remote network, but it has a maximum allowable hop count of 15 by
default, meaning that 16 is deemed unreachable. RIP works well in small networks, but it is
inefficient on large networks with slow WAN links or on networks with a large number of routers
installed.
RIP version 1 uses only classful routing, which means that all devices in the network must use
the same subnet mask. This is because RIP version 1 does not send updates with subnet mask
information. RIP version 2 provides something called prefix routing and does send subnet mask
information with the route updates. This is called classless routing.
Configuring RIP is pretty much straight forward. You just turn on the protocol stack with the help
of the command router rip and then instruct RIP which networks to advertise.
Lets start by configuring routerA. This specific router has three directly connected networks.
We want these networks to be advertised by RIP and this is how we do it:
RouterA(config)#router rip
RouterA(config-router)#version            2
RouterA(config-router)#network            192.168.10.0
RouterA(config-router)#network            10.10.25.0
RouterA(config-router)#network            10.10.125.0
Topology
Device       Interface     IP Address      Subnet Mask      Default Gateway
                                         255.255.255.2
R1           F0/0         192.168.2.1    52              N/A
             F0/1         192.168.1.1    255.255.255.0   N/A
                                         255.255.255.2
R2           F0/0         192.168.2.2    52              N/A
                                         255.255.255.2
             F0/1         192.168.3.1    52              N/A
                                         255.255.255.2
R3           F0/0         192.168.3.2    52              N/A
             F0/1         192.168.4.1    255.255.255.0   N/A
PC-A         NIC          192.168.1.10   255.255.255.0   192.168.1.1
PC-B         NIC          192.168.4.10   255.255.255.0   192.168.4.1
Configure the IP address, subnet mask, and default gateway settings on
PC-A and PC-B.
Configure the router (R1)
     a. Console into the router and enable privileged EXEC mode.
         Router> enable
         Router#
     b. Enter configuration mode.
         Router# conf t
         Enter configuration commands, one per line.     End with CNTL/Z.
         Router(config)#
     c. Assign a device name to the router.
         Router(config)# hostname R1
     d. Disable DNS lookup to prevent the router from attempting to
        translate incorrectly entered commands as though they were host
        names.
         R1(config)# no ip domain-lookup
     e. Assign class as the privileged EXEC encrypted password.
         R1(config)# enable secret class
     f. Assign cisco as the console password and enable login, and also to
        specify no timeout:
            R1(config)# line con 0
         R1(config-line)# password cisco
         R1(config-line)# login
         R1(config-line)# exec-timeout 0 0
         R1(config-line)# exit
         R1(config)#
     g. Assign cisco as the vty password and enable login and also
         R1(config)# line vty 0 4
        R1(config-line)#     password cisco
        R1(config-line)#     login
        R1(config-line)#     exec-timeout 0 0
        R1(config-line)#     exit
        R1(config)#
     h. Encrypt the clear text passwords.
        R1(config)# service password-encryption
     i. Configure and activate both interfaces on the router.
        R1(config)# int f0/0
        R1(config-if)# ip address 192.168.2.1 255.255.255.252
        R1(config-if)# no shut
        R1(config-if)#exit
        R1(config)# int f0/1
        R1(config-if)# ip address 192.168.1.1 255.255.255.0
        R1(config-if)# no shut
        R1(config-if)#
     j. Save the running configuration to the startup file.
        R1# copy running-config startup-config         (or) write mem
        Destination filename [startup-config]?
        Building configuration...
        [OK]
        R1#
Configure the Routers R2 and R3.
Static and Default Route in R1, R2 and R3.
Default Route in R1
R1(config)# ip route 0.0.0.0 0.0.0.0 192.168.2.2
Static Route in R2
R2(config)# ip route 192.168.1.0 255.255.255.0 192.168.2.1
R2(config)# ip route 192.168.4.0 255.255.255.0 192.168.3.2
Default Route in R3
R1(config)# ip route 0.0.0.0 0.0.0.0 192.168.3.1
Show routing table for R1, R2 and R3
R1#sh ip route
Gateway of last resort is 192.168.2.2 to network 0.0.0.0
C 192.168.1.0/24 is directly connected, FastEthernet0/1
C 192.168.2.0/24 is directly connected, FastEthernet0/0
S* 0.0.0.0/0 [1/0] via 192.168.2.2
R1#
R2#sh ip route
Gateway of last resort is not set
S   192.168.1.0/24   [1/0] via 192.168.2.1
C   192.168.2.0/24   is directly connected, FastEthernet0/0
C   192.168.3.0/24   is directly connected, FastEthernet0/1
S   192.168.4.0/24   [1/0] via 192.168.3.2
R2#
R3#sh ip route
Gateway of last resort is 192.168.3.1 to network 0.0.0.0
C 192.168.3.0/24 is directly connected, FastEthernet0/0
C 192.168.4.0/24 is directly connected, FastEthernet0/1
S* 0.0.0.0/0 [1/0] via 192.168.3.1
R3#
RIP configuration for R1,        R2 and R3
R1(config)#router rip
R1(config-router)#version        2
R1(config-router)#network        192.168.1.0
R1(config-router)#network        192.168.2.0
R2(config)#router rip
R2(config-router)#version 2
R2(config-router)#network 192.168.2.0
R2(config-router)#network 192.168.3.0
R3(config)#router rip
R3(config-router)#version 2
R3(config-router)#network 192.168.3.0
R3(config-router)#network 192.168.4.0
Show routing table for R1, R2 and R3
R1(config-router)#do sh ip route
Gateway of last resort is not set
C 192.168.1.0/24 is directly     connected, FastEthernet0/1
C 192.168.2.0/24 is directly     connected, FastEthernet0/0
R 192.168.3.0/24 [120/1] via     192.168.2.2, 00:00:05, FastEthernet0/0
R 192.168.4.0/24 [120/2] via     192.168.2.2, 00:00:05, FastEthernet0/0
R1(config-router)#
R2#sh ip route
Gateway of last resort is not set
R 192.168.1.0/24   [120/1] via   192.168.2.1, 00:00:20, FastEthernet0/0
C 192.168.2.0/24   is directly   connected, FastEthernet0/0
C 192.168.3.0/24   is directly   connected, FastEthernet0/1
R 192.168.4.0/24   [120/1] via   192.168.3.2, 00:00:06, FastEthernet0/1
R2#
R3#sh ip route
Gateway of last resort is not set
R 192.168.1.0/24   [120/2] via   192.168.3.1, 00:00:25, FastEthernet0/0
R 192.168.2.0/24   [120/1] via   192.168.3.1, 00:00:25, FastEthernet0/0
C 192.168.3.0/24   is directly   connected, FastEthernet0/0
C 192.168.4.0/24   is directly   connected, FastEthernet0/1
R3#