blob: e7b713a77e82a0ba084d53c2cebfe8b01fa614b0 [file] [log] [blame]
Vince Lehmanb8b18062015-07-14 13:07:22 -05001# -*- Mode:python; c-file-style:"gnu"; indent-tabs-mode:nil -*- */
2#
3# Copyright (C) 2015 The University of Memphis,
4# Arizona Board of Regents,
5# Regents of the University of California.
6#
7# This file is part of Mini-NDN.
8# See AUTHORS.md for a complete list of Mini-NDN authors and contributors.
9#
10# Mini-NDN is free software: you can redistribute it and/or modify
11# it under the terms of the GNU General Public License as published by
12# the Free Software Foundation, either version 3 of the License, or
13# (at your option) any later version.
14#
15# Mini-NDN is distributed in the hope that it will be useful,
16# but WITHOUT ANY WARRANTY; without even the implied warranty of
17# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18# GNU General Public License for more details.
19#
20# You should have received a copy of the GNU General Public License
21# along with Mini-NDN, e.g., in COPYING.md file.
22# If not, see <http://www.gnu.org/licenses/>.
ashu34c3ee02015-03-25 14:41:14 -050023
24import time
25import sys
Ashlesh Gawanded9c9e522015-10-15 16:40:12 -050026from itertools import cycle
ashu34c3ee02015-03-25 14:41:14 -050027
Vince Lehman3b8bc652015-06-18 15:01:47 -050028from ndn import ExperimentManager
29
ashu34c3ee02015-03-25 14:41:14 -050030class Experiment:
31
Vince Lehman3b8bc652015-06-18 15:01:47 -050032 def __init__(self, args):
33 self.net = args["net"]
34 self.nodes = args["nodes"]
35 self.convergenceTime = args["ctime"]
36 self.nPings = args["nPings"]
37 self.strategy = args["strategy"]
Ashlesh Gawanded9c9e522015-10-15 16:40:12 -050038 self.pctTraffic = float(args["pctTraffic"])
39
40 # Used to restart pings on the recovered node if any
41 self.pingedDict = {}
42
ashu34c3ee02015-03-25 14:41:14 -050043
44 def start(self):
45 self.setup()
46 self.run()
47
48 def setup(self):
49 for host in self.net.hosts:
50 # Set strategy
51 host.nfd.setStrategy("/ndn/edu", self.strategy)
52
53 # Start ping server
54 host.cmd("ndnpingserver /ndn/edu/" + str(host) + " > ping-server &")
55
56 # Create folder to store ping data
57 host.cmd("mkdir ping-data")
58
59 # Wait for convergence time period
60 print "Waiting " + str(self.convergenceTime) + " seconds for convergence..."
61 time.sleep(self.convergenceTime)
62 print "...done"
63
64 # To check whether all the nodes of NLSR have converged
65 didNlsrConverge = True
66
67 # Checking for convergence
68 for host in self.net.hosts:
69 statusRouter = host.cmd("nfd-status -b | grep /ndn/edu/%C1.Router/cs/")
70 statusPrefix = host.cmd("nfd-status -b | grep /ndn/edu/")
71 didNodeConverge = True
72 for node in self.nodes.split(","):
73 if ("/ndn/edu/%C1.Router/cs/" + node) not in statusRouter:
74 didNodeConverge = False
75 didNlsrConverge = False
76 if str(host) != node and ("/ndn/edu/" + node) not in statusPrefix:
77 didNodeConverge = False
78 didNlsrConverge = False
79
80 host.cmd("echo " + str(didNodeConverge) + " > convergence-result &")
81
82 if didNlsrConverge:
83 print("NLSR has successfully converged.")
84 else:
85 print("NLSR has not converged. Exiting...")
Ashlesh Gawande3807c1b2016-08-05 16:27:02 -050086 self.net.stop()
ashu34c3ee02015-03-25 14:41:14 -050087 sys.exit(1)
88
Vince Lehmancb20c542015-05-12 14:04:47 -050089 def ping(self, source, dest, nPings):
90 # Use "&" to run in background and perform parallel pings
91 print "Scheduling ping(s) from %s to %s" % (source.name, dest.name)
92 source.cmd("ndnping -t -c "+ str(nPings) + " /ndn/edu/" + dest.name + " >> ping-data/" + dest.name + ".txt &")
93 time.sleep(0.2)
94
ashu34c3ee02015-03-25 14:41:14 -050095 def startPings(self):
96 for host in self.net.hosts:
97 for other in self.net.hosts:
98 # Do not ping self
99 if host.name != other.name:
Vince Lehmancb20c542015-05-12 14:04:47 -0500100 self.ping(host, other, self.nPings)
ashu34c3ee02015-03-25 14:41:14 -0500101
Vince Lehmand96eed32015-10-22 13:57:27 -0500102 def failNode(self, host):
103 print("Bringing %s down" % host.name)
104 host.nfd.stop()
105
106 def recoverNode(self, host):
107 print("Bringing %s up" % host.name)
108 host.nfd.start()
109 host.nlsr.start()
110 host.nfd.setStrategy("/ndn/edu", self.strategy)
111 host.cmd("ndnpingserver /ndn/edu/" + str(host) + " > ping-server &")
112
Ashlesh Gawanded9c9e522015-10-15 16:40:12 -0500113 def startPctPings(self):
114 nNodesToPing = int(round(len(self.net.hosts)*self.pctTraffic))
115 print "Each node will ping %d node(s)" % nNodesToPing
116 # Temporarily store all the nodes being pinged by a particular node
117 nodesPingedList = []
118
119 for host in self.net.hosts:
120 # Create a circular list
121 pool = cycle(self.net.hosts)
122
123 # Move iterator to current node
124 next(x for x in pool if host.name == x.name)
125
126 # Track number of nodes to ping scheduled for this node
127 nNodesScheduled = 0
128
129 while nNodesScheduled < nNodesToPing:
130 other = pool.next()
131
132 # Do not ping self
133 if host.name != other.name:
134 self.ping(host, other, self.nPings)
135 nodesPingedList.append(other)
136
137 # Always increment because in 100% case a node should not ping itself
138 nNodesScheduled = nNodesScheduled + 1
139
140 self.pingedDict[host] = nodesPingedList
141 nodesPingedList = []
142
Vince Lehman3b8bc652015-06-18 15:01:47 -0500143 @staticmethod
144 def register(name, experimentClass):
145 ExperimentManager.register(name, experimentClass)
146