Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Optimize bulk unlocking #82

Merged
merged 1 commit into from
Dec 6, 2024
Merged

Optimize bulk unlocking #82

merged 1 commit into from
Dec 6, 2024

Conversation

sharshenov
Copy link
Member

  • Replace individual DEL commands with batched deletions
  • Use SCAN with COUNT parameter for better performance
  • Reduce network round-trips between application and Redis
  • Improve memory efficiency by processing keys in batches

This change enhances the performance of the delete_locks method, especially when dealing with a large number of keys. The new implementation uses the SCAN command with a COUNT parameter to retrieve keys in batches, reducing memory usage. It then deletes these keys in batches, significantly reducing the number of network round-trips to the Redis server.

While Lua scripting could potentially offer even greater performance benefits, we opted not to use it in this iteration. This decision maintains better readability and easier maintenance of the Ruby code, avoids potential issues with script caching across multiple Redis servers, and keeps the implementation consistent with other parts of the codebase. The current optimization strikes a balance between performance improvement and code simplicity.

@sharshenov sharshenov force-pushed the optimize-bulk-unlock branch 2 times, most recently from 93f030c to 3978afd Compare September 20, 2024 10:44
@sharshenov sharshenov force-pushed the optimize-bulk-unlock branch 2 times, most recently from cdb7f76 to 19ef616 Compare September 20, 2024 10:54
Copy link

@adis-io adis-io left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

🚀

lib/active_job/uniqueness/lock_manager.rb Outdated Show resolved Hide resolved
- Replace individual DEL commands with batched deletions with UNLINK
- Use SCAN with COUNT parameter for better performance
- Reduce network round-trips between application and Redis
- Improve memory efficiency by processing keys in batches

This change enhances the performance of the delete_locks method, especially when dealing with a large number of keys. The new implementation uses the SCAN command with a COUNT parameter to retrieve keys in batches, reducing memory usage. It then deletes these keys in batches, significantly reducing the number of network round-trips to the Redis server.

While Lua scripting could potentially offer even greater performance benefits, we opted not to use it in this iteration. This decision maintains better readability and easier maintenance of the Ruby code, avoids potential issues with script caching across multiple Redis servers, and keeps the implementation consistent with other parts of the codebase. The current optimization strikes a balance between performance improvement and code simplicity.
@sharshenov sharshenov force-pushed the optimize-bulk-unlock branch from 19ef616 to 125e5cf Compare December 6, 2024 13:25
@sharshenov sharshenov merged commit 1ea6985 into main Dec 6, 2024
76 checks passed
@sharshenov sharshenov deleted the optimize-bulk-unlock branch December 6, 2024 13:34
@sharshenov
Copy link
Member Author

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants