Changes between Version 4 and Version 5 of GEC22Agenda/LabWiki/ModuleA
- Timestamp:
- 03/09/15 14:40:24 (10 years ago)
Legend:
- Unmodified
- Added
- Removed
- Modified
-
GEC22Agenda/LabWiki/ModuleA
v4 v5 1 1 = Module A: Run your first experiment = 2 In this first module of the tutorial you will quickly learn how to execute an experimenton a GENI testbed by using !LabWiki.2 In this first module of the tutorial you will quickly learn how to design and execute a Lab exercise on a GENI testbed by using !LabWiki. 3 3 4 4 == Introduction == 5 The goal of this assignment is to implement the learning switch capability that is used by Ethernet switches by using a software-based OpenFlow switch. In the topology shown in the figure, this software switch is to be implemented in node “switch”. All the other nodes represent regular hosts. To realize this implementation of a learning switch, trema based openflow controller written in Ruby has to be designed and implemented. The correct functionality of the learning switch can be verified by creating an experiment script in which anynode A pings nodes B – node D in LabWiki.5 The goal of this assignment is to implement the learning switch capability that is used by Ethernet switches by using a software-based OpenFlow switch. In the topology shown in the figure, this software switch is to be implemented in node “switch”. All the other nodes represent regular hosts. To realize this implementation of a learning switch, Trema based Openflow controller written in Ruby has to be designed and implemented. The correct functionality of the learning switch can be verified by creating an experiment script in which a node A pings nodes B – node D in LabWiki. 6 6 7 7 == Working == 8 In the topology shown in the figure, the switch node will act as the learning switch, which connect nodes A-D with each other. Whenever a regular node pings any regular nodefor the first time, the switch does not know the destination address of the node. At this point, the switch node floods the packet to all the nodes it is connected to. When it receives a reply to the flood, this information will be used to populate its switching table. Hereafter,whenever any node wants to ping any other nodes, the switch node will fetch the information from the table. For this purpose, a script called "fdb.rb" is pre-loaded in the switch node. The script offers rudimentary database functionality that is used to maintain the switching table8 In the topology shown in the figure, the switch node will act as the learning switch, which connect nodes A-D with each other. Whenever any of these nodes ping each other for the first time, the switch does not know the destination address of the node. At this point, the switch node floods the packet to all the nodes it is connected to. When it receives a reply to the flood, this information will be used to populate its switching table. Hereafter,whenever any node wants to ping any other nodes, the switch node will fetch the information from the table. For this purpose, a script called "fdb.rb" is pre-loaded in the switch node. The script offers rudimentary database functionality that is used to maintain the switching table 9 9 10 10 To learn about learning-switch, check out this link: [https://www.opennetworking.org/images/stories/downloads/sdn-resources/white-papers/wp-sdn-newnorm.pdf] 11 11 12 To learn about the trema controller, check out this link:[http://trema.github.io/trema/]12 To learn about the Trema controller, check out this link:[http://trema.github.io/trema/] 13 13 14 14 [[Image(http://groups.geni.net/geni/raw-attachment/wiki/GEC20Agenda/LabWiki/ModuleA/GEC20_simple_topo.png, 40%)]]