viernes, 2 de septiembre de 2011

Uso de Dynagen en redes Cisco (simulador)

Para poder implementar redes con dispositivos Cisco, como switches, routers y otros más, Cisco ha creado un simulador muy útil llamado Packet Tracer y con el podemos experimentar diferentes tipos de redes, entrar a simulación y reproducir el viaje de los paquetes paso a paso, de esta forma podemos conocer cómo se desplazan los PDU´s, usando el modelo OSI y el modelo TCP/IP.
Este simulador está limitado en la totalidad de los comandos que puede utilizar en los routers, en comparación de los routers reales, ya que no usa el IOS original del router, sino una simulación, más pequeño, con sus comandos más importantes.

A medida que han ido apareciendo nuevas versiones, se han incrementado su capacidad de simulación, pero no cubre toda la capacidad que lo hace el router real.

Para poder trabajar con routers Cisco con su IOS original y en un programa simulador, se puede utilizar un simulador en base a Dynagen

Dynagen es un programa para usar con el emulador de router de Cisco Dynamips. Utiliza un archivo de configuración de red, en donde se especifica los componentes de red y sus conexiones. Los routers tienen asociado su IOS, en el cual aparecerá la ruta y el nombre del IOS. A continuación  adjuntamos un ejemplo de archivo de configuración de la red, para que lo puedas usar, pasa este contenido a un block de notas y lo guardas con la extensión .net, por ejemplo: CS 2-3-4.net

##################################
#          Cisco CCNA4                                #
##################################
#   Academia.    Cibertec                           #
#   Instructor:       Carlos Quiroz G.             #
##################################

debug = 0
autostart = True
model = 2691
WIC0/0 = WIC-2T
WIC0/1 = WIC-2T
workingdir = C:\Users\Calo\Desktop\CCNA4
[localhost]
    workingdir = C:\Users\Calo\Desktop\CCNA4
    [[2691]]
        workingdir = C:\Users\Calo\Desktop\CCNA4
        image = C:\Users\Calo\Desktop\IOS\c2691-adventerprisek9-mz.124-25.bin

        ram = 128
        ghostios = True
        sparsemem = True

    [[ROUTER R1]]
        console = 2001
        S0/0 = R2 S0/0
        f0/1 = NIO_udp:30000:127.0.0.1:20000
                # PC1 conectada a un puerto de f0/1, es una PC virtual
        cnfg = none
        model = 2691
       idlepc = 0x60a4ce50

    [[router R2]]
        console = 2002
        S0/1 = R3 S0/1
        f0/1 =NIO_gen_eth:\Device\NPF_{4B78FAA1-F40D-4376-BFD0-5500E2534BCD}
                # PC2 conectada a un puerto de f0/1, es la PC real, para Windows 7 es una interfaz loopback

        cnfg = none
        model = 2691
       idlepc = 0x60a4ce50

    [[router R3]]
        console = 2003
        S0/0 = R1 S0/1
        f0/1 = NIO_udp:30002:127.0.0.1:20002
                # PC3 conectada a un puerto de f0/1, es una PC virtual
        cnfg = none
        model = 2691
       idlepc = 0x60a4ce50

Para poder usar este archivo de configuración de red, se debe adecuarlo de la siguiente manera:
A.- Debemos cambiar el directorio de trabajo: workindir, debes crear una carpeta en donde se van a guardar los archivos que va a generar el simulador, la ruta a esa carpeta debes pegarla en los tres workindir del archivo de configuración de red.
B.- Debemos tener el IOS del router y guardarlo en una carpeta, luego modificar la ruta hacia este IOS, por ejemplo: C:\Users\Calo\Desktop\IOS\c2691-adventerprisek9-mz.124-25.bin, recuerda que la ruta hacia el IOS depende de tu computadora.
El IOS lo tienes que conseguir de Internet, como el que tenemos en la descripción anterior. Para que que puedas conseguir el IOS usa google y busca: intitle:index.of ios parent directory bin.

C.- Note que el archivo tiene tres routers, llamados R1, R2 y R3, el nombre puede cambiar por ejemplo R3 puede ser cambiado por ISP. Además, cada router debe tener  un número de consola diferente, console = 2001 para el primero, 2002 para el segundo, así sucesivamente.

D.- Debe establecer como se conectan las interfaces de los routers, en el ejemplo vemos a R1 conectado a R2 a través de sus interfaces seriales, esto dependerá de la topología de la red (S0/0 = R2 S0/0). Con esta configuración en R1 hemos conectado R1 con R2, ya no es necesario volver a hacerlo en R2. Note además que los número de las interfaces son diferentes al esquema, por lo que debemos considerar que la interfaz serial S0/0/0 es reemplazada por la S0/0.


  Para la conexión de las PC´s, tenemos dos alternativas:

 - Se puede usar PC´s virtuales con el objeto de hacer  ping desde estas PC´s, (luego explicaremos su configuración y cuál es el software que se debe usar), para ello debemos agregar el siguiente comando:
      f0/1 = NIO_udp:30000:127.0.0.1:20000
En el ejemplo dado, indica que la interfaz F0/1 del router está conectada a la PC virtual PC1, ya que se está usando el número de puerto 30000 y 20000. Si se quiere usar otra PC virtual, por ejemplo la PC2, se debe usar el mismo comando, pero, cambiando los número de puertos a 30001 y 20001, para PC3 se debe usar 30002 y 20002, así sucesivamente.

- Se puede usar la PC real, pero para Windows 7, no se puede hacer con su tarjeta de red real Ethernet, sino, se debe agregar una interfaz loopback de Microsoft., de esta forma agregaremos el siguiente comando:
    f0/1 = NIO_gen_eth:\Device\NPF_{4B78FAA1-F40D-4376-BFD0-5500E2534BCD}

En tu computadora, es probable que no tengas agregado esta interfaz, por lo que debes hacerlo de la siguiente manera:

Para instalar un Loopback en Windows 7
**************************************************************************************************
1.  Van al inicio y en el buscador ponen cmd y le dan ENTER.
2.  Escriben "hdwwiz.exe" sin comillas
3. En agregar hardware ponen la opción "instalar el hardware seleccionado manualmente.... (avanzado)"
4.  Saldrá una lista, busquen "Adaptadores de Red" y siguiente.
5.  Elijan el fabricante "Microsoft" y en adaptador de red "Adaptador de bucle invertido de Microsoft" siguiente.
6.  A continuación se ve el proceso de instalación y ya tienen el loopback.
7.  Se debe reiniciar la PC
8.  Luego de reiniciado se ejecuta: Network Device list del grupo de programas: Dynagen
9.  Este programa genera:
   NIO_gen_eth:\Device\NPF_{4B78FAA1-F40D-4376-BFD0-5500E2534BCD}
   Y lo debemos reemplazar en el archivo de configuración de red.
**************************************************************************************************

El programa Dynagen puede ser bajado de http://dynagen.org/, es un software libre, deben bajar también el programa Winpcap. Van a encontrar al Dynagen para diversos sistemas operativos, bajan para windows y lo instalan. Cuando esté instalado podrán verlo como en la siguiente figura:

Debemos ejecutar primero “Dynamips Server”, lo que abre una ventana de comandos, como la siguiente:
Luego de haber realizado los cambios en el archivo de red, debemos guardarlo, recuerde que debe tener la extensión .net. Una vez guardado abrimos al archivo de red con el programa: dg-local, que aparece después de instalar Dynagen (click derecho y abrir con).

Se abre una ventana de comandos de Dynagen.exe, mostrando el prompt:

   =>                       Desde aquí puedo ingresar comandos
   => ?                     Con “?” me muestra los comando que acepta.

Escriba el siguiente comando para ver la lista de dispositivos.

   => list all                 Muestra la lista de routers

Puede abrir cada una las ventanas de configuración para el router R1 mediante el siguiente comando.
   => telnet R1

Puede abrir todos los routers con un solo comando:
=> console /all


Antes de continuar se recomienda determinar el IDLEPC, el cual es un valor importante para el buen funcionamiento de la PC, en el caso de que no se calcule este valor, el procesador estará trabajando al 100%, haciendo que el sistema se vuelva lento.
Solo una sola vez es necesario calcular el IDLEPC, después debemos agregar este mismo valor en los otros ejercicios que desarrollemos, este valor es válido para cada PC, si cambiamos de PC, debemos calcularlo nuevamente. Para realizar el cálculo se debe poner el símbolo “#” antes del comando idlepc, por ejemplo:
    #   idlepc = 0x60a4ce50
En el caso de que no lo desabilite con el símbolo #, me indicará que no ouede calcularlo por que ya tiene idlepc, por el contrario, si los desabilito, aparecerá en la ventana de Dynagen los mensajes "warning" de usencia de los idlepc.

Para calcular el idlepc, debemos primero ejecutar el Dynamips Server y luego abrir el archivo de configuración de red con # en todos los idlepc, luego debemos ejecutar telnet R1 y a continuación se determina el idlepc con el siguiente comando:

   => idlepc get R1                                       
Please wait while gathering statistics...
*  1: 0x604b8db4 [53]
   2: 0x60a52258 [76]
   3: 0x60a4b6f0 [62]
   4: 0x60a4b720 [78]
   5: 0x60a4b8f4 [78]
   6: 0x60a4b964 [77]
   7: 0x60a4cc9c [66]
   8: 0x60a4ce50 [61]
   9: 0x60a4ce84 [41]
* 10: 0x602471f0 [57]
Potentially better idlepc values marked with "*"
Enter the number of the idlepc value to apply [1-10] or ENTER for no change:

La computadora realiza los cálculos y entrega una lista de números, al menos uno de ellos debe estar marcado con un asterico (*), si ninguno tiene *, vuelva a ejecutar el comando. Elija uno de ellos que esté marcado con *, este número lo debe ingresar en el archivo de configuración de red y en todos los archivos .net que genere. Este cálculo se recomienda para un mejor uso del CPU en cada computadora.
Si antes tenía:   idlepc = 0x60a4ce50 ahora debe ser cambiado por: idlepc = 0x604b8db4 en el archivo de configuración de red.

Para terminar en la ventana Dynagen, ejecute:
  => exit

Una vez que se grabado el archivo de red, cierre todos los archivos y vuelva a abrirlos,

Primero: Dynamips Server

Segundo: Abrir el archivo de configuración de red con dg-local. Aparece la ventana de Dynagen

Tercero: Desde Dynagen ejecute: console /all, con ello se abrirán n ventanas si el archivo de red tiene n routers.

Cuarto: Configurar cada uno de los routers, en particular se recomienda que nombre a los routers para poder diferenciar las ventanas de telnet.

Para cada router el comando siguiente, permite cargar una configuración previa, para ello debe dar la ruta y el nombre del archivo:
    cnfg = C:\Users\CCNA\Desktop\ccna4\working\lab-2-5-1\R1.cfg

En el caso de que no se quiere cargar una configuración previa, use:
    cnfg = none

Luego de haber realizado la configuración de todos los routers, salve las configuraciones con el comando copy o con wr, podrá luego volverlos abrir en otro mamento y continuar con la configuración o simplemente revisarla, toda la información estará en la carpeta de trabajo llamada workindir.

Se puede exportar los archivos de configuración de cada router, para ello use el siguiente comando:

   => export /all "C:\Calo\Escritorio\CCNA4\entrega\ccna4\working"
La dirección de la carpeta donde deben guardarse los archivos de configuración debe estar entre comillas. El resultado se muestra a continuación:

The directory C:\Calo\Escritorio\CCNA4\entrega\ccna4\working already exists. Ok to overwrite (Y/N)? y
Exporting R1 to C:\Calo\Escritorio\CCNA4\entrega\ccna4\working\R1.cfg
Exporting R2 to C:\Calo\Escritorio\CCNA4\entrega\ccna4\working\R2.cfg
Exporting R3 to C:\Calo\Escritorio\CCNA4\entrega\ccna4\working\R3.cfg

Para importar estos archivos a los routers lo logramos con el siguiente comando:

import /all "C:\Calo\Escritorio\CCNA4\entrega\ccna4\working"

Esto permite cargar una configuración de los routers, para ello, luego de ejecutar el import, debe cerrar todos los archivos y luego los abrimos, ejecutando primero Dynamips server, en este segundo intento veremos que se cargan las configuraciones en cada uno de los routers.

 Para las PC´s virtuales, lo puedes bajar de Internet, usa Google y busca: vpcs-0.16c PC virtual
Descomprimes el archivo y guardas la carpeta de las PC´s vituales, como aparece en la anterior figura, debes luego configurar las IP, de la siguiente manera:

# The startup file of VPC
###########################################

############################################
# pc1, pc2, pc3, pc4, pc5: ipv4
1
ip   192.168.10.10       192.168.10.1   24
2
ip   192.168.30.10       192.168.30.1    24
3
ip   192.168.30.10       192.168.30.1    24
4
ip   192.168.30.128     192.168.30.1     24
5
ip   209.165.202.158   209.165.202.129 27
6
ip   209.165.201.30     209.165.201.1     27
############################################
# En dynagen agregar:
#   f1/2 = NIO_udp:30000:127.0.0.1:20000
#   para PC1
#   f1/2 = NIO_udp:30001:127.0.0.1:20001
#   para PC2

En esta configuración se ha configurado desde la PC1 a la PC6, con la IP, puerta de enlace y prefijo de la máscara de red. Luego se debe ejecutar el archivo vpcs y aparecerá la siguiente ventana:

Para hacer ping desde la PC1, debemos escribir 1 y le damos enter, de igual forma se debe hacer para usar las otras PC´s.