1
0
Fork 0
mirror of https://we.phorge.it/source/phorge.git synced 2025-01-02 02:40:58 +01:00
phorge-phorge/src/applications/transactions
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
..
application Put inline previews in remarkup textareas 2015-12-22 12:18:28 -08:00
commentaction Allow stacked comment actions to be explicitly ordered 2016-04-06 09:15:27 -07:00
constants Merge TYPE_PROJECT_COLUMNS and TYPE_COLUMN transactions into a more general TYPE_COLUMNS transaction 2016-04-06 09:13:31 -07:00
controller In prose diff dialogs (like "Show Details" in transactions), show "old", "new" and "diff" tabs 2016-11-07 15:18:19 -08:00
data Don't re-mention users for comment edits 2016-06-13 13:57:59 -07:00
edges Remove "Used By" from Passphrase 2016-05-16 16:38:52 -07:00
editengine Remove empty implementations of describeAutomaticCapabilities() 2016-11-09 15:24:22 -08:00
editfield Make the "All Day Event" control use a checkbox instead of a dropdown 2016-10-31 14:18:59 -07:00
editor Cache Almanac URIs for repositories 2016-12-06 09:14:45 -08:00
edittype Improve Conduit type handling for *.edit endpoints 2015-12-16 08:45:46 -08:00
engineextension Redesign Config Application 2016-08-29 15:49:49 -07:00
error Allow users to unset "Editor", tailor short error messages properly on settings forms 2016-06-05 14:03:02 -07:00
exception Mark some strings for translation 2015-06-09 23:06:52 +10:00
feed Give application actors in feed reasonable icons 2016-04-20 14:38:55 -07:00
interface Transactions - adding willRenderTimeline to handle tricky cases 2014-12-04 13:58:52 -08:00
phid Allow ApplicationEditor forms to be reconfigured 2015-11-10 10:24:40 -08:00
query Update EditEngine for two column 2016-03-28 09:18:55 -07:00
replyhandler Modularize content sources 2016-03-26 11:59:45 -07:00
response Various translation improvements 2015-11-03 07:02:46 +11:00
storage Ignore Calendar date edits which just change the internal date timezone without rescheduling it 2016-11-28 10:33:59 -08:00
view Show file comments on file lightboxes 2016-11-18 13:24:03 -08:00
worker Cache user notification and message counts 2016-06-05 08:52:43 -07:00
xaction Modularize application transactions in Paste, mostly 2016-06-14 06:13:28 -07:00