Page MenuHomePhabricator

When search indexers contend for a lock, just yield
ClosedPublic

Authored by epriestley on Jun 22 2018, 5:05 PM.
Tags
None
Referenced Files
Unknown Object (File)
Sat, Jan 18, 3:49 AM
Unknown Object (File)
Tue, Dec 31, 11:39 PM
Unknown Object (File)
Dec 12 2024, 7:20 AM
Unknown Object (File)
Nov 28 2024, 9:26 AM
Unknown Object (File)
Nov 24 2024, 10:00 AM
Unknown Object (File)
Nov 24 2024, 10:00 AM
Unknown Object (File)
Nov 20 2024, 5:51 PM
Unknown Object (File)
Nov 19 2024, 7:10 AM
Subscribers
None

Details

Summary

Depends on D19503. Ref T13151. See PHI719. If you have something like a script which updates an object in a loop, we can end up queueing many search reindex tasks.

These tasks may reasonably contend for the lock, especially if the object is larger (lots of text and/or lots of comments) and indexing takes a few seconds.

This isn't concerning, and the indexers should converge to good behavior quickly once the updates stop.

Today, they'll spew a bunch of serious-looking lock exceptions into the log. Instead, just yield so it's more clear that there's (normally) no cause for concern here.

Test Plan

Ran bin/search index Txxx --force on a large object in multiple windows with a 0 second lock, saw an explicit yield instead of a lock exception.

Diff Detail

Repository
rP Phabricator
Lint
Lint Not Applicable
Unit
Tests Not Applicable

Event Timeline

amckinley added inline comments.
src/applications/search/worker/PhabricatorSearchWorker.php
48

I guess doing anything more complicated like exponential backoff would be overkill, and this at least ensures the indexing will happen within 15 seconds of the update torrent from stopping.

This revision is now accepted and ready to land.Jun 22 2018, 11:22 PM
This revision was automatically updated to reflect the committed changes.