Tuesday, December 2, 2014

CCNP Update : BGP

Here are my notes on BGP. It's a work in progress.

BGP on OneNote

You can access the OneNote notebook for the blog from the tab next to Home button at the top.

Monday, November 10, 2014

CCNP Update: EIGRP

Here's my first CCNP update.

I've completed EIGRP and you can find my notes for it attached to the post.

I'd be happy to answer any questions you might have because that helps me learn as well. Also, if anyone finds any mistakes, do let me know!

EIGRP on OneNote
I prefer that you look at these since you can see the pictures more clearly and content is just better formatted.

EIGRP notes PDF
Convenient if you want to download them for viewing later.

My next CCNP update will be on BGP.

Tuesday, November 4, 2014

Cisco Router Boot Sequence

Router Boot Sequence is something I studied for my CCNA exam back in August, but I've forgotten the details of the process with time. I had a discussion with my supervisor today about what exactly is the startup process of a computer and it made me realize that I need to brush up on the topic. So I consulted the Todd Lammle book that I used for my CCNA. Here is the summary of the default boot sequence:
  1. Power-on self-test checks the hardware to verify if all components of the device are operational and if necessary components are present. Stored in and run from ROM.
  2. Bootstrap, located in ROM, then looks for Cisco IOS. It checks in this particular order- the Flash memory, TFTP Server and the ROM. The operating system, once found, is loaded in the RAM.
  3. Next step is to find the startup-config file. It's in NVRAM by default. If found, it is copied over to the RAM and loaded there. The router is ready to be used at this point. But in case that the router is missing startup-config file, it is searched for at a TFTP server. If that fails too, the router starts in the setup mode (which I've personally never bothered to look at by the way. I just skip it).

Default Router Boot Sequence


So there you have it, the default boot sequence of Cisco routers. My next post will be on EIGRP.

Sunday, November 2, 2014

Mininet Basics

If you are getting started with SDN, Mininet is an amazing tool with which you can create and test a realistic virtual network.

In this post, I will cover the following topics-
  • Mininet VM Setup
  • Monitoring Traffic in Wireshark
  • OpenFlow Messages

Mininet VM Setup

You need to follow these steps to get your Mininet VM up and running.
  1. Download and install VirtualBox (https://www.virtualbox.org/wiki/Downloads) and Mininet VM image (https://github.com/mininet/mininet/wiki/Mininet-VM-Images). Extract the Mininet VM and open it using VirtualBox.
  2. Before running the VM, go to Settings of the VM in VirtualBox and set Adapter-2 as Host-Only Adapter.
  3. Start your VM. You can log in using PuTTY. Default log in credentials are mininet/mininet.
  4. If you are on Windows, you need Xming X Server for Windows (http://sourceforge.net/projects/xming/files/latest/download?source=files) to run Wireshark (built in the Mininet VM) or access the hosts/switches.


Creating a simple topology

Once you are in the Mininet VM, you can use ifconfig to figure out the IP address of your VM. Once you have it, run PuTTY and connect to the VM using that IP address.


Now that you are in the Mininet VM, run sudo mn . This will start a simple topology, as shown below. In case you are wondering, 'sudo' stands for 'substitute user do' (and in this case makes you execute commands with root privileges) and 'mn' stands for mininet.




Now that you have a topology running, next is to look at various packets flowing between the controller and the switch.


Packet Capture

To do this, start another PuTTY session to your VM. This time, make sure that you enable X11 forwarding under Connection/SSH/X11, as shown. Connect to your VM as before.

Enabling X11 forwarding

















After you are in, run sudo wireshark &. This will open Wireshark built in the Mininet VM. Ignore any warnings. Start the packet capture on Loopback (lo) interface. Use filter of to filter through the clutter. This will show you OpenFlow messages.

Wireshark capture of OpenFlow messages

This brings us to the messages you'll see in OpenFlow.
  • Hello - Sent from Switch to Controller when switch boots up. Controller replies back to Hellos from switches.
  • Features Request/Reply - The controller sends this message to every switch it is connected to in order to figure out switches capabilities.
  • Echo Request/Reply - It's an ongoing message between controller-switch to make sure connection is up. These messages are sent every 5 seconds. You can see this one above. Switch sends the Request and the Controller sends Reply back.
  • Packet_IN - Sent from Switch to Controller when it sees a 'new' packet (usually the first packet of a flow). 
  • Packet_OUT - Sent from the Controller as a reply to Packet_IN message. It has the 'action' (forward to port 5, drop, discard etc) that will be taken for that packet. This type of message is usually sent for broadcast messages.
  • Flow_Mod - This type of packet is also sent in reply to Packet_IN message. It goes one step further and installs a flow entry in the switch. This one is usually sent for unicast messages.
In Mininet, you'll notice either Packet_OUT or Flow_Mod in reply to Packet_IN messages. This is by design of OpenFlow 1.0, which we are using here.

I encourage you to look at packet capture from wireshark. It's not fun, but it's really informative. 

To exit mininet, use exit. Use sudo mn --clean after you are done.

You can read more about Mininet and OpenFlow by visiting these links-
  1. Mininet Walkthrough (http://mininet.org/walkthrough/)
  2. OpenFlow Tutorial (http://archive.openflow.org/wk/index.php/OpenFlow_Tutorial)
Let me know if there is anything specific on Mininet that you want me to cover. Between school and work, I will try to find time for at least one or two posts every week (at least that's what I'm telling myself.)

Until next time.