Page MenuHomePhabricator

When we purge the request cache, also force PHP to collect cycles
ClosedPublic

Authored by epriestley on Sep 28 2017, 6:42 PM.
Tags
None
Referenced Files
Unknown Object (File)
Sun, Jan 5, 7:45 AM
Unknown Object (File)
Fri, Dec 13, 10:49 AM
Unknown Object (File)
Dec 6 2024, 12:59 PM
Unknown Object (File)
Nov 27 2024, 9:03 PM
Unknown Object (File)
Nov 24 2024, 6:53 AM
Unknown Object (File)
Nov 11 2024, 5:57 AM
Unknown Object (File)
Nov 4 2024, 7:45 PM
Unknown Object (File)
Oct 24 2024, 5:49 PM
Subscribers
None

Details

Summary

Ref T12997. See that task for more details. Briefly, an unusual dataset (where commits are mentioned hundreds of times by other commits) is causing some weird memory behavior in the daemons.

Forcing PHP to GC cycles explicitly after each task completes seems to help with this, by cleaning up some of the memory between tasks. A more thorough fix might be to untangle the $xactions structure, but that's significantly more involved.

Test Plan
  • Did this locally in a controlled environment, saw an immediate collection of a 500MB $xactions cycle.
  • Put a similar change in production, memory usage seemed less to improve. It's hard to tell for sure that this does anything, but it shouldn't hurt.

Diff Detail

Repository
rP Phabricator
Lint
Lint Not Applicable
Unit
Tests Not Applicable