| 8 | rodolico | 1 | #!/usr/bin/env perl
 | 
        
           |  |  | 2 |   | 
        
           |  |  | 3 | # All functions related to maniplating/reporting on cluster
 | 
        
           |  |  | 4 | # part of havirt.
 | 
        
           |  |  | 5 |   | 
        
           |  |  | 6 | # Copyright 2024 Daily Data, Inc.
 | 
        
           |  |  | 7 | # 
 | 
        
           |  |  | 8 | # Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following 
 | 
        
           |  |  | 9 | # conditions are met:
 | 
        
           |  |  | 10 | #
 | 
        
           |  |  | 11 | #   Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer.
 | 
        
           |  |  | 12 | #   Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimer 
 | 
        
           |  |  | 13 | #   in the documentation and/or other materials provided with the distribution.
 | 
        
           |  |  | 14 | #   Neither the name of the copyright holder nor the names of its contributors may be used to endorse or promote products derived
 | 
        
           |  |  | 15 | #   from this software without specific prior written permission.
 | 
        
           |  |  | 16 | # 
 | 
        
           |  |  | 17 | # THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT
 | 
        
           |  |  | 18 | # NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL
 | 
        
           |  |  | 19 | # THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
 | 
        
           |  |  | 20 | # (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
 | 
        
           |  |  | 21 | # INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE
 | 
        
           |  |  | 22 | # OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
 | 
        
           |  |  | 23 |   | 
        
           |  |  | 24 | # v0.0.1 20240602 RWR
 | 
        
           |  |  | 25 | # Initial setup
 | 
        
           |  |  | 26 |   | 
        
           |  |  | 27 | package cluster;
 | 
        
           |  |  | 28 |   | 
        
           |  |  | 29 | use warnings;
 | 
        
           |  |  | 30 | use strict;  
 | 
        
           |  |  | 31 |   | 
        
           |  |  | 32 | # define the version number
 | 
        
           |  |  | 33 | # see https://metacpan.org/pod/release/JPEACOCK/version-0.97/lib/version.pod
 | 
        
           |  |  | 34 | use version;
 | 
        
           |  |  | 35 | our $VERSION = version->declare("0.0.1");
 | 
        
           |  |  | 36 |   | 
        
           |  |  | 37 |   | 
        
           |  |  | 38 | use Data::Dumper;
 | 
        
           |  |  | 39 |   | 
        
           |  |  | 40 | use Exporter;
 | 
        
           |  |  | 41 |   | 
        
           |  |  | 42 | our @ISA = qw( Exporter );
 | 
        
           |  |  | 43 | our @EXPORT = qw( 
 | 
        
           |  |  | 44 |                   &list
 | 
        
           |  |  | 45 |                 );
 | 
        
           |  |  | 46 |   | 
        
           | 10 | rodolico | 47 | sub status {
 | 
        
           |  |  | 48 |    my $return = '';
 | 
        
           |  |  | 49 |    &main::loadVirtDB();
 | 
        
           |  |  | 50 |    &main::loadNodePopulations();
 | 
        
           |  |  | 51 |    &main::loadNodeDB();
 | 
        
           |  |  | 52 |    my @header = ('Node','Threads','Memory','Domains','vcpu','mem_used' );
 | 
        
           |  |  | 53 |    my @data;
 | 
        
           |  |  | 54 |    my $usedmem = 0;
 | 
        
           |  |  | 55 |    my $usedcpu = 0;
 | 
        
           |  |  | 56 |    my $availmem = 0;
 | 
        
           |  |  | 57 |    my $availcpu = 0;
 | 
        
           |  |  | 58 |    my $totalDomains = 0;
 | 
        
           |  |  | 59 |    foreach my $node (sort keys %$main::nodeDB ) {
 | 
        
           |  |  | 60 |       my $memory = 0;
 | 
        
           |  |  | 61 |       my $vcpus = 0;
 | 
        
           |  |  | 62 |       my $count = 0;
 | 
        
           |  |  | 63 |       foreach my $domain ( keys %{ $main::nodePopulations->{$node}->{'running'} } ) {
 | 
        
           |  |  | 64 |          $memory += $main::virtDB->{$domain}->{'memory'};
 | 
        
           |  |  | 65 |          $vcpus += $main::virtDB->{$domain}->{'vcpu'};
 | 
        
           |  |  | 66 |          $count++;
 | 
        
           |  |  | 67 |       }
 | 
        
           |  |  | 68 |       push @data, [ $node,$main::nodeDB->{$node}->{cpu_count},$main::nodeDB->{$node}->{memory},$count,$vcpus,$memory ];
 | 
        
           |  |  | 69 |       $usedmem += $memory;
 | 
        
           |  |  | 70 |       $usedcpu += $vcpus;
 | 
        
           |  |  | 71 |       $totalDomains += $count;
 | 
        
           |  |  | 72 |       $availmem += $main::nodeDB->{$node}->{memory};
 | 
        
           |  |  | 73 |       $availcpu += $main::nodeDB->{$node}->{cpu_count};
 | 
        
           |  |  | 74 |    } # outer for
 | 
        
           |  |  | 75 |    push @data, [ 'Total',$availcpu,$availmem,$totalDomains,$usedcpu,$usedmem ];
 | 
        
           |  |  | 76 |    return &main::report( \@header, \@data );
 | 
        
           |  |  | 77 | }
 |