(plugin) cloud::cadvisor::restapi - mode container-usage fix uninitia… (#4667)

This commit is contained in:
qgarnier 2023-09-27 16:22:29 +02:00 committed by GitHub
parent 5863ac7671
commit aa45bfa7ff
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 24 additions and 7 deletions

View File

@ -111,11 +111,13 @@ sub get_port {
sub internal_api_list_nodes { sub internal_api_list_nodes {
my ($self, %options) = @_; my ($self, %options) = @_;
my $response = $self->{http}->request( my $response = $self->{http}->request(
hostname => $options{node_name}, hostname => $options{node_name},
url_path => '/api/' . $self->{option_results}->{api_version} . $self->{option_results}->{api_path}, url_path => '/api/' . $self->{option_results}->{api_version} . $self->{option_results}->{api_path},
unknown_status => '', critical_status => '', warning_status => ''); unknown_status => '', critical_status => '', warning_status => ''
);
my $nodes; my $nodes;
eval { eval {
$nodes = JSON::XS->new->utf8->decode($response); $nodes = JSON::XS->new->utf8->decode($response);
@ -139,7 +141,9 @@ sub internal_api_info {
my $response = $self->{http}->request( my $response = $self->{http}->request(
hostname => $options{node_name}, hostname => $options{node_name},
url_path => '/api/' . $self->{option_results}->{api_version} . '/machine/', url_path => '/api/' . $self->{option_results}->{api_version} . '/machine/',
unknown_status => '', critical_status => '', warning_status => ''); unknown_status => '', critical_status => '', warning_status => ''
);
my $nodes; my $nodes;
eval { eval {
$nodes = JSON::XS->new->utf8->decode($response); $nodes = JSON::XS->new->utf8->decode($response);
@ -157,12 +161,13 @@ sub internal_api_info {
sub internal_api_list_containers { sub internal_api_list_containers {
my ($self, %options) = @_; my ($self, %options) = @_;
my $response = $self->{http}->request( my $response = $self->{http}->request(
hostname => $options{node_name}, hostname => $options{node_name},
url_path => '/api/' . $self->{option_results}->{api_version} . $self->{option_results}->{api_path}, url_path => '/api/' . $self->{option_results}->{api_version} . $self->{option_results}->{api_path},
unknown_status => '', critical_status => '', warning_status => '' unknown_status => '', critical_status => '', warning_status => ''
); );
my $containers = []; my $containers = [];
my $containers_ids; my $containers_ids;
eval { eval {
@ -209,10 +214,13 @@ sub internal_api_list_containers {
sub internal_api_get_machine_stats { sub internal_api_get_machine_stats {
my ($self, %options) = @_; my ($self, %options) = @_;
my $response = $self->{http}->request( my $response = $self->{http}->request(
hostname => $options{node_name}, hostname => $options{node_name},
url_path => '/api/' . $self->{option_results}->{api_version} . '/machine', url_path => '/api/' . $self->{option_results}->{api_version} . '/machine',
unknown_status => '', critical_status => '', warning_status => ''); unknown_status => '', critical_status => '', warning_status => ''
);
my $machine_stats; my $machine_stats;
my $full_machine_stats; my $full_machine_stats;
eval { eval {
@ -239,6 +247,7 @@ sub internal_api_get_container_stats {
url_path => '/api/' . $self->{option_results}->{api_version} . $self->{option_results}->{api_path} . '/' . $options{container_id}, url_path => '/api/' . $self->{option_results}->{api_version} . $self->{option_results}->{api_path} . '/' . $options{container_id},
unknown_status => '', critical_status => '', warning_status => '' unknown_status => '', critical_status => '', warning_status => ''
); );
my $container_stats; my $container_stats;
my $full_container_stats; my $full_container_stats;
eval { eval {
@ -251,8 +260,15 @@ sub internal_api_get_container_stats {
short_msg => "Node '$options{node_name}': cannot decode json get container stats response: $@" short_msg => "Node '$options{node_name}': cannot decode json get container stats response: $@"
); );
} else { } else {
$container_stats->[0] = $full_container_stats->{stats}[0]; my $stats;
$container_stats->[1] = $full_container_stats->{stats}[scalar(@{$full_container_stats->{stats}}) - 1]; if (defined($full_container_stats->{stats})) {
$stats = $full_container_stats->{stats};
} else {
my @keys = keys(%$full_container_stats);
$stats = $full_container_stats->{ $keys[0] }->{stats};
}
$container_stats->[0] = $stats->[0];
$container_stats->[1] = $stats->[scalar(@$stats) - 1];
} }
return $container_stats; return $container_stats;
} }

View File

@ -156,6 +156,7 @@ sub manage_selection {
$self->{output}->output_add(long_msg => "skipping '" . $name . "': no matching filter.", debug => 1); $self->{output}->output_add(long_msg => "skipping '" . $name . "': no matching filter.", debug => 1);
next; next;
} }
my $first_index = 0; my $first_index = 0;
my $first_stat = $result->{$container_id}->{Stats}[$first_index]; my $first_stat = $result->{$container_id}->{Stats}[$first_index];
my $first_ts = $first_stat->{timestamp}; my $first_ts = $first_stat->{timestamp};