fixes for race conditions and dupes in job queue

we had situations where the manager would start workers on the same job,
either because of race conditions or because at the time of queueing it wasn't
known that the jobs were targeting the same device (due to device aliases).

this commit removes duplicate jobs, reduces the need for locking on the job
queue, and makes use of lldpRemChassisId to try to deduplicate jobs before
they are started. in effect we have several goes to prevent duplicate jobs:

1. at neighbor discovery time we try to skip queueing same lldpRemChassisId
2. at job selection we 'error out' jobs with same profile as job selected
3. at job selection we check for running job with same profile as selected
4. the job manager process also checks for duplicate job profiles
5. at job lock we abort if the job was 'errored out'

all together this seems to work well. a test on a large university network of
303 devices (four core routers and the rest edge routers, runing VRF with many
duplicate identities), ~1200 subnets, ~50k hosts, resulted in no DB deadlock
or contention and a complete discover+arpnip+macsuck (909 jobs) in ~3 minutes
(with ~150 duplicate jobs identified and skipped).
This commit is contained in:
Oliver Gorwits
2017-11-23 19:23:55 +00:00
parent 1bbe8c9164
commit 0bb15f36b9
10 changed files with 166 additions and 114 deletions

View File

@@ -238,6 +238,7 @@ sub renumber {
if $new_ip eq '0.0.0.0'
or $new_ip eq '127.0.0.1';
# Community is not included as SNMP::test_connection will take care of it
foreach my $set (qw/
DeviceIp
DeviceModule
@@ -259,10 +260,6 @@ sub renumber {
->search({remote_ip => $old_ip})
->update({remote_ip => $new_ip});
$schema->resultset('Admin')
->search({device => $old_ip})
->update({device => $new_ip});
$schema->resultset('Node')
->search({switch => $old_ip})
->update({switch => $new_ip});