Skip 3 expensive calls for jobs saving in 'waiting' status on UnifiedJob#15174
Merged
Conversation
1130e34 to
03530c8
Compare
by not looking up "status_before" from previous instance we save 2 to 3 expensive calls (the self lookup of old state, the lookup of parent, and the update to parent if allow_simultaneous == False)
03530c8 to
3a029c3
Compare
chrismeyersfsu
approved these changes
May 9, 2024
AlanCoding
approved these changes
May 10, 2024
djyasin
pushed a commit
to djyasin/awx
that referenced
this pull request
Sep 16, 2024
…Job (ansible#15174) skip update parent logic for 'waiting' on UnifiedJob by not looking up "status_before" from previous instance we save 2 to 3 expensive calls (the self lookup of old state, the lookup of parent, and the update to parent if allow_simultaneous == False or status == 'waiting')
djyasin
pushed a commit
to djyasin/awx
that referenced
this pull request
Nov 11, 2024
…Job (ansible#15174) skip update parent logic for 'waiting' on UnifiedJob by not looking up "status_before" from previous instance we save 2 to 3 expensive calls (the self lookup of old state, the lookup of parent, and the update to parent if allow_simultaneous == False or status == 'waiting')
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Add this suggestion to a batch that can be applied as a single commit.This suggestion is invalid because no changes were made to the code.Suggestions cannot be applied while the pull request is closed.Suggestions cannot be applied while viewing a subset of changes.Only one suggestion per line can be applied in a batch.Add this suggestion to a batch that can be applied as a single commit.Applying suggestions on deleted lines is not supported.You must change the existing code in this line in order to create a valid suggestion.Outdated suggestions cannot be applied.This suggestion has been applied or marked resolved.Suggestions cannot be applied from pending reviews.Suggestions cannot be applied on multi-line comments.Suggestions cannot be applied while the pull request is queued to merge.Suggestion cannot be applied right now. Please check back later.
SUMMARY
Alternative to #15171
@AlanCoding suggested most speed up could be gained in just not updating parent for waiting jobs
Put all 39,000 jobs in my system back in pending and triggered task manager. Had START_TASK_LIMIT set to 10,000
Result was ~ 133 jobs/second -- close to the 142 jobs/second we get from bulk_update approach with exact same workload in #15171 (compared to ~ 20 jobs/second in devel)
ISSUE TYPE
COMPONENT NAME
ADDITIONAL INFORMATION
@AlanCoding has indicated he'd like to solve this in potentially more universal way leveraging django-ansible-base