def wait_for_oc_service(cls, server): oc_port = 443 try: ipv4 = Utils.get_ipv4(server.addresses["public"]) msg = "Waiting for OpenCenter service to be up: %s" % server.name logger.info(msg) while (not Utils.port_is_open(ipv4, oc_port)): msg = "Still waiting for OpenCenter service to be up: %s" \ % server.name logger.debug(msg) sleep(10) msg = "OpenCenter Service Ready on: %s" % server.name logger.info(msg) except Exception,e: logger.error(msg)
def wait_for_oc_server(cls, nova_client, oc_server, network): updated_oc_server = oc_server oc_port = 443 # Check server status until active status = cls.check_status(nova_client, updated_oc_server) while not status: if status == False: sleep(10) updated_oc_server = \ cls.update_server(nova_client, updated_oc_server) elif status is None: msg = "Server Error (OC Server - Booting Issue): Deleting %s" \ % updated_oc_server.name return cls.oc_server_recover(\ msg, updated_oc_server, nova_client, network) status = cls.check_status(nova_client, updated_oc_server) ipv4 = Utils.get_ipv4(updated_oc_server.addresses["public"]) active_port = 22 # SSH # If active, do post setup if Utils.port_is_open(ipv4, active_port): updated_oc_server = cls.post_setup(nova_client, oc_server, oc_port) if not updated_oc_server: msg = "Server Error (OC Server - Setup Issue): Deleting %s" \ % updated_oc_server.name return cls.oc_server_recover(\ msg, updated_oc_server, nova_client, network) # If for some reason network is not working even when active, try again else: msg = "Server Error (OC Server - Routing Issue): Deleting %s" \ % updated_oc_server.name return cls.oc_server_recover(\ msg, updated_oc_server, nova_client, network) return updated_oc_server
def wait_for_oc_agents(cls, oc_agents, nova_client, oc_server, network): updated_oc_agents = [] active_port = 22 # SSH while len(updated_oc_agents) != len(oc_agents): for index, oc_agent in enumerate(oc_agents): status = cls.check_status(nova_client, oc_agent) if status == True: updated_oc_agent = cls.update_server(nova_client, oc_agent) ipv4 = Utils.get_ipv4(updated_oc_agent.addresses["public"]) if updated_oc_agent not in updated_oc_agents: if Utils.port_is_open(ipv4, active_port): updated_oc_agent = \ cls.post_setup(nova_client, oc_agent) updated_oc_agents.append(updated_oc_agent) else: msg = "Server Error (OC Agent - " + \ "Booting Issue): Deleting %s" \ % oc_agent.name logger.error(msg) cls.delete_server(oc_agent) sleep(10) oc_agent = cls.launch_oc_agent(\ oc_server, nova_client, network) oc_agents[index] = oc_agent elif status == False: sleep(10) elif status is None: msg = "Server Error (OC Agent - " + \ "Routing Issue): Deleting %s" % oc_agent.name logger.error(msg) cls.delete_server(oc_agent) sleep(10) oc_agent = cls.launch_oc_agent(\ oc_server, nova_client, network) oc_agents[index] = oc_agent return updated_oc_agents