[libvirt] [PATCHv2 5/6] virNodeGetCPUTime: Implement virsh support

Minoru Usui usui at mxm.nes.nec.co.jp
Wed Apr 27 05:09:36 UTC 2011


On Tue, 19 Apr 2011 12:01:34 +0100
"Daniel P. Berrange" <berrange at redhat.com> wrote:

> On Fri, Apr 08, 2011 at 08:36:52PM +0900, Minoru Usui wrote:
> > virNodeGetCPUTime: Implement virsh support
> > 
> > Add nodecputime subcommand to virsh.
> > This subcommand prints below output.
> > 
> > [Linux]
> >   # build/tools/virsh nodecputime
> >   usage:            2.8%
> >     user  :         0.8%
> >     system:         1.9%
> >     idle  :        97.2%
> >     iowait:         0.0%
> > 
> > [can get cpu utilization directly(ESX?)]
> >   # build/tools/virsh nodecputime
> >   usage:            2.8%
> > 
> > Signed-off-by: Minoru Usui <usui at mxm.nes.nec.co.jp>
> > ---
> >  tools/virsh.c   |   96 +++++++++++++++++++++++++++++++++++++++++++++++++++++++
> >  tools/virsh.pod |    4 ++
> >  2 files changed, 100 insertions(+), 0 deletions(-)
> > 
> > diff --git a/tools/virsh.c b/tools/virsh.c
> > index 19e3449..93288ba 100644
> > --- a/tools/virsh.c
> > +++ b/tools/virsh.c
> > @@ -3388,6 +3388,101 @@ cmdNodeinfo(vshControl *ctl, const vshCmd *cmd ATTRIBUTE_UNUSED)
> >  }
> >  
> >  /*
> > + * "nodecputime" command
> > + */
> > +static const vshCmdInfo info_nodecputime[] = {
> > +    {"help", N_("Prints cpu utilizatoin of the node.")},
> > +    {"desc", N_("Returns cpu utilizatoin of the node.(%)")},
> > +    {NULL, NULL}
> > +};
> > +
> > +static int
> > +cmdNodeCpuTime(vshControl *ctl, const vshCmd *cmd ATTRIBUTE_UNUSED)
> > +{
> > +    int i, j;
> > +    int flag_utilization = FALSE;
> > +    virNodeCpuTime stats[VIR_NODE_CPU_TIME_NR];
> > +    int nr_stats;
> > +    struct cpu_time {
> > +        unsigned long long user;
> > +        unsigned long long sys;
> > +        unsigned long long idle;
> > +        unsigned long long iowait;
> > +        unsigned long long util;
> > +    } cpu_time[2];
> > +    double user_time, sys_time, idle_time, iowait_time, total_time;
> > +    double usage;
> > +
> > +    if (!vshConnectionUsability(ctl, ctl->conn))
> > +        return FALSE;
> > +
> > +    memset(cpu_time, 0, sizeof(struct cpu_time) * 2);
> > +
> > +    for (i = 0; i < 2; i++) {
> > +        memset(stats, 0, sizeof(virNodeCpuTime) * VIR_NODE_CPU_TIME_NR);
> > +        nr_stats = virNodeGetCpuTime(ctl->conn, &stats[0],
> > +                                     VIR_NODE_CPU_TIME_NR, 0);
> > +        if (nr_stats < 0) {
> > +            vshError(ctl, "%s", _("failed to get cpu time of the node."));
> > +            return FALSE;
> > +        }
> > +
> > +        for (j = 0; j < nr_stats; j++) {
> > +            switch (stats[j].tag) {
> > +            case VIR_NODE_CPU_TIME_KERNEL:
> > +                cpu_time[i].sys = stats[j].val;
> > +                break;
> > +            case VIR_NODE_CPU_TIME_USER:
> > +                cpu_time[i].user = stats[j].val;
> > +                break;
> > +            case VIR_NODE_CPU_TIME_IDLE:
> > +                cpu_time[i].idle = stats[j].val;
> > +                break;
> > +            case VIR_NODE_CPU_TIME_IOWAIT:
> > +                cpu_time[i].iowait = stats[j].val;
> > +                break;
> > +            case VIR_NODE_CPU_TIME_UTILIZATION:
> > +                flag_utilization = TRUE;
> > +                cpu_time[i].util = stats[j].val;
> > +                break;
> > +            case VIR_NODE_CPU_TIME_NR:
> > +            default:
> > +                break;
> > +            }
> > +        }
> > +
> > +        sleep(1);
> > +    }
> 
> I'm not sure about this bit. In other places in virsh, we just report
> the absolute CPU time value, and don't try to calculate the deltas.
> There is a virt-top program that might like to use this data to provide
> a continuous display of utilization.

Matthias said, ESX cannot get absolute CPU time.
It just get CPU percentage.

  http://www.mail-archive.com/libvir-list@redhat.com/msg35769.html

And I think CPU percentage is very useful for user.
The user don't care about absolute CPU time value.
They want to know about CPU load of each host.

So I wrote this specification.
 
> Alternatively, we could add an arg for this to request that it calculate
> delta over 'n' seconds.

I agree. It's very userful. 
But ESX cannot change interval, perhaps.

> Daniel
> -- 
> |: http://berrange.com      -o-    http://www.flickr.com/photos/dberrange/ :|
> |: http://libvirt.org              -o-             http://virt-manager.org :|
> |: http://autobuild.org       -o-         http://search.cpan.org/~danberr/ :|
> |: http://entangle-photo.org       -o-       http://live.gnome.org/gtk-vnc :|


-- 
Minoru Usui <usui at mxm.nes.nec.co.jp>




More information about the libvir-list mailing list