Skip to content

pfondo/sdn-bundle-simulator

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

39 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

sdn-bundle-simulator

Build Status

Description

This is a simulator of a bundle of Energy-Efficient Ethernet (EEE) links between two switches. It simulates a Software-Defined Networking (SDN) application which periodically queries the flows installed in the first switch and performs a new allocation of the flows to the ports of the bundle, that will be used during the next interval.

The simulator has been designed following the Open Network Operating System (ONOS) syntax in order to ease the migration of the algorithms to an operative ONOS application.

Flows are defined as a bitmask on the destination IP address.

Features

  • Modify the speed of the trace being evaluated.
  • Calculate the average binary rate of the trace.
  • Calculate the average delay of the packets.
  • Calculate the average energy consumption of the device.
  • Calculate the number of flow modifications performed by the algorithm.
  • Calculate the packet loss.

Compilation

mvn clean package

Execution

usage: sdn-bundle-simulator [-a <ALGORITHM>] [-e <BIT>] [-f <TIMEOUT>]
       [-h] -i <INPUT> [-lla <ALGORITHM>] [-n <PORTS>] [-p <PERIOD>] [-q
       <SIZE>] [-s <BIT>] [-x <SPEED>]
 -a,--algorithm <ALGORITHM>               Specifies the algorithm.
                                          Available algorithms: 0, 11, 1,
                                          2, 3, 4, 5, 6, 7, 8, 9, 10
                                          [default: 3].
 -e,--endBitDstIp <BIT>                   Specifies the last bit of the
                                          destination IP address that will
                                          be used to define the flows
                                          [default: 8].
 -f,--flowRuleTimeout <TIMEOUT>           Specifies flow rule timeout
                                          (seconds) [default: 30].
 -h,--help                                Shows this help menu.
 -i,--input <INPUT>                       Specifies the input file.
 -lla,--lowLatencyAlgorithm <ALGORITHM>   Specifies the low-latency
                                          algorithm. Available algorithms:
                                          0, 1, 2 [default: 0]. Note that
                                          this is compatible with the
                                          "algorithm" option.
 -n,--numPorts <PORTS>                    Specifies the number of ports.
                                          [default: 5].
 -p,--period <PERIOD>                     Specifies flow sampling period
                                          (seconds) [default: 0.5].
 -q,--queueSize <SIZE>                    Specifies the size of the queue
                                          of each port (seconds) [default:
                                          0.01].
 -s,--startBitDstIp <BIT>                 Specifies the first bit of the
                                          destination IP address that will
                                          be used to define the flows
                                          [default: 0].
 -x,--speed <SPEED>                       Specifies the relative speed of
                                          the trace [default: 1].

Input trace format

Each packet will be represented in a single line with the following format:

<Timestamp (seconds)> <Source IP> <Destination IP> <Length (bytes)>

Besides, comment lines are allowed, starting the line with the '#' character. An example is shown to illustrate the format:

# <Timestamp (seconds)> <Source IP> <Destination IP> <Length (bytes)>
0.000000 192.168.0.1 192.168.0.2 1500
0.100000 192.168.0.1 192.168.0.2 1000
1.200000 192.168.0.3 192.168.0.4 500

Results

  • The final results of the simulation are written to standard output.
  • The standard error output is also used to inform of the parameters of the running simulation, and also its status.
  • A "results" folder is created to store the detailed results of the simulation.
  • Setting the PRINT_PACKETS=true in the auxiliar.Queue: A "packets" folder is created to store the packets transmitted by each port during this simulation.

Adding an algorithm

Adding a new algorithm to the simulator is simple. These are the main steps that should be followed:

  1. Create your own class, say AlgorithmX, extending the algorithm.BaseAlgorithm abstract class. There are several examples in the algorithm package (e.g., algorithm.Algorithm0).
  2. Implement the Map<FlowEntry, PortNumber> computeAllocation(Map<FlowEntry, Long> flowMap, Set<PortNumber> linkPorts) method in AlgorithmX using your own flow allocation logic.
  3. If you wish, you can also find interesting implementing the following methods in AlgorithmX overriding the default implementation: double getPortBytesAvailable(long numFlows), PortNumber selectOutputPort(DeviceId src, DeviceId dst). Besides, to create a new policy to manage low-latency packets, you can extend algorithm.LowLatencyBaseAlgorithm and implement the needed methods.
  4. If you wish, you can also modify how the expected number of bytes that each flow will transmit in the next interval is calculated, modifying the algorithm.FlowBytesHistory class.
  5. In the Map<String, Class<? extends BaseAlgorithm>> getAlgorithmsAvailable() method of the conf.Configuration class, add a line to include your algorithm among the algorithms available (e.g., algorithmsAvailable.put("X", AlgorithmX.class);).
  6. Then you can run the simulator using the --algorithm X argument.

Copyright

Copyright ⓒ 2017–2018 Pablo Fondo Ferreiro pfondo@det.uvigo.es.

This simulator is licensed under the GNU General Public License, version 3 (GPL-3.0). For more information see LICENSE.txt

Releases

No releases published

Packages

No packages published

Languages