From 30ed3dbad5a177fcfa5f06cd3b9dbdbb409cc0c8 Mon Sep 17 00:00:00 2001 From: Ramon Novoa Date: Mon, 10 Aug 2015 16:46:10 +0200 Subject: [PATCH] Sort queued files before applying the one XML per agent limit. (cherry picked from commit e113c7e850bb8f1f89a40465b45eae39861b1ec1) --- pandora_server/lib/PandoraFMS/DataServer.pm | 53 ++++++++++++--------- 1 file changed, 31 insertions(+), 22 deletions(-) diff --git a/pandora_server/lib/PandoraFMS/DataServer.pm b/pandora_server/lib/PandoraFMS/DataServer.pm index f34c59a59d..95b89b0ed7 100644 --- a/pandora_server/lib/PandoraFMS/DataServer.pm +++ b/pandora_server/lib/PandoraFMS/DataServer.pm @@ -96,6 +96,7 @@ sub data_producer ($) { my @tasks; my @files; + my @sorted; # Open the incoming directory opendir (DIR, $pa_config->{'incomingdir'}) @@ -104,12 +105,37 @@ sub data_producer ($) { # Do not read more than max_queue_files files my $file_count = 0; while (my $file = readdir (DIR)) { - + # Data files must have the extension .data + next if ($file !~ /^.*[\._]\d+\.data$/); + + # Do not queue more than max_queue_files files + if ($file_count >= $pa_config->{"max_queue_files"}) { + last; + } + + push (@files, $file); + $file_count++; + } + closedir(DIR); + + # Sort the queue + { + # Temporarily disable warnings (some files may have been deleted) + no warnings; + if ($pa_config->{'dataserver_lifo'} == 0) { + @sorted = sort { -M $pa_config->{'incomingdir'} . "/$b" <=> -M $pa_config->{'incomingdir'} . "/$a" } (@files); + } else { + @sorted = sort { -M $pa_config->{'incomingdir'} . "/$a" <=> -M $pa_config->{'incomingdir'} . "/$b" } (@files); + } + } + + # Do not process more than one XML from the same agent at the same time + foreach my $file (@sorted) { + next if ($file !~ /^(.*)[\._]\d+\.data$/); - - # Do not process more than one XML from the same agent at the same time - my $agent_name = $1; + my $agent_name = $1; + $AgentSem->down (); if (defined ($Agents{$agent_name})) { $AgentSem->up (); @@ -118,24 +144,7 @@ sub data_producer ($) { $Agents{$agent_name} = 1; $AgentSem->up (); - push (@files, $file); - $file_count++; - - # Do not queue more than max_queue_files files - if ($file_count >= $pa_config->{"max_queue_files"}) { - last; - } - } - closedir(DIR); - - # Temporarily disable warnings (some files may have been deleted) - { - no warnings; - if ($pa_config->{'dataserver_lifo'} == 0) { - @tasks = sort { -C $pa_config->{'incomingdir'} . "/$b" <=> -C $pa_config->{'incomingdir'} . "/$a" } (@files); - } else { - @tasks = sort { -C $pa_config->{'incomingdir'} . "/$a" <=> -C $pa_config->{'incomingdir'} . "/$b" } (@files); - } + push (@tasks, $file); } return @tasks;