Mark a module for update after setting its status to prevent race

conditions.

(cherry picked from commit ae6507390d)
This commit is contained in:
Ramon Novoa 2014-12-01 12:40:58 +01:00
parent e9fe321729
commit c236b32331
1 changed files with 12 additions and 6 deletions

View File

@ -1134,6 +1134,7 @@ sub pandora_process_module ($$$$$$$$$;$) {
my $last_known_status = $agent_status->{'last_known_status'};
my $last_error = defined ($module->{'last_error'}) ? $module->{'last_error'} : $agent_status->{'last_error'};
my $ff_start_utimestamp = $agent_status->{'ff_start_utimestamp'};
my $mark_for_update = 0;
# Get new status
my $new_status = get_module_status ($processed_data, $module, $module_type);
@ -1188,8 +1189,8 @@ sub pandora_process_module ($$$$$$$$$;$) {
$status = $new_status;
$last_status = $new_status;
# Update module status count
pandora_mark_agent_for_module_update ($dbh, $agent->{'id_agente'});
# Update module status count.
$mark_for_update = 1;
}
# Set not-init modules to normal status even if min_ff_event is not matched the first time they receive data.
# if critical or warning status, just pass through here and wait the time min_ff_event will be matched.
@ -1198,8 +1199,8 @@ sub pandora_process_module ($$$$$$$$$;$) {
$status = 0;
$last_status = $new_status;
# Update module status count
pandora_mark_agent_for_module_update ($dbh, $agent->{'id_agente'});
# Update module status count.
$mark_for_update = 1;
}
# If unknown modules receive data, restore status even if min_ff_event is not matched.
elsif ($status == 3) {
@ -1208,8 +1209,8 @@ sub pandora_process_module ($$$$$$$$$;$) {
generate_status_event ($pa_config, $processed_data, $agent, $module, $new_status, $status, $last_known_status, $dbh);
$status = $new_status;
# Update module status count
pandora_mark_agent_for_module_update ($dbh, $agent->{'id_agente'});
# Update module status count.
$mark_for_update = 1;
} else {
$last_status = $new_status;
}
@ -1254,6 +1255,11 @@ sub pandora_process_module ($$$$$$$$$;$) {
else {
logger($pa_config, "Alerts inhibited for agent '" . $agent->{'nombre'} . "'.", 10);
}
# Update module status count
if ($mark_for_update == 1) {
pandora_mark_agent_for_module_update ($dbh, $agent->{'id_agente'});
}
}
########################################################################