diff options
-rwxr-xr-x | examples/example.py | 6 | ||||
-rwxr-xr-x | examples/two-layers.py | 6 | ||||
-rw-r--r-- | rumba/model.py | 21 | ||||
-rw-r--r-- | rumba/prototypes/irati.py | 46 | ||||
-rw-r--r-- | rumba/prototypes/ouroboros.py | 17 | ||||
-rw-r--r-- | rumba/prototypes/rlite.py | 43 | ||||
-rwxr-xr-x | tools/democonf2rumba.py | 7 |
7 files changed, 90 insertions, 56 deletions
diff --git a/examples/example.py b/examples/example.py index 54ecd37..8d91102 100755 --- a/examples/example.py +++ b/examples/example.py @@ -40,4 +40,8 @@ exp = rl.Experiment(tb, nodes = [a, b]) print(exp) -exp.run() +try: + exp.swap_in() + exp.bootstrap_prototype() +finally: + exp.swap_out() diff --git a/examples/two-layers.py b/examples/two-layers.py index 9032588..fff3866 100755 --- a/examples/two-layers.py +++ b/examples/two-layers.py @@ -52,4 +52,8 @@ exp = rl.Experiment(tb, nodes = [a, b, c, d]) print(exp) -exp.run() +try: + exp.swap_in() + exp.bootstrap_prototype() +finally: + exp.swap_out() diff --git a/rumba/model.py b/rumba/model.py index 4c3985d..1fa007c 100644 --- a/rumba/model.py +++ b/rumba/model.py @@ -532,16 +532,17 @@ class Experiment: self.compute_ipcps() @abc.abstractmethod - def run_prototype(self): + def install_prototype(self): raise Exception('run_prototype() method not implemented') - def run(self): - try: - # Realize the experiment testbed (testbed-specific) - self.testbed.swap_in(self) + @abc.abstractmethod + def bootstrap_prototype(self): + raise Exception('run_prototype() method not implemented') + + def swap_in(self): + # Realize the experiment testbed (testbed-specific) + self.testbed.swap_in(self) - # Run the experiment using the prototype (prototype-specific) - self.run_prototype() - finally: - # No matter what happens, undo the testbed (testbed-specific) - self.testbed.swap_out(self) + def swap_out(self): + # Undo the testbed (testbed-specific) + self.testbed.swap_out(self) diff --git a/rumba/prototypes/irati.py b/rumba/prototypes/irati.py index fe9b052..5f6ec52 100644 --- a/rumba/prototypes/irati.py +++ b/rumba/prototypes/irati.py @@ -66,23 +66,26 @@ class Experiment(mod.Experiment): def conf_dir(self, path): return os.path.join(self._conf_dir, path) + def install(self): + """Installs IRATI on the nodes.""" + cmds = list() + + cmds.append("sudo apt-get update") + cmds.append("sudo apt-get install g++ gcc " + "protobuf-compiler libprotobuf-dev git --yes") + cmds.append("sudo rm -rf ~/irati") + cmds.append("cd && git clone https://github.com/IRATI/stack irati") + cmds.append("cd ~/irati && sudo ./install-from-scratch") + + for node in self.nodes: + ssh.execute_commands(self.testbed, node.ssh_config, + cmds, time_out=None) + def setup(self): - """Installs IRATI on the vms.""" - setup_irati = False - if setup_irati: - cmds = list() - - cmds.append("sudo apt-get update") - cmds.append("sudo apt-get install g++ gcc " - "protobuf-compiler libprotobuf-dev git --yes") - cmds.append("sudo rm -rf ~/irati") - cmds.append("cd && git clone https://github.com/IRATI/stack irati") - cmds.append("cd ~/irati && sudo ./install-from-scratch") - cmds.append("sudo nohup ipcm &> ipcm.log &") - - for node in self.nodes: - ssh.execute_commands(self.testbed, node.ssh_config, - cmds, time_out=None) + for node in self.nodes: + ssh.execute_command(self.testbed, node.ssh_config, + "sudo nohup ipcm &> ipcm.log &", + time_out=None) def bootstrap_network(self): """Creates the network by enrolling and configuring the nodes""" @@ -90,7 +93,12 @@ class Experiment(mod.Experiment): self.process_node(node) self.enroll_nodes() - def run_prototype(self): + def install_prototype(self): + logger.info("irati: installing") + self.install() + logger.info("irati: done installing") + + def bootstrap_prototype(self): logger.info("irati: setting up") self.setup() logger.info("irati: software initialized on all nodes") @@ -103,8 +111,8 @@ class Experiment(mod.Experiment): """ Installs the configuration and boots up rina on a node :type node: mod.Node - :param node: - :return: + :param node: + :return: """ name = node.name diff --git a/rumba/prototypes/ouroboros.py b/rumba/prototypes/ouroboros.py index 9776c5e..bbf8c75 100644 --- a/rumba/prototypes/ouroboros.py +++ b/rumba/prototypes/ouroboros.py @@ -33,18 +33,22 @@ class Experiment(mod.Experiment): mod.Experiment.__init__(self, testbed, nodes) def setup_ouroboros(self): + for node in self.nodes: + ssh.execute_command(self.testbed, node.ssh_config, + "sudo nohup irmd > /dev/null &", + time_out=None) + + def install_ouroboros(self): cmds = list() cmds.append("sudo apt-get update") cmds.append("sudo apt-get install cmake protobuf-c-compiler git --yes") cmds.append("sudo rm -r ~/ouroboros/build") cmds.append("cd ~/ouroboros; sudo ./install_debug.sh /") - cmds.append("sudo nohup irmd > /dev/null &") for node in self.nodes: ssh.execute_commands(self.testbed, node.ssh_config, cmds, time_out=None) - return def bind_names(self): for node in self.nodes: @@ -136,8 +140,13 @@ class Experiment(mod.Experiment): cmds, time_out=None) time.sleep(2) - def run_prototype(self): - logger.info("Setting up Ouroboros...") + def install_prototype(self): + logger.info("Installing Ouroboros...") + self.install_ouroboros() + logger.info("Installed on all nodes...") + + def bootstrap_prototype(self): + logger.info("Starting IRMd on all nodes...") self.setup_ouroboros() logger.info("Binding names...") self.bind_names() diff --git a/rumba/prototypes/rlite.py b/rumba/prototypes/rlite.py index feca5a4..77f59cb 100644 --- a/rumba/prototypes/rlite.py +++ b/rumba/prototypes/rlite.py @@ -36,28 +36,17 @@ class Experiment(mod.Experiment): ssh.execute_commands(self.testbed, node.ssh_config, cmds, time_out=None) - def init(self): - cmds = [] - - if False: # ubuntu - cmds.append("apt-get update") - cmds.append("apt-get install g++ gcc cmake " - "linux-headers-$(uname -r) " - "protobuf-compiler libprotobuf-dev git --yes") - cmds.append("rm -rf ~/rlite") - cmds.append("cd ~; git clone https://github.com/vmaffione/rlite") - cmds.append("cd ~/rlite && ./configure && make " - "&& sudo make install") + def init_nodes(self): + cmds = ["modprobe rlite", + "modprobe rlite-normal", + "modprobe rlite-shim-eth", + "modprobe rlite-shim-udp4", + "modprobe rlite-shim-loopback", + "rlite-uipcps -v DBG -k 0 &> uipcp.log &"] # Load kernel modules - cmds.append("modprobe rlite") - cmds.append("modprobe rlite-normal") - cmds.append("modprobe rlite-shim-eth") - cmds.append("modprobe rlite-shim-udp4") - cmds.append("modprobe rlite-shim-loopback") # Start the uipcps daemon - cmds.append("rlite-uipcps -v DBG -k 0 &> uipcp.log &") for node in self.nodes: self.execute_commands(node, cmds) @@ -115,9 +104,23 @@ class Experiment(mod.Experiment): "%(lower_dif)s %(enroller)s" % d self.execute_commands(e['enrollee'], [cmd]) - def run_prototype(self): + def install_prototype(self): + logger.info("rlite: installing") + cmds = ["apt-get update", + "apt-get install g++ gcc cmake " + "linux-headers-$(uname -r) " + "protobuf-compiler libprotobuf-dev git --yes", + "rm -rf ~/rlite", + "cd ~; git clone https://github.com/vmaffione/rlite", + "cd ~/rlite && ./configure && make && sudo make install"] + + for node in self.nodes: + self.execute_commands(node, cmds) + logger.info("rlite: installed") + + def bootstrap_prototype(self): logger.info("rlite: setting up") - self.init() + self.init_nodes() logger.info("rlite: software initialized on all nodes") self.create_ipcps() logger.info("rlite: IPCPs created on all nodes") diff --git a/tools/democonf2rumba.py b/tools/democonf2rumba.py index c708e8e..9d909c7 100755 --- a/tools/democonf2rumba.py +++ b/tools/democonf2rumba.py @@ -123,7 +123,12 @@ def make_experiment(filename, experiment_class, experiment_kwargs, experiment_kwargs['testbed'] = testbed experiment_kwargs['nodes'] = parsed_nodes - return experiment_class(**experiment_kwargs).run() + exp = experiment_class(**experiment_kwargs) + try: + exp.swap_in() + exp.bootstrap_prototype() + finally: + exp.swap_out() def setup_testbed_common_args(t_p): |