diff --git a/modules/Bio/EnsEMBL/Hive/Limiter.pm b/modules/Bio/EnsEMBL/Hive/Limiter.pm index f443146c1cba288d5c8638c6a9e3f05d56fee500..a1579cf746903a7a15936d6e33fa8347a38b4124 100644 --- a/modules/Bio/EnsEMBL/Hive/Limiter.pm +++ b/modules/Bio/EnsEMBL/Hive/Limiter.pm @@ -108,10 +108,12 @@ sub preliminary_offer { my $product = $available_capacity * $multiplier; my $slots_available = int( "$product" ); # stringification helps to round up things like 0.1*10 (instead of leaving them at 0.99999999) - return ($slots_available<$slots_asked) ? $slots_available : $slots_asked; + my $hit_the_limit = $slots_available<$slots_asked; + + return ($hit_the_limit ? $slots_available : $slots_asked , $hit_the_limit); } - return $slots_asked; + return ($slots_asked, 0); } diff --git a/modules/Bio/EnsEMBL/Hive/Scheduler.pm b/modules/Bio/EnsEMBL/Hive/Scheduler.pm index 754a295010a766e8c9e22c85c13d2b669da27d65..6f12a7e85e2a0c1c4208d8ffd1eed30c5fe8e219 100644 --- a/modules/Bio/EnsEMBL/Hive/Scheduler.pm +++ b/modules/Bio/EnsEMBL/Hive/Scheduler.pm @@ -261,15 +261,20 @@ sub schedule_workers { : (), ); + my $hit_the_limit; + # negotiations: foreach my $limiter (@limiters) { - $extra_workers_this_analysis = $limiter->preliminary_offer( $extra_workers_this_analysis ); - } - - # do not continue with this analysis if limiters haven't agreed on a positive number: - if ($extra_workers_this_analysis <= 0) { - push @$log_buffer, "Although Analysis '$logic_name' needed extra workers, it is being skipped because of activated limiters."; - next; + ($extra_workers_this_analysis, $hit_the_limit) = $limiter->preliminary_offer( $extra_workers_this_analysis ); + + if($hit_the_limit) { + if($extra_workers_this_analysis>0) { + push @$log_buffer, "Hit the limit of *** ".$limiter->description." ***, settling for $extra_workers_this_analysis Workers."; + } else { + push @$log_buffer, "Hit the limit of *** ".$limiter->description." ***, skipping this Analysis."; + next; + } + } } # let all parties know the final decision of negotiations: diff --git a/modules/Bio/EnsEMBL/Hive/Worker.pm b/modules/Bio/EnsEMBL/Hive/Worker.pm index 5b73c8743aaf6f95089a638917cf105e8a839108..ef750b083f7000c0a60dfaaada43a58e35fa020a 100644 --- a/modules/Bio/EnsEMBL/Hive/Worker.pm +++ b/modules/Bio/EnsEMBL/Hive/Worker.pm @@ -490,7 +490,8 @@ sub run { } else { my $desired_batch_size = $current_role->analysis->stats->get_or_estimate_batch_size(); - $desired_batch_size = $self->job_limiter->preliminary_offer( $desired_batch_size ); + my $hit_the_limit; # dummy at the moment + ($desired_batch_size, $hit_the_limit) = $self->job_limiter->preliminary_offer( $desired_batch_size ); my $actual_batch = $job_adaptor->grab_jobs_for_role( $current_role, $desired_batch_size ); if(scalar(@$actual_batch)) {