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)
Mon, Feb 3, 2:48 AM
Unknown Object (File)
Sat, Feb 1, 7:39 AM
Unknown Object (File)
Wed, Jan 29, 1:52 AM
Unknown Object (File)
Mon, Jan 20, 7:54 PM
Unknown Object (File)
Jan 14 2025, 12:35 PM
Unknown Object (File)
Jan 14 2025, 8:04 AM
Unknown Object (File)
Jan 11 2025, 2:07 AM
Unknown Object (File)
Jan 5 2025, 7:45 AM
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