libvirt是一个用于管理虚拟化平台的开源工具包,提供了对不同虚拟化技术(如KVM、QEMU、Xen等)的统一管理接口。在libvirt中,Domain
类表示虚拟机(domain)对象,并提供了丰富的方法来管理虚拟机的各个方面。在本篇博客中,我们将介绍Domain
类的一些主要方法,帮助开发人员更好地理解如何使用libvirt来管理虚拟机。
abortJob()
该方法用于请求在最早的机会中中止当前后台作业。后台作业通常是一些长时间运行的任务,例如磁盘复制。
int abortJob()
addAgentLifecycleListener(AgentLifecycleListener cb)
添加一个用于接收代理生命周期事件的监听器。代理是与虚拟机内部通信的一种机制,此方法允许开发人员监测代理的生命周期事件。
void addAgentLifecycleListener(AgentLifecycleListener cb)
addBlockJobListener(BlockJobListener cb)
添加一个回调以接收块作业事件的通知。块作业是虚拟机磁盘相关的一些操作,例如复制、移动等。
void addBlockJobListener(BlockJobListener cb)
addIOErrorListener(IOErrorListener cb)
添加一个回调以接收IO错误事件的通知。这可以帮助开发人员监测虚拟机上发生的IO错误。
void addIOErrorListener(IOErrorListener cb)
addLifecycleListener(LifecycleListener l)
添加一个用于接收虚拟机生命周期事件的监听器。这些事件包括虚拟机的创建、销毁、暂停、继续等。
void addLifecycleListener(LifecycleListener l)
addPMSuspendListener(PMSuspendListener l)
添加一个用于接收虚拟机电源管理(PM)挂起事件的监听器。PM事件涉及到虚拟机的挂起和恢复。
void addPMSuspendListener(PMSuspendListener l)
addPMWakeupListener(PMWakeupListener l)
添加一个用于接收虚拟机电源管理(PM)唤醒事件的监听器。PM事件涉及到虚拟机的挂起和恢复。
void addPMWakeupListener(PMWakeupListener l)
addRebootListener(RebootListener l)
添加一个用于接收虚拟机重启事件的监听器。该方法允许开发人员监测虚拟机的重启操作。
void addRebootListener(RebootListener l)
attachDevice(String xmlDesc)
创建虚拟设备附加到后端。通过该方法,可以将新的虚拟设备附加到虚拟机。
void attachDevice(String xmlDesc)
attachDeviceFlags(String xmlDesc, int flags)
创建虚拟设备附加到后端,可以指定附加设备的标志。
void attachDeviceFlags(String xmlDesc, int flags)
blockCommit(String disk, String base, String top, long bandwidth, int flags)
将对磁盘镜像的临时更改提交到较低级别的基础文件。通常用于虚拟机磁盘的快照和回滚操作。
void blockCommit(String disk, String base, String top, long bandwidth, int flags)
blockCopy(String diskPath, String xmlDesc, TypedParameter[] params, int flags)
将虚拟机的生活块设备(磁盘)迁移到另一个块设备。通常用于在线迁移虚拟机磁盘。
void blockCopy(String diskPath, String xmlDesc, TypedParameter[] params, int flags)
blockInfo(String path)
获取连接到该虚拟机的块设备(磁盘)的统计信息。
DomainBlockInfo blockInfo(String path)
blockJobAbort(String disk, int flags)
取消给定磁盘上的活动块作业。
void blockJobAbort(String disk, int flags)
blockPeek(String disk, long offset, ByteBuffer buffer)
读取虚拟机磁盘设备的内容。
void blockPeek(String disk, long offset, ByteBuffer buffer)
blockResize(String disk, long size, int flags)
在虚拟机运行时调整磁盘设备的大小。
void blockResize(String disk, long size, int flags)
blockStats(String path)
获取连接到该虚拟机的块设备(磁盘)的统计信息。
DomainBlockStats blockStats(String path)
coreDump(String to, int flags)
将虚拟机的核心转储到指定文件以供分析。
void coreDump(String to, int flags)
cpuMapLength(int maxCpus)
获取存储单个虚拟CPU与所有物理CPU之间完整CPU映射所需的长度。
int cpuMapLength(int maxCpus)
create()
启动该虚拟机。这个方法用于启动之前已经定义的虚拟机。
int create()
create(int flags)
启动该虚拟机,并可以提供一些启动标志。
int create(int flags)
destroy()
销毁虚拟机对象。这个方法停止虚拟机,并且虚拟机对象之后仍然可用。
void destroy()
detachDevice(String xmlDesc)
销毁虚拟机的虚拟设
备附加到后端。
void detachDevice(String xmlDesc)
detachDeviceFlags(String xmlDesc, int flags)
销毁虚拟机的虚拟设备附加到后端,可以指定附加设备的标志。
void detachDeviceFlags(String xmlDesc, int flags)
equals(Object obj)
判断两个虚拟机对象是否相等。
boolean equals(Object obj)
finalize()
虚拟机对象的垃圾回收方法。
protected void finalize()
free()
释放虚拟机对象。
int free()
getAutostart()
获取虚拟机是否配置为在主机启动时自动启动。
boolean getAutostart()
getBlockJobInfo(String disk, int flags)
获取给定磁盘的块作业信息。
DomainBlockJobInfo getBlockJobInfo(String disk, int flags)
getConnect()
获取与虚拟机关联的连接对象。
Connect getConnect()
getID()
获取虚拟机的超级用户ID号。
int getID()
getInfo()
提取关于虚拟机的信息,如状态、内存使用等。
DomainInfo getInfo()
getJobInfo()
提取关于虚拟机后台作业进度的信息。
DomainJobInfo getJobInfo()
getMaxMemory()
获取分配给虚拟机的最大物理内存。
long getMaxMemory()
getMaxVcpus()
获取支持的虚拟CPU的最大数量。
int getMaxVcpus()
getMetadata(int type, String uri, int flags)
检索给定类型的域元素。域元素可以包括描述、注释等。
String getMetadata(int type, String uri, int flags)
getName()
获取虚拟机的公共名称。
String getName()
getOSType()
获取虚拟机操作系统的类型。
String getOSType()
getSchedulerParameters()
获取调度器参数。
SchedParameter[] getSchedulerParameters()
getSchedulerType()
获取调度器类型。
String getSchedulerType()
getSecurityLabel()
获取虚拟机的安全标签。
SecurityLabel getSecurityLabel()
getUUID()
获取虚拟机的UUID。
int[] getUUID()
getUUIDString()
获取虚拟机的UUID,并以字符串形式返回。
String getUUIDString()
getVcpusCpuMaps()
获取虚拟机的虚拟CPU与物理CPU的映射。
int[] getVcpusCpuMaps()
getVcpusInfo()
提取虚拟机的虚拟CPU信息。
VcpuInfo[] getVcpusInfo()
getXMLDesc(int flags)
提供虚拟机的XML描述。
String getXMLDesc(int flags)
解libvirt中Domain类的方法2:https://developer.aliyun.com/article/1552405