本文整理汇总了Java中com.vmware.vim25.mo.InventoryNavigator类的典型用法代码示例。如果您正苦于以下问题:Java InventoryNavigator类的具体用法?Java InventoryNavigator怎么用?Java InventoryNavigator使用的例子?那么, 这里精选的类代码示例或许可以为您提供帮助。
InventoryNavigator类属于com.vmware.vim25.mo包,在下文中一共展示了InventoryNavigator类的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Java代码示例。
示例1: migrateVM
import com.vmware.vim25.mo.InventoryNavigator; //导入依赖的package包/类
private static boolean migrateVM(String targetVMName, String newHostName,
boolean tryAnotherVM, boolean tryAnotherHost) throws Exception {
ServiceInstance si = new ServiceInstance(new URL(url), username, password,
true);
try {
Folder rootFolder = si.getRootFolder();
HostSystem newHost = (HostSystem)new InventoryNavigator(rootFolder)
.searchManagedEntity("HostSystem", newHostName);
return migrateVM(si, rootFolder, newHost, targetVMName, newHostName,
tryAnotherVM, tryAnotherHost);
} finally {
si.getServerConnection().logout();
}
}
示例2: doMigrateVM
import com.vmware.vim25.mo.InventoryNavigator; //导入依赖的package包/类
private static synchronized boolean doMigrateVM(String targetVMName,
String newHostName) throws Exception {
ServiceInstance si = new ServiceInstance(new URL(url), username, password,
true);
try {
Folder rootFolder = si.getRootFolder();
InventoryNavigator in = new InventoryNavigator(rootFolder);
HostSystem newHost = (HostSystem)in.searchManagedEntity("HostSystem",
newHostName);
if (newHost == null) {
throw new TestException("Could not find host " + newHostName + " as a target host for vMotion.");
}
return migrateVM(si, rootFolder, newHost, targetVMName, newHostName);
} finally {
si.getServerConnection().logout();
}
}
示例3: HydraTask_migrateNetDownVM
import com.vmware.vim25.mo.InventoryNavigator; //导入依赖的package包/类
public static void HydraTask_migrateNetDownVM() throws Exception {
SharedMap sMap = VMotionBB.getBB().getSharedMap();
Boolean bool = (Boolean)sMap.get("connectionDropped");
if (bool == null || !bool) {
return;
}
initializeParams();
if (!validateParams()) {
return;
}
ServiceInstance si = new ServiceInstance(new URL(url), username, password,
true);
try {
Folder rootFolder = si.getRootFolder();
HostSystem newHost = (HostSystem)new InventoryNavigator(rootFolder)
.searchManagedEntity("HostSystem", hostNames[0]);
migrateVM(si, rootFolder, newHost, vmNames[0], hostNames[0], false, false);
} finally {
si.getServerConnection().logout();
}
}
示例4: tryFindResourcePool
import com.vmware.vim25.mo.InventoryNavigator; //导入依赖的package包/类
private Optional<ResourcePool> tryFindResourcePool(Folder folder, String hostname) {
Iterable<ResourcePool> resourcePools = ImmutableSet.<ResourcePool>of();
try {
ManagedEntity[] resourcePoolEntities = new InventoryNavigator(folder).searchManagedEntities("ResourcePool");
resourcePools = Iterables.transform(Arrays.asList(resourcePoolEntities), new Function<ManagedEntity, ResourcePool>() {
public ResourcePool apply(ManagedEntity input) {
return (ResourcePool) input;
}
});
Optional<ResourcePool> optionalResourcePool = Iterables.tryFind(resourcePools, VSpherePredicate.isResourcePoolOf(hostname));
return optionalResourcePool;
} catch (Exception e) {
logger.error("Problem in finding a valid resource pool", e);
}
return Optional.absent();
}
示例5: getClusters
import com.vmware.vim25.mo.InventoryNavigator; //导入依赖的package包/类
private Set<? extends Location> getClusters() {
Set<Location> hosts = Sets.newHashSet();
try (VSphereServiceInstance instance = serviceInstance.get();) {
ManagedEntity[] clusterEntities = new InventoryNavigator(instance.getInstance().getRootFolder()).searchManagedEntities("ClusterComputeResource");
for (ManagedEntity cluster : clusterEntities) {
Location location = new LocationImpl(LocationScope.ZONE, cluster.getName(), cluster.getName(), null, ImmutableSet.of(""), Maps.<String, Object>newHashMap());
hosts.add(location);
}
hosts.add(new LocationImpl(LocationScope.ZONE, "default", "default", null, ImmutableSet.of(""), Maps.<String, Object>newHashMap()));
return hosts;
} catch (Exception e) {
logger.error("Problem in finding a valid cluster", e);
Throwables.propagateIfPossible(e);
}
return hosts;
}
示例6: load
import com.vmware.vim25.mo.InventoryNavigator; //导入依赖的package包/类
@Override
public Optional<VirtualMachine> load(String vmName) {
Optional<VirtualMachine> results = Optional.absent();
try (VSphereServiceInstance instance = serviceInstance.get();) {
VirtualMachine vm = (VirtualMachine) new InventoryNavigator(instance.getInstance().getRootFolder()).searchManagedEntity("VirtualMachine", vmName);
if (VSpherePredicate.isTemplatePredicate.apply(vm)) {
results = Optional.of(vm);
}
} catch (Exception e) {
logger.error("Can't find template " + vmName, e);
Throwables.propagateIfPossible(e);
}
return results;
}
示例7: getHostMachines
import com.vmware.vim25.mo.InventoryNavigator; //导入依赖的package包/类
private List<ManagedEntity> getHostMachines(Folder rootFolder, List<Map<String, Object>> hostConfigs) {
List<ManagedEntity> hostEntities = new ArrayList<ManagedEntity>();
for (Map<String, Object> hostConfig : hostConfigs) {
String hostName = (String) hostConfig.get("host");
try {
if ("*".equals(hostName)) {
hostEntities = Arrays.asList(new InventoryNavigator(rootFolder).searchManagedEntities("HostSystem"));
} else {
ManagedEntity hostSystem = new InventoryNavigator(rootFolder).searchManagedEntity("HostSystem", hostName);
if (hostSystem != null) {
hostEntities.add(hostSystem);
} else {
logger.error("Could not find Host with name " + hostName);
}
}
} catch (InvalidProperty invalidProperty) {
logger.error("Unable to get the host details", invalidProperty);
} catch (RuntimeFault runtimeFault) {
logger.error("Unable to get the host details", runtimeFault);
} catch (RemoteException e) {
logger.error("Unable to get the host details", e);
}
}
return hostEntities;
}
示例8: inventoryNavigator
import com.vmware.vim25.mo.InventoryNavigator; //导入依赖的package包/类
@Bean
@ConditionalOnProperty("vsphere.host")
InventoryNavigator inventoryNavigator(@Value("${vsphere.host}") String host,
@Value("${vsphere.username}") String username,
@Value("${vsphere.password}") String password) throws MalformedURLException,
RemoteException {
URL url = new URL(String.format("https://%s/sdk", host));
ServiceInstance serviceInstance = new ServiceInstance(url, username, password, true);
return new InventoryNavigator(serviceInstance.getRootFolder());
}
示例9: VSphereMetricsForwarder
import com.vmware.vim25.mo.InventoryNavigator; //导入依赖的package包/类
@Autowired
public VSphereMetricsForwarder(InventoryNavigator inventoryNavigator,
@Value("${cf.instance.Name:default}") String cfInstanceName,
@Value("${datastores:}") String[] datastores) {
this.inventoryNavigator = inventoryNavigator;
this.cfInstanceName = cfInstanceName;
this.insights = NewRelic.getAgent().getInsights();
this.datastores = Lists.newArrayList(datastores);
}
示例10: migrateVM
import com.vmware.vim25.mo.InventoryNavigator; //导入依赖的package包/类
private static boolean migrateVM(ServiceInstance si, Folder rootFolder,
HostSystem newHost, String targetVMName, String newHostName)
throws Exception {
log("Selected host [vm] for vMotion: " + newHostName + " [" + targetVMName
+ "]");
VirtualMachine vm = (VirtualMachine)new InventoryNavigator(rootFolder)
.searchManagedEntity("VirtualMachine", targetVMName);
if (vm == null) {
log(WARNING, "Could not resolve VM " + targetVMName + ", vMotion of this VM cannot be performed.");
return false;
}
ComputeResource cr = (ComputeResource)newHost.getParent();
String[] checks = new String[] { "cpu", "software" };
HostVMotionCompatibility[] vmcs = si.queryVMotionCompatibility(vm,
new HostSystem[] { newHost }, checks);
String[] comps = vmcs[0].getCompatibility();
if (checks.length != comps.length) {
log(WARNING, "CPU/software NOT compatible, vMotion failed.");
return false;
}
long start = System.currentTimeMillis();
Task task = vm.migrateVM_Task(cr.getResourcePool(), newHost,
VirtualMachineMovePriority.highPriority,
VirtualMachinePowerState.poweredOn);
if (task.waitForMe() == Task.SUCCESS) {
long end = System.currentTimeMillis();
log("vMotion of " + targetVMName + " to " + newHostName
+ " completed in " + (end - start) + "ms. Task result: "
+ task.getTaskInfo().getResult());
return true;
} else {
TaskInfo info = task.getTaskInfo();
log(WARNING, "vMotion of " + targetVMName + " to " + newHostName
+ " failed. Error details: " + info.getError().getFault());
return false;
}
}
示例11: main
import com.vmware.vim25.mo.InventoryNavigator; //导入依赖的package包/类
public static void main(String[] args) throws Exception {
ServiceInstance si = new ServiceInstance(new URL(
"https://10.120.30.40/sdk"), "[email protected]",
"Administrator!23", true);
// Get the rootFolder
Folder rootFolder = si.getRootFolder();
// Get all the hosts in the vCenter server
ManagedEntity[] hosts = new InventoryNavigator(rootFolder)
.searchManagedEntities("HostSystem");
if (hosts == null) {
System.out.println("Host not found on vCenter");
si.getServerConnection().logout();
return;
}
// Map to store the datastore name as key and its UUID as the value
Map< String , String> vmfsdatastoreUUIDs = new HashMap< String , String>();
// Map to store host as key and all of its datastores as the value
Map< ManagedEntity , Datastore[]> hostDatastores = new HashMap< ManagedEntity , Datastore[]>();
for (ManagedEntity hostSystem : hosts) {
HostDatastoreBrowser hdb = ((HostSystem) hostSystem)
.getDatastoreBrowser();
Datastore[] ds = hdb.getDatastores();
hostDatastores.put(hostSystem, ds);
}
System.out.println("Hosts and all of its associated datastores");
for (Map.Entry < ManagedEntity , Datastore[]> datastores : hostDatastores
.entrySet()) {
System.out.println("");
System.out.print("[" + datastores.getKey().getName() + "::");
for (Datastore datastore : datastores.getValue()) {
System.out.print(datastore.getName() + ",");
DatastoreInfo dsinfo = datastore.getInfo();
if (dsinfo instanceof VmfsDatastoreInfo) {
VmfsDatastoreInfo vdinfo = (VmfsDatastoreInfo) dsinfo;
vmfsdatastoreUUIDs.put(datastore.getName(), vdinfo
.getVmfs().getUuid());
}
}
System.out.print("]");
}
System.out.println(" ");
System.out.println("Datastore and its UUID");
for (Map.Entry< String , String> dsuuid : vmfsdatastoreUUIDs.entrySet()) {
System.out.println("[" + dsuuid.getKey() + "::" + dsuuid.getValue()
+ "]");
}
si.getServerConnection().logout();
}
示例12: listNodes
import com.vmware.vim25.mo.InventoryNavigator; //导入依赖的package包/类
private Iterable<VirtualMachine> listNodes(VSphereServiceInstance instance) {
Iterable<VirtualMachine> vms = ImmutableSet.of();
try {
Folder nodesFolder = instance.getInstance().getRootFolder();
ManagedEntity[] managedEntities = new InventoryNavigator(nodesFolder).searchManagedEntities("VirtualMachine");
vms = Iterables.transform(Arrays.asList(managedEntities), new Function<ManagedEntity, VirtualMachine>() {
public VirtualMachine apply(ManagedEntity input) {
return (VirtualMachine) input;
}
});
} catch (Throwable e) {
logger.error("Can't find vm", e);
}
return vms;
}
示例13: listNodesByIds
import com.vmware.vim25.mo.InventoryNavigator; //导入依赖的package包/类
@Override
public Iterable<VirtualMachine> listNodesByIds(Iterable<String> ids) {
Iterable<VirtualMachine> vms = ImmutableSet.of();
try (VSphereServiceInstance instance = serviceInstance.get();) {
Folder nodesFolder = instance.getInstance().getRootFolder();
List<List<String>> list = new ArrayList<List<String>>();
Iterator<String> idsIterator = ids.iterator();
while (idsIterator.hasNext()) {
list.add(Lists.newArrayList("VirtualMachine", idsIterator.next()));
}
String[][] typeInfo = ListsUtils.ListToArray(list);
ManagedEntity[] managedEntities = new InventoryNavigator(nodesFolder).searchManagedEntities(
typeInfo, true);
vms = Iterables.transform(Arrays.asList(managedEntities), new Function<ManagedEntity, VirtualMachine>() {
public VirtualMachine apply(ManagedEntity input) {
return (VirtualMachine) input;
}
});
} catch (Throwable e) {
logger.error("Can't find vms ", e);
}
return vms;
// Iterable<VirtualMachine> nodes = listNodes();
// Iterable<VirtualMachine> selectedNodes = Iterables.filter(nodes, VSpherePredicate.isNodeIdInList(ids));
// return selectedNodes;
}
示例14: getSystemHost
import com.vmware.vim25.mo.InventoryNavigator; //导入依赖的package包/类
private HostSystem getSystemHost() {
Iterable<HostSystem> hosts = ImmutableSet.<HostSystem>of();
try {
VSphereServiceInstance instance = serviceInstance.get();
ManagedEntity[] hostEntities = new InventoryNavigator(instance.getInstance().getRootFolder()).searchManagedEntities("HostSystem");
hosts = Iterables.transform(Arrays.asList(hostEntities), new Function<ManagedEntity, HostSystem>() {
public HostSystem apply(ManagedEntity input) {
return (HostSystem) input;
}
});
HostSystem curHostSystem = null;
long maxMemory = Integer.MIN_VALUE;
for (HostSystem hostSystem : hosts) {
int currentMemory = hostSystem.getSummary().getQuickStats().getOverallMemoryUsage();
long currentTotalMemory = hostSystem.getConfig().getSystemResources().getConfig().getMemoryAllocation().getLimit();
if (currentTotalMemory - currentMemory > maxMemory) {
curHostSystem = hostSystem;
maxMemory = currentTotalMemory - currentMemory;
}
}
return curHostSystem;
} catch (Exception e) {
logger.error("Problem in finding a valid host: " + e.toString(), e);
}
return null;
}
示例15: apply
import com.vmware.vim25.mo.InventoryNavigator; //导入依赖的package包/类
@Override
public Folder apply(final String folderName) {
try {
if (Strings.isNullOrEmpty(folderName))
return (Folder) master.getParent();
VSphereServiceInstance instance = serviceInstance.get();
ManagedEntity entity = new InventoryNavigator(instance.getInstance().getRootFolder()).searchManagedEntity("Folder", folderName);
return (Folder) entity;
} catch (Exception e) {
logger.error("Problem in finding a valid Folder with name " + folderName, e);
}
return (Folder) master.getParent();
}