使用libvirt技术监控虚拟机资源利用情况

(一)计算资源与内存资源的监控

libvirt中提供virDomainGetInfo方法可以将一个domain的计算资源和内存资源的使用情况封装在一个结构体中,如下:

  1. struct virDomainInfo{
  2. unsigned char state : //the running state, one of virDomainState
  3. unsigned long maxMem :// the maximum memory in KBytes allowed
  4. unsigned long memory :// the memory in KBytes used by the domain
  5. unsigned short nrVirtCpu :// the number of virtual CPUs for the domain
  6. unsigned long long cpuTime : //the CPU time used in nanoseconds
  7. }

获取内存资源和计算资源监控信息并打印的方法如下:

  1. virDomainInfoPtr domaininfo;
  2. domaininfo = malloc(sizeof(virDomainInfo)* 1);
  3. m = virDomainGetInfo(allDomains[numOfDom] , domaininfo);
  4. printf("状态:%d    ",(*domaininfo).state);
  5. printf("最大内存:%ld    ",((*domaininfo).maxMem)/1024);
  6. printf("内存:%ld   ",((*domaininfo).memory)/1024);
  7. printf("虚拟cpu个数:%d   ",(*domaininfo).nrVirtCpu);
  8. printf("cpu时间:%lld   ",(*domaininfo).cpuTime);

libvirt中并不能直接获取到虚拟机的CPU使用率,但是可以通过CPUTIME来计算出实际使用率。计算的公式为:

首先得到一个周期差:cpu_time_diff = cpuTimenow — cpuTimet seconds ago

然后根据这个差值计算实际使用率:%CPU = 100 × cpu_time_diff / (t × nr_cores × 109)

cpuTime可以通过virDomainGetInfo(C)和virDomain::info()(Python)获得

#include <stdio.h>
#include <sys/time.h>
#include <libvirt/libvirt.h>
#include <libvirt/virterror.h> int main(int argc, char ** argv) {
virConnectPtr conn = virConnectOpen("qemu:///system");
if(conn == NULL) {
printf("error connecting qemu driver\n");
exit(1);
}
virDomainPtr vm_ptr = virDomainLookupByName(conn, "1");
if(vm_ptr == NULL) {
printf("error finding domain\n");
virConnectClose(conn);
exit(1);
}
virDomainInfo info_s,info_e;
struct timeval real_time_s, real_time_e;
int cpu_diff, real_diff;
float usage;
while(true){
if(virDomainGetInfo(vm_ptr, &info_s) !=0) {
printf("error get domain info\n");
virDomainFree(vm_ptr);
virConnectClose(conn);
exit(1);
} if(gettimeofday(&real_time_s, NULL) == -1) {
printf("error get time of day\n");
virDomainFree(vm_ptr);
virConnectClose(conn);
exit(1);
} sleep(1); if(virDomainGetInfo(vm_ptr, &info_e) !=0) {
printf("error get domain info\n");
virDomainFree(vm_ptr);
virConnectClose(conn);
exit(1);
} if(gettimeofday(&real_time_e, NULL) == -1) {
printf("error get time of day\n");
virDomainFree(vm_ptr);
virConnectClose(conn);
exit(1);
}//转换成微秒
cpu_diff = (info_e.cpuTime - info_s.cpuTime) / 1000;
//转换成微秒
real_diff = 1000000 * (real_time_e.tv_sec - real_time_s.tv_sec) +
(real_time_e.tv_usec - real_time_s.tv_usec);
//是否要考虑多核的情况?
usage = cpu_diff / (float) (real_diff);
printf("cpu_diff:%d, real_diff:%d, cpu usage:%f\n", cpu_diff, real_diff, usage);
}
virDomainFree(vm_ptr);
virConnectClose(conn);
return 0;
#include <stdio.h>
#include <sys/time.h>
#include <libvirt/libvirt.h>
#include <libvirt/virterror.h> int main(int argc, char ** argv) {
virConnectPtr conn = virConnectOpen("qemu:///system");
if(conn == NULL) {
printf("error connecting qemu driver\n");
exit(1);
}
virDomainPtr vm_ptr = virDomainLookupByName(conn, "1");
if(vm_ptr == NULL) {
printf("error finding domain\n");
virConnectClose(conn);
exit(1);
} virTypedParameter par_s, par_e;
struct timeval real_time_s, real_time_e; int cpu_diff, real_diff;
float usage; while(true){
if(gettimeofday(&real_time_s, NULL) == -1) {
printf("error get time of day\n");
virDomainFree(vm_ptr);
virConnectClose(conn);
exit(1);
}
virDomainGetCPUStats(vm_ptr, &par_s, 1, -1, 1, 0);
sleep(1);
if(gettimeofday(&real_time_e, NULL) == -1) {
printf("error get time of day\n");
virDomainFree(vm_ptr);
virConnectClose(conn);
exit(1);
virDomainGetCPUStats(vm_ptr, &par_e, 1, -1, 1, 0);
cpu_diff = (par_e.value.ul - par_s.value.ul) / 1000;
real_diff = 1000000 * (real_time_e.tv_sec - real_time_s.tv_sec) +
(real_time_e.tv_usec - real_time_s.tv_usec);
usage = cpu_diff / (float)(real_diff);
printf("cpu_diff:%d, real_diff:%d, cpu usage:%f\n", cpu_diff, real_diff, usage); }
virDomainFree(vm_ptr);
virConnectClose(conn);
return 0;
}

这两个接口的结果差不多,利用率与top命令输出一致,但是与虚拟机内部使用率不一致。如将结果除以vcpu个数,则cpu利用率更接近虚拟机内部的虚拟机使用率。

对于memory利用率,windows需要安装 virtio memory balloon drivers for Windows guests,这样 memory/MaxMemory就是正确的内存利用率。如果不安装,那么这个比例始终为1。

(二)获得网络流量信息

可以使用 virDomainInterfaceStats方法,将一个domain的网络流量信息封装在一个virDomainInterfaceStatsStruct结构体中,该方法需要传递一个虚拟网卡接口的参数,这个参数可以通过XML文件取得:

<interface type='bridge'>
      <mac address='00:16:3e:74:03:53'/>
      <source bridge='xenbr0'/>
      <script path='vif-bridge'/>
      <target dev='vif1.0 '/>          /*这个就是需要的参数*/
    </interface>

具体代码如下:

    1. virDomainInterfaceStatsPtr interfacestats;
    2. interfacestats = malloc(sizeof(virDomainInterfaceStatsStruct)* 10);
    3. m = virDomainInterfaceStats(allDomains[numOfDom], i_path, interfacestats, 10);
    4. printf("rx字节数:%ld    ",(*interfacestats).rx_bytes);
    5. printf("tx字节数:%ld    ",(*interfacestats).tx_bytes);
    6. printf("rx丢包:%ld    ",(*interfacestats).rx_drop);
    7. printf("tx丢包:%ld\n",(*interfacestats).tx_drop);

使用libvirt技术监控虚拟机资源利用情况的更多相关文章

  1. 【转载】阿里云ECS服务器监控资源使用情况

    在阿里云Ecs服务器运维过程中,无论是Centos系统还是Windows系统,有时候我们需要监控分析最新的服务器资源利用率等运行情况,例如最近3个小时CPU使用率情况.内存使用率.网络流入带宽.网络流 ...

  2. 深入理解Java虚拟机-如何利用VisualVM对高并发项目进行性能分析

    前面在学习JVM的知识的时候,一般都需要利用相关参数进行分析,而分析一般都需要用到一些分析的工具,因为一般使用IDEA,而VisualVM对于IDEA也不错,所以就选择VisualVM来分析JVM性能 ...

  3. 第15章: Prometheus监控Kubernetes资源与应用

    Prometheus监控Kubernetes资源与应用 目录 1 监控方案 2 2 监控指标 4 3 实现思路 4 4 在K8S中部署Prometheus 4 5 在K8S中部署Grafana与可视化 ...

  4. 使用visualVM 1.3.8(visualvm_138-ml.zip) 监控远程Tomcat运行情况

    服务端CentOS6.4 x64安装的是jdk1.7 下载visualVM1.3.8-ml 也就是多语言版本,包含中文,界面用起来方便.官方下载地址比较慢,百度上搜索的都是csdn,51cto等必须登 ...

  5. WCF技术剖析之五:利用ASP.NET兼容模式创建支持会话(Session)的WCF服务

    原文:WCF技术剖析之五:利用ASP.NET兼容模式创建支持会话(Session)的WCF服务 在<基于IIS的WCF服务寄宿(Hosting)实现揭秘>中,我们谈到在采用基于IIS(或者 ...

  6. docker stats监控容器资源消耗

    在容器的使用过程中,如果能及时的掌握容器使用的系统资源,无论对开发还是运维工作都是非常有益的.幸运的是 docker 自己就提供了这样的命令:docker stats. 默认输出 docker sta ...

  7. libvirt工具实现虚拟机管理

    libvirt工具实现虚拟机管理 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.介绍virt-install命令的常用参数 virt-install是一个命令行工具,它能够为K ...

  8. Prometheus 监控K8S 资源状态对象

    Prometheus 监控K8S 资源状态对象 官方文档:https://github.com/kubernetes/kube-state-metrics kube-state-metrics是一个简 ...

  9. COW技术重置虚拟机

    最近使用COW技术做虚拟机重置,结果成功了,特地来给大家分享一下这次的成果! 文章目录 一.COW技术是什么? 二.重置虚拟机步骤 总结 往期杂文 一.COW技术是什么? Copy On Write, ...

随机推荐

  1. odoo小数精确度

    python round() 函数     Python用于四舍五入的内建函数round() ,它的定义为 意思是, 将 小数部分保留到 ndigits 指定的 小数位,也就是 精度保持到 ndigi ...

  2. Web框架Django(一)

    Python的WEB框架有Django.Tornado.Flask 等多种,Django相较与其他WEB框架其优势为:大而全,框架本身集成了ORM.模型绑定.模板引擎.缓存.Session等诸多功能. ...

  3. Google架构学习

    http://hideto.iteye.com/blog/130815 原文:Google Architecture Google是伸缩性的王者.Google一直的目标就是构建高性能高伸缩性的基础组织 ...

  4. Layout规则总结

    一.尺寸要求 1.过孔到焊盘的距离多少合适? 6mil左右 2.铜皮到边框的距离多少合适? 极限8mil,通常12,最好做到20,40 3.Thermal焊盘打地孔个数? 正方形 3*3  4*4   ...

  5. Ubuntu16.04 下docker部署web项目

    概念性的请戳 第一步:更新apt-get update 第二步:安装环境 apt-get install \ apt-transport-https \ ca-certificates \ curl ...

  6. Python--数据类型整理

      数据类型整理-------------------------------------------------------------------------------------------- ...

  7. Learning English From Android Source Code:2 Ampersand

    这一次想把标点符号的英语表达总结一下,这些单词非常重要但easy被我们忽视.以我的经验,还是多认识几个.以备不时之需. 以下从"标点符号"開始: punctuation [英][ˌ ...

  8. 何时使用Entity或DTO

    关注公众号: 锅外的大佬 每日推送国外优秀的技术翻译文章,励志帮助国内的开发者更好地成长! JPA和Hibernate允许你在JPQL和Criteria查询中使用DTO和Entity作为映射.当我在我 ...

  9. h5的复制功能

    js+html5实现复制文字按钮 <div> <input type="text" name="guanfangaddress" id=&qu ...

  10. 基于TCP的一对回射客户/服务器程序及其运行过程分析( 下 )

    执行分析 1. 打开服务器进程: 2. 执行netstat -a命令观察当前的连接状态: 第1条连接记录说明:绑定了本地主机的任意IP,端口为9877,目前处于监听状态. 3. 打开客户进程: 4. ...