1
0
Fork 0
mirror of https://we.phorge.it/source/phorge.git synced 2025-01-22 20:51:10 +01:00
phorge-phorge/src/applications/repository/query
epriestley e6ddd6d0e9 Cache Almanac URIs for repositories
Summary:
Ref T11954. This is kind of complex and I'm not sure I want to actually land it, but it gives us a fairly good improvement for clustered repositories so I'm leaning toward moving forward.

When we make (or receive) clustered repository requests, we must first load a bunch of stuff out of Almanac to figure out where to send the request (or if we can handle the request ourselves).

This involves several round trip queries into Almanac (service, device, interfaces, bindings, properties) and generally is fairly slow/expensive. The actual data we get out of it is just a list of URIs.

Caching this would be very easy, except that invalidating the cache is difficult, since editing any binding, property, interface, or device may invalidate the cache for indirectly connected services and repositories.

To address this, introduce `PhabricatorCacheEngine`, which is an extensible engine like `PhabricatorDestructionEngine` for propagating cache updates. It has two modes:

  - Discover linked objects (that is: find related objects which may need to have caches invalidated).
  - Invalidate caches (that is: nuke any caches which need to be nuked).

Both modes are extensible, so third-party code can build repository-dependent caches or whatever. This may be overkill but even if Almanac is the only thing we use it for it feels like a fairly clean solution to the problem.

With `CacheEngine`, make any edit to Almanac stuff propagate up to the Service, and then from the Service to any linked Repositories.

Once we hit repositories, invalidate their caches when Almanac changes.

Test Plan:
  - Observed a 20-30ms performance improvement with `ab -n 100`.
  - (The main page making Conduit calls also gets a performance improvement, although that's a little trickier to measure directly.)
  - Added debugging code to the cache engine stuff to observe the linking and invalidation phases.
  - Made invalidation throw; verified that editing properties, bindings, etc, properly invalidates the cache of any indirectly linked repositories.

Reviewers: chad

Reviewed By: chad

Maniphest Tasks: T11954

Differential Revision: https://secure.phabricator.com/D17000
2016-12-06 09:14:45 -08:00
..
PhabricatorRepositoryGitLFSRefQuery.php Implement a Git LFS link table and basic batch API 2016-03-17 17:15:20 -07:00
PhabricatorRepositoryPullEventQuery.php Add a basic pull event log for debugging repository cloning 2016-01-28 08:18:34 -08:00
PhabricatorRepositoryPushEventQuery.php Make buildWhereClause() a method of AphrontCursorPagedPolicyAwareQuery 2015-04-20 10:06:09 -07:00
PhabricatorRepositoryPushLogQuery.php Make buildWhereClause() a method of AphrontCursorPagedPolicyAwareQuery 2015-04-20 10:06:09 -07:00
PhabricatorRepositoryPushLogSearchEngine.php Fix an issue with PHID/handle management in push logs 2016-04-20 04:47:10 -07:00
PhabricatorRepositoryQuery.php Cache Almanac URIs for repositories 2016-12-06 09:14:45 -08:00
PhabricatorRepositoryRefCursorQuery.php Add a DiffusionRefDatasource for typeahead'ing branches, tags, bookmarks and refs 2015-12-10 14:21:24 -08:00
PhabricatorRepositorySearchEngine.php Index all repository URIs, not just the "primary" repository URI 2016-05-11 06:36:06 -07:00
PhabricatorRepositoryTransactionQuery.php Use application PHIDs for application transactions 2013-07-29 12:04:15 -07:00
PhabricatorRepositoryURIQuery.php Rough sketch of new repository URI editing 2016-04-29 09:21:00 -07:00
PhabricatorRepositoryURITransactionQuery.php Add repository URI view pages and IO/Display edit logic 2016-04-29 09:22:16 -07:00