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.
- 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.
mvn clean package
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].
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
- 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 theauxiliar.Queue
: A "packets" folder is created to store the packets transmitted by each port during this simulation.
Adding a new algorithm to the simulator is simple. These are the main steps that should be followed:
- Create your own class, say
AlgorithmX
, extending thealgorithm.BaseAlgorithm
abstract class. There are several examples in the algorithm package (e.g.,algorithm.Algorithm0
). - Implement the
Map<FlowEntry, PortNumber> computeAllocation(Map<FlowEntry, Long> flowMap, Set<PortNumber> linkPorts)
method inAlgorithmX
using your own flow allocation logic. - 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 extendalgorithm.LowLatencyBaseAlgorithm
and implement the needed methods. - 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. - In the
Map<String, Class<? extends BaseAlgorithm>> getAlgorithmsAvailable()
method of theconf.Configuration
class, add a line to include your algorithm among the algorithms available (e.g.,algorithmsAvailable.put("X", AlgorithmX.class);
). - Then you can run the simulator using the
--algorithm X
argument.
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