def wait_for_maas(self): """ install and configure maas """ random_status = ["Packages are being installed to a MAAS container.", "There's a few packages, it'll take just a minute", "Checkout http://maas.ubuntu.com/ while you wait."] is_connected = False count = 0 while not is_connected: self.ui.render_node_install_wait(message="Waiting...") self.ui.status_info_message( random_status[random.randrange(len(random_status))]) count = count + 1 self.ui.status_info_message( "Waiting for MAAS (tries {0})".format(count)) uri = path.join('http://', utils.container_ip('maas'), 'MAAS') log.debug("Checking MAAS availability ({0})".format(uri)) try: res = requests.get(uri) is_connected = res.ok except: self.ui.status_info_message("Waiting for MAAS to be installed") time.sleep(10) # Render nodeview, even though nothing is there yet. self.initialize()
def add_static_route(self, lxc_net): """ Adds static route to host system """ # Store container IP in config ip = utils.container_ip(self.container_name) self.config.setopt('container_ip', ip) log.info("Adding static route for {} via {}".format(lxc_net, ip)) out = utils.get_command_output( 'ip route add {} via {} dev lxcbr0'.format(lxc_net, ip)) if out['status'] != 0: raise Exception("Could not add static route for {}" " network: {}".format(lxc_net, out['output']))
def do_install(self): self.display_controller.status_info_message("Building environment") if os.path.exists(self.container_abspath): raise Exception("Container exists, please uninstall or kill " "existing cloud before proceeding.") # check for deb early, will actually install it later upstream_deb = self.config.getopt('upstream_deb') if upstream_deb and not os.path.isfile(upstream_deb): raise Exception("Upstream deb '{}' " "not found.".format(upstream_deb)) utils.ssh_genkey() self.prep_userdata() utils.render_charm_config(self.config) self.prep_juju() self.set_perms() self.create_container_and_wait() # Copy over host ssh keys utils.container_cp(self.container_name, os.path.join(utils.install_home(), '.ssh/id_rsa*'), '.ssh/.') # Install local copy of openstack installer if provided if upstream_deb: shutil.copy(upstream_deb, self.config.cfg_path) self._install_upstream_deb() # Stop before we attempt to access container if self.config.getopt('install_only'): log.info("Done installing, stopping here per --install-only.") self.config.setopt('install_only', True) self.loop.exit(0) # Update jujus no-proxy setting if applicable if self.config.getopt('http_proxy') or \ self.config.getopt('https_proxy'): log.info("Updating juju environments for proxy support") lxc_net = self.config.getopt('lxc_network') self.config.update_environments_yaml( key='no-proxy', val='{},localhost,{}'.format( utils.container_ip(self.container_name), netutils.get_ip_set(lxc_net))) # start the party cloud_status_bin = ['openstack-status'] self.tasker.start_task("Bootstrapping Juju") utils.container_run(self.container_name, "{0} juju bootstrap".format( self.config.juju_home(use_expansion=True)), use_ssh=True) utils.container_run( self.container_name, "{0} juju status".format( self.config.juju_home(use_expansion=True)), use_ssh=True) self.tasker.stop_current_task() self.display_controller.status_info_message( "Starting cloud deployment") utils.container_run_status( self.container_name, " ".join(cloud_status_bin), self.config)
def do_install(self): self.display_controller.status_info_message("Building environment") if os.path.exists(self.container_abspath): raise Exception("Container exists, please uninstall or kill " "existing cloud before proceeding.") # check for deb early, will actually install it later upstream_deb = self.config.getopt('upstream_deb') if upstream_deb and not os.path.isfile(upstream_deb): raise Exception("Upstream deb '{}' " "not found.".format(upstream_deb)) utils.ssh_genkey() self.prep_userdata() utils.render_charm_config(self.config) self.prep_juju() self.set_perms() self.create_container_and_wait() # Copy over host ssh keys utils.container_cp(self.container_name, os.path.join(utils.install_home(), '.ssh/id_rsa*'), '.ssh/.') # Install local copy of openstack installer if provided if upstream_deb: shutil.copy(upstream_deb, self.config.cfg_path) self._install_upstream_deb() # Stop before we attempt to access container if self.config.getopt('install_only'): log.info("Done installing, stopping here per --install-only.") self.config.setopt('install_only', True) self.loop.exit(0) # Update jujus no-proxy setting if applicable if self.config.getopt('http_proxy') or \ self.config.getopt('https_proxy'): log.info("Updating juju environments for proxy support") lxc_net = self.config.getopt('lxc_network') self.config.update_environments_yaml( key='no-proxy', val='{},localhost,{}'.format( utils.container_ip(self.container_name), netutils.get_ip_set(lxc_net))) # start the party cloud_status_bin = ['openstack-status'] self.tasker.start_task("Bootstrapping Juju") utils.container_run(self.container_name, "{0} juju bootstrap".format( self.config.juju_home(use_expansion=True)), use_ssh=True) utils.container_run(self.container_name, "{0} juju status".format( self.config.juju_home(use_expansion=True)), use_ssh=True) self.tasker.stop_current_task() self.display_controller.status_info_message( "Starting cloud deployment") utils.container_run_status(self.container_name, " ".join(cloud_status_bin), self.config)