def _GET(self, *param, **params): host_id = self.chk_hostby1(param) if host_id is None: return web.notfound() self.view.host_id = host_id bond_list = get_bonding_info() if self.is_mode_input() is True: exist_bond_max_num = -1 exist_bond_list = get_ifconfig_info("regex:^bond") for bond_name in exist_bond_list.keys(): try: num = int(bond_name.replace("bond","")) except ValueError: continue if exist_bond_max_num < num: exist_bond_max_num = num self.view.create_bond_name = "bond%s" % (exist_bond_max_num + 1) dev_list = get_ifconfig_info("regex:^eth") for bond in bond_list: for slave in bond_list[bond]['slave']: if slave in dev_list: dev_list[slave]['bond'] = bond #pysical_dev_list = get_ifconfig_info("regex:^peth") pysical_dev_list = get_ifconfig_info("regex:^br") for pysical_dev in pysical_dev_list: if pysical_dev[1:] in dev_list: dev_list[pysical_dev[1:]]['bridge'] = pysical_dev self.view.bond_target_dev = dev_list self.view.hypervisors = available_virt_mechs() return True dev_list = get_ifconfig_info() for bond in bond_list: if bond in dev_list: dev_list[bond]['bond'] = True for slave in bond_list[bond]['slave']: for dev in dev_list: if dev == slave: dev_list[dev]['bond'] = True self.view.current = dev_list self.view.bond_list = bond_list return True
def _GET(self, *param, **params): host_id = self.chk_hostby1(param) if host_id is None: return web.notfound() self.view.host_id = host_id bond_list = get_bonding_info() if self.is_mode_input() is True: exist_bond_max_num = -1 exist_bond_list = get_ifconfig_info("regex:^bond") for bond_name in exist_bond_list.keys(): try: num = int(bond_name.replace("bond", "")) except ValueError: continue if exist_bond_max_num < num: exist_bond_max_num = num self.view.create_bond_name = "bond%s" % (exist_bond_max_num + 1) dev_list = get_ifconfig_info("regex:^eth") for bond in bond_list: for slave in bond_list[bond]['slave']: if slave in dev_list: dev_list[slave]['bond'] = bond #pysical_dev_list = get_ifconfig_info("regex:^peth") pysical_dev_list = get_ifconfig_info("regex:^br") for pysical_dev in pysical_dev_list: if pysical_dev[1:] in dev_list: dev_list[pysical_dev[1:]]['bridge'] = pysical_dev self.view.bond_target_dev = dev_list self.view.hypervisors = available_virt_mechs() return True dev_list = get_ifconfig_info() for bond in bond_list: if bond in dev_list: dev_list[bond]['bond'] = True for slave in bond_list[bond]['slave']: for dev in dev_list: if dev == slave: dev_list[dev]['bond'] = True self.view.current = dev_list self.view.bond_list = bond_list return True
def _GET(self, *param, **params): host_id = self.chk_hostby1(param) if host_id is None: return web.notfound() model = findbyhost1(self.orm, host_id) uris = available_virt_uris() self.kvc = KaresansuiVirtConnection() try: # libvirt connection scope --> # Storage Pool #inactive_pool = self.kvc.list_inactive_storage_pool() inactive_pool = [] active_pool = self.kvc.list_active_storage_pool() pools = inactive_pool + active_pool pools.sort() if not pools: return web.badrequest('One can not start a storage pool.') # Output .input if self.is_mode_input() is True: self.view.pools = pools pools_info = {} pools_vols_info = {} pools_iscsi_blocks = {} already_vols = [] guests = [] guests += self.kvc.list_inactive_guest() guests += self.kvc.list_active_guest() for guest in guests: already_vol = self.kvc.get_storage_volume_bydomain(domain=guest, image_type=None, attr='path') if already_vol: already_vols += already_vol.keys() for pool in pools: pool_obj = self.kvc.search_kvn_storage_pools(pool)[0] if pool_obj.is_active() is True: pools_info[pool] = pool_obj.get_info() blocks = None if pools_info[pool]['type'] == 'iscsi': blocks = self.kvc.get_storage_volume_iscsi_block_bypool(pool) if blocks: pools_iscsi_blocks[pool] = [] vols_obj = pool_obj.search_kvn_storage_volumes(self.kvc) vols_info = {} for vol_obj in vols_obj: vol_name = vol_obj.get_storage_volume_name() vols_info[vol_name] = vol_obj.get_info() if blocks: if vol_name in blocks and vol_name not in already_vols: pools_iscsi_blocks[pool].append(vol_obj.get_info()) pools_vols_info[pool] = vols_info self.view.pools_info = pools_info self.view.pools_vols_info = pools_vols_info self.view.pools_iscsi_blocks = pools_iscsi_blocks bridge_prefix = { "XEN":"xenbr", "KVM":KVM_BRIDGE_PREFIX, } self.view.host_id = host_id self.view.DEFAULT_KEYMAP = DEFAULT_KEYMAP self.view.DISK_NON_QEMU_FORMAT = DISK_NON_QEMU_FORMAT self.view.DISK_QEMU_FORMAT = DISK_QEMU_FORMAT self.view.hypervisors = {} self.view.mac_address = {} self.view.keymaps = {} self.view.phydev = {} self.view.virnet = {} used_ports = {} for k,v in MACHINE_HYPERVISOR.iteritems(): if k in available_virt_mechs(): self.view.hypervisors[k] = v uri = uris[k] mem_info = self.kvc.get_mem_info() active_networks = self.kvc.list_active_network() used_graphics_ports = self.kvc.list_used_graphics_port() bus_types = self.kvc.bus_types self.view.bus_types = bus_types self.view.max_mem = mem_info['host_max_mem'] self.view.free_mem = mem_info['host_free_mem'] self.view.alloc_mem = mem_info['guest_alloc_mem'] self.view.mac_address[k] = generate_mac_address(k) self.view.keymaps[k] = eval("get_keymaps(%s_KEYMAP_DIR)" % k) # Physical device phydev = [] phydev_regex = re.compile(r"%s" % bridge_prefix[k]) for dev,dev_info in get_ifconfig_info().iteritems(): try: if phydev_regex.match(dev): phydev.append(dev) except: pass if len(phydev) == 0: phydev.append("%s0" % bridge_prefix[k]) phydev.sort() self.view.phydev[k] = phydev # Physical device # Virtual device self.view.virnet[k] = sorted(active_networks) used_ports[k] = used_graphics_ports exclude_ports = [] for k, _used_port in used_ports.iteritems(): exclude_ports = exclude_ports + _used_port exclude_ports = sorted(exclude_ports) exclude_ports = [p for p, q in zip(exclude_ports, exclude_ports[1:] + [None]) if p != q] self.view.graphics_port = next_number(GRAPHICS_PORT_MIN_NUMBER, PORT_MAX_NUMBER, exclude_ports) else: # .part models = findbyhost1guestall(self.orm, host_id) guests = [] if models: # Physical Guest Info self.view.hypervisors = {} for model in models: for k,v in MACHINE_HYPERVISOR.iteritems(): if k in available_virt_mechs(): self.view.hypervisors[k] = v uri = uris[k] if hasattr(self, "kvc") is not True: self.kvc = KaresansuiVirtConnection(uri) domname = self.kvc.uuid_to_domname(model.uniq_key) #if not domname: return web.conflict(web.ctx.path) _virt = self.kvc.search_kvg_guests(domname) if 0 < len(_virt): guests.append(MergeGuest(model, _virt[0])) else: guests.append(MergeGuest(model, None)) # Exported Guest Info exports = {} for pool_name in pools: files = [] pool = self.kvc.search_kvn_storage_pools(pool_name) path = pool[0].get_info()["target"]["path"] if os.path.exists(path): for _afile in glob.glob("%s/*/info.dat" % (path,)): param = ExportConfigParam() param.load_xml_config(_afile) _dir = os.path.dirname(_afile) uuid = param.get_uuid() name = param.get_domain() created = param.get_created() title = param.get_title() if title != "": title = re.sub("[\r\n]","",title) if title == "": title = _('untitled') if created != "": created_str = time.strftime("%Y/%m/%d %H:%M:%S", \ time.localtime(float(created))) else: created_str = _("N/A") files.append({"dir": _dir, "pool" : pool_name, #"b64dir" : base64_encode(_dir), "uuid" : uuid, "name" : name, "created" : int(created), "created_str" : created_str, "title" : title, "icon" : param.get_database()["icon"], }) exports[pool_name] = files # .json if self.is_json() is True: guests_json = [] for x in guests: guests_json.append(x.get_json(self.me.languages)) self.view.guests = json_dumps(guests_json) else: self.view.exports = exports self.view.guests = guests return True finally: #self.kvc.close() pass # libvirt connection scope --> Guest#_post()
def process(self): (opts, args) = getopts() start_msg = _("Generated by %s on %s") % (prog_name,time.strftime("%Y/%m/%d %H:%M:%S", time.localtime())) print "# " + start_msg if is_executable(COMMAND_VIRSH): old_lang = os.environ.get('LANG') os.environ['LANG'] = "C" if opts.all is True or (opts.list is not True and opts.netlist is not True and opts.nodeinfo is not True and opts.poollist is not True): """ Show version """ print "" print "## Version" (rc,res) = execute_command([COMMAND_VIRSH,"version"]) if rc == 0: for line in res: if line != "": print line self.showKaresansuiVersion() if opts.all is True: """ Show uri """ print "" print "## URI" (rc,res) = execute_command([COMMAND_VIRSH,"uri"]) if rc == 0: print _("Connecting URI: %s") %(res[0]) """ Show hostname """ print "" print "## Hostname" (rc,res) = execute_command([COMMAND_VIRSH,"hostname"]) if rc == 0: print _("Hypervisor hostname: %s") %(res[0]) if opts.all is True or opts.nodeinfo is True: """ Show nodeinfo """ print "" print "## Node Information" (rc,res) = execute_command([COMMAND_VIRSH,"nodeinfo"]) if rc == 0: for line in res: if line != "": print line if opts.all is True or opts.list is True: """ Show dom list """ print "" print "## Domain List" (rc,res) = execute_command([COMMAND_VIRSH,"list","--all"]) if rc == 0: for line in res: if line != "": print line if opts.all is True or opts.netlist is True: """ Show net list """ print "" print "## Network List" (rc,res) = execute_command([COMMAND_VIRSH,"net-list","--all"]) if rc == 0: for line in res: if line != "": print line if opts.all is True or opts.poollist is True: """ Show pool list """ print "" print "## Pool List" (rc,res) = execute_command([COMMAND_VIRSH,"pool-list","--all"]) if rc == 0: for line in res: if line != "": print line os.environ['LANG'] = old_lang else: try: conn = libvirt.openReadOnly(None) hypervisor = conn.getType() if opts.all is True or (opts.list is not True and opts.netlist is not True and opts.nodeinfo is not True and opts.poollist is not True): """ Show version """ print "" print "## Version" ret = libvirtmod.virGetVersion(hypervisor) libVersion = ret[0] apiVersion = ret[1] libVersion_major = libVersion / 1000000 libVersion %= 1000000 libVersion_minor = libVersion / 1000 libVersion_rel = libVersion % 1000 apiVersion_major = apiVersion / 1000000 apiVersion %= 1000000 apiVersion_minor = apiVersion / 1000 apiVersion_rel = apiVersion % 1000 print _("Using library: libvir %d.%d.%d") %(libVersion_major, libVersion_minor, libVersion_rel) print _("Using API: %s %d.%d.%d") %(hypervisor, apiVersion_major, apiVersion_minor, apiVersion_rel) try: # See https://www.redhat.com/archives/libvir-list/2010-January/msg00723.html ret = libvirtmod.virConnectGetVersion(conn._o) hvVersion = ret hvVersion_major = hvVersion / 1000000 hvVersion %= 1000000 hvVersion_minor = hvVersion / 1000 hvVersion_rel = hvVersion % 1000 print _("Running hypervisor: %s %d.%d.%d") %(hypervisor, hvVersion_major, hvVersion_minor, hvVersion_rel) except: if hypervisor == "QEMU": (rc,res) = execute_command(["qemu","--version"]) if rc == 0: p = re.compile("QEMU PC emulator version ([0-9\.]+),.*") if p.search(res[0]): qemuVersion = p.sub("\\1",res[0]) print _("Running hypervisor: %s %s") %(hypervisor, qemuVersion) self.showKaresansuiVersion() if opts.all is True: """ Show uri """ print "" print "## URI" uri = conn.getURI() print _("Connecting URI: %s") %(uri) """ Show hostname """ print "" print "## Hostname" hostname = conn.getHostname() print _("Hypervisor hostname: %s") %(hostname) if opts.all is True or opts.nodeinfo is True: """ Show nodeinfo """ print "" print "## Node Information" nodeInfo = conn.getInfo() print "%-20s %s" % (_("CPU model:") ,nodeInfo[0]) print "%-20s %s" % (_("CPU(s):") ,nodeInfo[2]) print "%-20s %s MHz"% (_("CPU frequency:") ,nodeInfo[3]) print "%-20s %s" % (_("CPU socket(s):") ,nodeInfo[5]) print "%-20s %s" % (_("Core(s) per socket:"),nodeInfo[6]) print "%-20s %s" % (_("Thread(s) per core:"),nodeInfo[7]) print "%-20s %s" % (_("NUMA cell(s):") ,nodeInfo[4]) print "%-20s %lu kB"% (_("Memory Size:") ,(float)(nodeInfo[1])*1024) if opts.all is True or opts.list is True: """ Show dom list """ print "" print "## Domain List" state_flags = [ "no state", # VIR_DOMAIN_NOSTATE "running", # VIR_DOMAIN_RUNNING "idle", # VIR_DOMAIN_BLOCKED "paused", # VIR_DOMAIN_PAUSED "in shutdown", # VIR_DOMAIN_SHUTDOWN "shut off", # VIR_DOMAIN_SHUTOFF "crashed", # VIR_DOMAIN_CRASHED ] #print "%3s %-20s %s" %(_("Id"), _("Name"), _("State")) #print "----------------------------------" print "%3s %-20s %-12s %-37s %-10s %-12s %-12s %-3s %-12s" %(_("Id"), _("Name"), _("State"), _("UUID"), _("Autostart"), _("MaxMem"), _("Memory"), _("Vcpus"), _("CPUTime"), ) print "---------------------------------------------------------------------------" domains_ids = conn.listDomainsID() for id in domains_ids: dom = conn.lookupByID(id) name = dom.name() domID = id domInfo = dom.info() domUUID = dom.UUIDString() domAutostart = dom.autostart() if domAutostart == True: locale_domAutostart = _("enable") else: locale_domAutostart = _("disable") state = domInfo[0] if domID == -1: #print "%3s %-20s %s" %("-", name, state_flags[state]) print "%3s %-20s %-12s %-37s %-10s %-12ld %-12ld %-3d %-12ld" %("-", name, state_flags[state], domUUID, locale_domAutostart, domInfo[1], domInfo[2], domInfo[3], domInfo[4]) else: #print "%3d %-20s %s" %(domID, name, state_flags[state]) print "%3d %-20s %-12s %-37s %-10s %-12ld %-12ld %-3d %-12ld" %(domID, name, state_flags[state], domUUID, locale_domAutostart, domInfo[1], domInfo[2], domInfo[3], domInfo[4]) defined_domains = conn.listDefinedDomains() for name in defined_domains: dom = conn.lookupByName(name) #print dom.memoryStats() domID = dom.ID() domInfo = dom.info() domUUID = dom.UUIDString() domAutostart = dom.autostart() if domAutostart == True: locale_domAutostart = _("enable") else: locale_domAutostart = _("disable") state = domInfo[0] if domID == -1: #print "%3s %-20s %s" %("-", name, state_flags[state]) print "%3s %-20s %-12s %-37s %-10s %-12ld %-12ld %-3d %-12ld" %("-", name, state_flags[state], domUUID, locale_domAutostart, domInfo[1], domInfo[2], domInfo[3], domInfo[4]) else: #print "%3d %-20s %s" %(domID, name, state_flags[state]) print "%3d %-20s %-12s %-37s %-10s %-12ld %-12ld %-3d %-12ld" %(domID, name, state_flags[state], domUUID, locale_domAutostart, domInfo[1], domInfo[2], domInfo[3], domInfo[4]) if opts.all is True or opts.netlist is True: """ Show net list """ print "" print "## Network List" #print "%-20s %-10s %-10s" %(_("Name"), _("State"), _("Autostart")) #print "-----------------------------------------" print "%-20s %-10s %-37s %-10s" %(_("Name"), _("State"), _("UUID"), _("Autostart"), ) print "--------------------------------------------------------------------------" networks = conn.listNetworks() for name in networks: net = conn.networkLookupByName(name) uuid = net.UUIDString() autostart = net.autostart() if autostart == True: locale_autostart = _("yes") else: locale_autostart = _("no") print "%-20s %-10s %-37s %-10s" %(name, _("Active"), uuid, locale_autostart) defined_networks = conn.listDefinedNetworks() for name in defined_networks: net = conn.networkLookupByName(name) uuid = net.UUIDString() autostart = net.autostart() if autostart == True: locale_autostart = _("yes") else: locale_autostart = _("no") print "%-20s %-10s %-37s %-10s" %(name, _("Inactive"), uuid, locale_autostart) if opts.all is True or opts.poollist is True: """ Show pool list """ #taizoa print "" print "## Pool List" print "%-20s %-10s %-37s %-10s" %(_("Name"), _("State"), _("UUID"), _("Autostart"), ) print "--------------------------------------------------------------------------" pools = conn.listStoragePools() for name in pools: pool = conn.storagePoolLookupByName(name) uuid = pool.UUIDString() autostart = pool.autostart() if autostart == True: locale_autostart = _("yes") else: locale_autostart = _("no") print "%-20s %-10s %-37s %-10s" %(name, _("Active"), uuid, locale_autostart) defined_pools = conn.listDefinedStoragePools() for name in defined_pools: pool = conn.storagePoolLookupByName(name) uuid = pool.UUIDString() autostart = pool.autostart() if autostart == True: locale_autostart = _("yes") else: locale_autostart = _("no") print "%-20s %-10s %-37s %-10s" %(name, _("Inactive"), uuid, locale_autostart) except: pass if opts.all is True: """ Show available uris """ print "" print "## Available URIs" for mech,uri in available_virt_uris().iteritems(): print uri """ Show available mechs """ print "" print "## Available mechanisms" for mech in available_virt_mechs(): print mech """ Show installed packages """ print "" print "## Installed packages" (rc,res) = execute_command(["rpm","-qa",'--queryformat=%{NAME}\t%{VERSION}\t%{RELEASE}\t%{INSTALLTIME}\t%{BUILDHOST}\n']) if rc == 0: print "%-25s %-10s %-10s %-20s" %(_("Name"), _("Version"), _("Release"), _("InstallTime"), ) print "------------------------------------------------------------------" p = re.compile("hde\.co\.jp") output = [] for aline in res: arr = aline.split("\t") if p.search(arr[4]): str = "%-25s %-10s %-10s %-20s" %(arr[0],arr[1],arr[2],time.strftime("%Y-%m-%d %H:%M:%S",time.localtime(float(arr[3]))),) output.append(str) print "\n".join(sorted(output)) finish_msg = _("Completed on %s") % time.strftime("%Y/%m/%d %H:%M:%S", time.localtime()) print "" print "# " + finish_msg return True
def _GET(self, *param, **params): host_id = self.chk_hostby1(param) if host_id is None: return web.notfound() model = findbyhost1(self.orm, host_id) uris = available_virt_uris() #import pdb; pdb.set_trace() if model.attribute == MACHINE_ATTRIBUTE["URI"]: uri_guests = [] uri_guests_status = {} uri_guests_kvg = {} uri_guests_info = {} uri_guests_name = {} segs = uri_split(model.hostname) uri = uri_join(segs, without_auth=True) creds = '' if segs["user"] is not None: creds += segs["user"] if segs["passwd"] is not None: creds += ':' + segs["passwd"] # Output .part if self.is_mode_input() is not True: try: self.kvc = KaresansuiVirtConnectionAuth(uri, creds) host = MergeHost(self.kvc, model) for guest in host.guests: _virt = self.kvc.search_kvg_guests( guest.info["model"].name) if 0 < len(_virt): for _v in _virt: uuid = _v.get_info()["uuid"] uri_guests_info[uuid] = guest.info uri_guests_kvg[uuid] = _v uri_guests_name[uuid] = guest.info[ "model"].name.encode("utf8") for name in sorted(uri_guests_name.values(), key=str.lower): for uuid in dict_search(name, uri_guests_name): uri_guests.append( MergeGuest(uri_guests_info[uuid]["model"], uri_guests_kvg[uuid])) uri_guests_status[uuid] = uri_guests_info[uuid][ 'virt'].status() finally: self.kvc.close() # .json if self.is_json() is True: guests_json = [] for x in uri_guests: guests_json.append(x.get_json(self.me.languages)) self.view.uri_guests = json_dumps(guests_json) else: self.view.uri_guests = uri_guests self.view.uri_guests_status = uri_guests_status self.kvc = KaresansuiVirtConnection() try: # libvirt connection scope --> # Storage Pool #inactive_pool = self.kvc.list_inactive_storage_pool() inactive_pool = [] active_pool = self.kvc.list_active_storage_pool() pools = inactive_pool + active_pool pools.sort() if not pools: return web.badrequest('One can not start a storage pool.') # Output .input if self.is_mode_input() is True: self.view.pools = pools pools_info = {} pools_vols_info = {} pools_iscsi_blocks = {} already_vols = [] guests = [] guests += self.kvc.list_inactive_guest() guests += self.kvc.list_active_guest() for guest in guests: already_vol = self.kvc.get_storage_volume_bydomain( domain=guest, image_type=None, attr='path') if already_vol: already_vols += already_vol.keys() for pool in pools: pool_obj = self.kvc.search_kvn_storage_pools(pool)[0] if pool_obj.is_active() is True: pools_info[pool] = pool_obj.get_info() blocks = None if pools_info[pool]['type'] == 'iscsi': blocks = self.kvc.get_storage_volume_iscsi_block_bypool( pool) if blocks: pools_iscsi_blocks[pool] = [] vols_obj = pool_obj.search_kvn_storage_volumes( self.kvc) vols_info = {} for vol_obj in vols_obj: vol_name = vol_obj.get_storage_volume_name() vols_info[vol_name] = vol_obj.get_info() if blocks: if vol_name in blocks and vol_name not in already_vols: pools_iscsi_blocks[pool].append( vol_obj.get_info()) pools_vols_info[pool] = vols_info self.view.pools_info = pools_info self.view.pools_vols_info = pools_vols_info self.view.pools_iscsi_blocks = pools_iscsi_blocks bridge_prefix = { "XEN": "xenbr", "KVM": KVM_BRIDGE_PREFIX, } self.view.host_id = host_id self.view.DEFAULT_KEYMAP = DEFAULT_KEYMAP self.view.DISK_NON_QEMU_FORMAT = DISK_NON_QEMU_FORMAT self.view.DISK_QEMU_FORMAT = DISK_QEMU_FORMAT self.view.hypervisors = {} self.view.mac_address = {} self.view.keymaps = {} self.view.phydev = {} self.view.virnet = {} used_ports = {} for k, v in MACHINE_HYPERVISOR.iteritems(): if k in available_virt_mechs(): self.view.hypervisors[k] = v uri = uris[k] mem_info = self.kvc.get_mem_info() active_networks = self.kvc.list_active_network() used_graphics_ports = self.kvc.list_used_graphics_port( ) bus_types = self.kvc.bus_types self.view.bus_types = bus_types self.view.max_mem = mem_info['host_max_mem'] self.view.free_mem = mem_info['host_free_mem'] self.view.alloc_mem = mem_info['guest_alloc_mem'] self.view.mac_address[k] = generate_mac_address(k) self.view.keymaps[k] = eval( "get_keymaps(%s_KEYMAP_DIR)" % k) # Physical device phydev = [] phydev_regex = re.compile(r"%s" % bridge_prefix[k]) for dev, dev_info in get_ifconfig_info().iteritems(): try: if phydev_regex.match(dev): phydev.append(dev) except: pass if len(phydev) == 0: phydev.append("%s0" % bridge_prefix[k]) phydev.sort() self.view.phydev[k] = phydev # Physical device # Virtual device self.view.virnet[k] = sorted(active_networks) used_ports[k] = used_graphics_ports exclude_ports = [] for k, _used_port in used_ports.iteritems(): exclude_ports = exclude_ports + _used_port exclude_ports = sorted(exclude_ports) exclude_ports = [ p for p, q in zip(exclude_ports, exclude_ports[1:] + [None]) if p != q ] self.view.graphics_port = next_number(GRAPHICS_PORT_MIN_NUMBER, PORT_MAX_NUMBER, exclude_ports) else: # .part models = findbyhost1guestall(self.orm, host_id) guests = [] if models: # Physical Guest Info self.view.hypervisors = {} for model in models: for k, v in MACHINE_HYPERVISOR.iteritems(): if k in available_virt_mechs(): self.view.hypervisors[k] = v uri = uris[k] if hasattr(self, "kvc") is not True: self.kvc = KaresansuiVirtConnection(uri) domname = self.kvc.uuid_to_domname( model.uniq_key) #if not domname: return web.conflict(web.ctx.path) _virt = self.kvc.search_kvg_guests(domname) if 0 < len(_virt): guests.append(MergeGuest(model, _virt[0])) else: guests.append(MergeGuest(model, None)) # Exported Guest Info exports = {} for pool_name in pools: files = [] pool = self.kvc.search_kvn_storage_pools(pool_name) path = pool[0].get_info()["target"]["path"] if os.path.exists(path): for _afile in glob.glob("%s/*/info.dat" % (path, )): param = ExportConfigParam() param.load_xml_config(_afile) _dir = os.path.dirname(_afile) uuid = param.get_uuid() name = param.get_domain() created = param.get_created() title = param.get_title() if title != "": title = re.sub("[\r\n]", "", title) if title == "": title = _('untitled') if created != "": created_str = time.strftime("%Y/%m/%d %H:%M:%S", \ time.localtime(float(created))) else: created_str = _("N/A") files.append({ "dir": _dir, "pool": pool_name, #"b64dir" : base64_encode(_dir), "uuid": uuid, "name": name, "created": int(created), "created_str": created_str, "title": title, "icon": param.get_database()["icon"], }) exports[pool_name] = files # .json if self.is_json() is True: guests_json = [] for x in guests: guests_json.append(x.get_json(self.me.languages)) self.view.guests = json_dumps(guests_json) else: self.view.exports = exports self.view.guests = guests return True except: pass finally: #self.kvc.close() pass # libvirt connection scope --> Guest#_post()
def process(self): (opts, args) = getopts() start_msg = _("Generated by %s on %s") % ( prog_name, time.strftime("%Y/%m/%d %H:%M:%S", time.localtime())) print "# " + start_msg if is_executable(COMMAND_VIRSH): old_lang = os.environ.get('LANG') os.environ['LANG'] = "C" if opts.all is True or (opts.list is not True and opts.netlist is not True and opts.nodeinfo is not True and opts.poollist is not True): """ Show version """ print "" print "## Version" (rc, res) = execute_command([COMMAND_VIRSH, "version"]) if rc == 0: for line in res: if line != "": print line self.showKaresansuiVersion() if opts.all is True: """ Show uri """ print "" print "## URI" (rc, res) = execute_command([COMMAND_VIRSH, "uri"]) if rc == 0: print _("Connecting URI: %s") % (res[0]) """ Show hostname """ print "" print "## Hostname" (rc, res) = execute_command([COMMAND_VIRSH, "hostname"]) if rc == 0: print _("Hypervisor hostname: %s") % (res[0]) if opts.all is True or opts.nodeinfo is True: """ Show nodeinfo """ print "" print "## Node Information" (rc, res) = execute_command([COMMAND_VIRSH, "nodeinfo"]) if rc == 0: for line in res: if line != "": print line if opts.all is True or opts.list is True: """ Show dom list """ print "" print "## Domain List" (rc, res) = execute_command([COMMAND_VIRSH, "list", "--all"]) if rc == 0: for line in res: if line != "": print line if opts.all is True or opts.netlist is True: """ Show net list """ print "" print "## Network List" (rc, res) = execute_command([COMMAND_VIRSH, "net-list", "--all"]) if rc == 0: for line in res: if line != "": print line if opts.all is True or opts.poollist is True: """ Show pool list """ print "" print "## Pool List" (rc, res) = execute_command([COMMAND_VIRSH, "pool-list", "--all"]) if rc == 0: for line in res: if line != "": print line os.environ['LANG'] = old_lang else: try: conn = libvirt.openReadOnly(None) hypervisor = conn.getType() if opts.all is True or (opts.list is not True and opts.netlist is not True and opts.nodeinfo is not True and opts.poollist is not True): """ Show version """ print "" print "## Version" ret = libvirtmod.virGetVersion(hypervisor) libVersion = ret[0] apiVersion = ret[1] libVersion_major = libVersion / 1000000 libVersion %= 1000000 libVersion_minor = libVersion / 1000 libVersion_rel = libVersion % 1000 apiVersion_major = apiVersion / 1000000 apiVersion %= 1000000 apiVersion_minor = apiVersion / 1000 apiVersion_rel = apiVersion % 1000 print _("Using library: libvir %d.%d.%d") % ( libVersion_major, libVersion_minor, libVersion_rel) print _("Using API: %s %d.%d.%d") % ( hypervisor, apiVersion_major, apiVersion_minor, apiVersion_rel) try: # See https://www.redhat.com/archives/libvir-list/2010-January/msg00723.html ret = libvirtmod.virConnectGetVersion(conn._o) hvVersion = ret hvVersion_major = hvVersion / 1000000 hvVersion %= 1000000 hvVersion_minor = hvVersion / 1000 hvVersion_rel = hvVersion % 1000 print _("Running hypervisor: %s %d.%d.%d") % ( hypervisor, hvVersion_major, hvVersion_minor, hvVersion_rel) except: if hypervisor == "QEMU": (rc, res) = execute_command(["qemu", "--version"]) if rc == 0: p = re.compile( "QEMU PC emulator version ([0-9\.]+),.*") if p.search(res[0]): qemuVersion = p.sub("\\1", res[0]) print _("Running hypervisor: %s %s") % ( hypervisor, qemuVersion) self.showKaresansuiVersion() if opts.all is True: """ Show uri """ print "" print "## URI" uri = conn.getURI() print _("Connecting URI: %s") % (uri) """ Show hostname """ print "" print "## Hostname" hostname = conn.getHostname() print _("Hypervisor hostname: %s") % (hostname) if opts.all is True or opts.nodeinfo is True: """ Show nodeinfo """ print "" print "## Node Information" nodeInfo = conn.getInfo() print "%-20s %s" % (_("CPU model:"), nodeInfo[0]) print "%-20s %s" % (_("CPU(s):"), nodeInfo[2]) print "%-20s %s MHz" % (_("CPU frequency:"), nodeInfo[3]) print "%-20s %s" % (_("CPU socket(s):"), nodeInfo[5]) print "%-20s %s" % (_("Core(s) per socket:"), nodeInfo[6]) print "%-20s %s" % (_("Thread(s) per core:"), nodeInfo[7]) print "%-20s %s" % (_("NUMA cell(s):"), nodeInfo[4]) print "%-20s %lu kB" % (_("Memory Size:"), (float)(nodeInfo[1]) * 1024) if opts.all is True or opts.list is True: """ Show dom list """ print "" print "## Domain List" state_flags = [ "no state", # VIR_DOMAIN_NOSTATE "running", # VIR_DOMAIN_RUNNING "idle", # VIR_DOMAIN_BLOCKED "paused", # VIR_DOMAIN_PAUSED "in shutdown", # VIR_DOMAIN_SHUTDOWN "shut off", # VIR_DOMAIN_SHUTOFF "crashed", # VIR_DOMAIN_CRASHED ] #print "%3s %-20s %s" %(_("Id"), _("Name"), _("State")) #print "----------------------------------" print "%3s %-20s %-12s %-37s %-10s %-12s %-12s %-3s %-12s" % ( _("Id"), _("Name"), _("State"), _("UUID"), _("Autostart"), _("MaxMem"), _("Memory"), _("Vcpus"), _("CPUTime"), ) print "---------------------------------------------------------------------------" domains_ids = conn.listDomainsID() for id in domains_ids: dom = conn.lookupByID(id) name = dom.name() domID = id domInfo = dom.info() domUUID = dom.UUIDString() domAutostart = dom.autostart() if domAutostart == True: locale_domAutostart = _("enable") else: locale_domAutostart = _("disable") state = domInfo[0] if domID == -1: #print "%3s %-20s %s" %("-", name, state_flags[state]) print "%3s %-20s %-12s %-37s %-10s %-12ld %-12ld %-3d %-12ld" % ( "-", name, state_flags[state], domUUID, locale_domAutostart, domInfo[1], domInfo[2], domInfo[3], domInfo[4]) else: #print "%3d %-20s %s" %(domID, name, state_flags[state]) print "%3d %-20s %-12s %-37s %-10s %-12ld %-12ld %-3d %-12ld" % ( domID, name, state_flags[state], domUUID, locale_domAutostart, domInfo[1], domInfo[2], domInfo[3], domInfo[4]) defined_domains = conn.listDefinedDomains() for name in defined_domains: dom = conn.lookupByName(name) #print dom.memoryStats() domID = dom.ID() domInfo = dom.info() domUUID = dom.UUIDString() domAutostart = dom.autostart() if domAutostart == True: locale_domAutostart = _("enable") else: locale_domAutostart = _("disable") state = domInfo[0] if domID == -1: #print "%3s %-20s %s" %("-", name, state_flags[state]) print "%3s %-20s %-12s %-37s %-10s %-12ld %-12ld %-3d %-12ld" % ( "-", name, state_flags[state], domUUID, locale_domAutostart, domInfo[1], domInfo[2], domInfo[3], domInfo[4]) else: #print "%3d %-20s %s" %(domID, name, state_flags[state]) print "%3d %-20s %-12s %-37s %-10s %-12ld %-12ld %-3d %-12ld" % ( domID, name, state_flags[state], domUUID, locale_domAutostart, domInfo[1], domInfo[2], domInfo[3], domInfo[4]) if opts.all is True or opts.netlist is True: """ Show net list """ print "" print "## Network List" #print "%-20s %-10s %-10s" %(_("Name"), _("State"), _("Autostart")) #print "-----------------------------------------" print "%-20s %-10s %-37s %-10s" % ( _("Name"), _("State"), _("UUID"), _("Autostart"), ) print "--------------------------------------------------------------------------" networks = conn.listNetworks() for name in networks: net = conn.networkLookupByName(name) uuid = net.UUIDString() autostart = net.autostart() if autostart == True: locale_autostart = _("yes") else: locale_autostart = _("no") print "%-20s %-10s %-37s %-10s" % ( name, _("Active"), uuid, locale_autostart) defined_networks = conn.listDefinedNetworks() for name in defined_networks: net = conn.networkLookupByName(name) uuid = net.UUIDString() autostart = net.autostart() if autostart == True: locale_autostart = _("yes") else: locale_autostart = _("no") print "%-20s %-10s %-37s %-10s" % ( name, _("Inactive"), uuid, locale_autostart) if opts.all is True or opts.poollist is True: """ Show pool list """ #taizoa print "" print "## Pool List" print "%-20s %-10s %-37s %-10s" % ( _("Name"), _("State"), _("UUID"), _("Autostart"), ) print "--------------------------------------------------------------------------" pools = conn.listStoragePools() for name in pools: pool = conn.storagePoolLookupByName(name) uuid = pool.UUIDString() autostart = pool.autostart() if autostart == True: locale_autostart = _("yes") else: locale_autostart = _("no") print "%-20s %-10s %-37s %-10s" % ( name, _("Active"), uuid, locale_autostart) defined_pools = conn.listDefinedStoragePools() for name in defined_pools: pool = conn.storagePoolLookupByName(name) uuid = pool.UUIDString() autostart = pool.autostart() if autostart == True: locale_autostart = _("yes") else: locale_autostart = _("no") print "%-20s %-10s %-37s %-10s" % ( name, _("Inactive"), uuid, locale_autostart) except: pass if opts.all is True: """ Show available uris """ print "" print "## Available URIs" for mech, uri in available_virt_uris().iteritems(): print uri """ Show available mechs """ print "" print "## Available mechanisms" for mech in available_virt_mechs(): print mech """ Show installed packages """ print "" print "## Installed packages" (rc, res) = execute_command([ "rpm", "-qa", '--queryformat=%{NAME}\t%{VERSION}\t%{RELEASE}\t%{INSTALLTIME}\t%{BUILDHOST}\n' ]) if rc == 0: print "%-25s %-10s %-10s %-20s" % ( _("Name"), _("Version"), _("Release"), _("InstallTime"), ) print "------------------------------------------------------------------" p = re.compile("hde\.co\.jp") output = [] for aline in res: arr = aline.split("\t") if p.search(arr[4]): str = "%-25s %-10s %-10s %-20s" % ( arr[0], arr[1], arr[2], time.strftime("%Y-%m-%d %H:%M:%S", time.localtime(float(arr[3]))), ) output.append(str) print "\n".join(sorted(output)) finish_msg = _("Completed on %s") % time.strftime( "%Y/%m/%d %H:%M:%S", time.localtime()) print "" print "# " + finish_msg return True