Page MenuHomePhabricator

Add a maximum read buffer size to ExecFuture
ClosedPublic

Authored by epriestley on Dec 16 2013, 6:16 PM.
Tags
None
Referenced Files
Unknown Object (File)
Tue, Dec 31, 5:24 PM
Unknown Object (File)
Thu, Dec 26, 5:19 PM
Unknown Object (File)
Dec 17 2024, 10:36 AM
Unknown Object (File)
Dec 8 2024, 4:49 PM
Unknown Object (File)
Dec 8 2024, 4:43 PM
Unknown Object (File)
Dec 5 2024, 7:24 AM
Unknown Object (File)
Dec 3 2024, 8:06 AM
Unknown Object (File)
Dec 1 2024, 1:45 PM
Subscribers

Details

Summary

Ref T4241. Currently, ExecFuture may read an arbitrarily large amount of data into memory during execution. In T4241, this arises specifically with git-upload-pack, which emits about as much data as the size of the repository. Currently, the subprocess emits this data far faster than we can send it over the network, so we end up with a huge in-process buffer containing the entire repository.

Instead, we want to throttle git-upload-pack until the network can catch up. This is the first step in letting that happen.

Test Plan

Added a unit test.

Diff Detail

Lint
Lint Skipped
Unit
Tests Skipped

Event Timeline

epriestley updated this revision to Unknown Object (????).Dec 16 2013, 6:18 PM
  • Use slightly clearer variable names.
btrahan added inline comments.
src/future/exec/ExecFuture.php
534–541

just wanted to double check if any other callsites - particular in children classes - need to be updated as I think not specifying length will trigger the early return.

src/future/exec/ExecFuture.php
168

(This is the first in a series of several complicated diffs, and I just wanted to limit the amount of extra stuff happening for now.)

534–541

Ah, yeah -- a lot of protected in this class should really be private, it's just super old -- there are no other callsites and the class is final. I'll send a followup.

could you help me to solve this problem as soon as possible, thank you very much

src/future/exec/ExecFuture.php
542

fread() will be blocked , when the content of stdout is too much

hey @xuyulong - are you trying to run Phabricator on windows? That is currently (and likely to remain) not supported. Otherwise, what Arcanist or other workflows are you encountering to hit this error?

yes,i am run phabricator on windows,but, fread() will not block when my cpp files smaller than 3k and the fread() will be blocked when the cpp file more than 3.26 K

See T3272. Windows doesn't have async pipes, so it isn't clear how to deal with this. T3272 has a possible solution (redirect the pipes through files, essentially).