Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Disable HTTP Pipelining #3035

Draft
wants to merge 3 commits into
base: develop
Choose a base branch
from

Conversation

AiraYumi
Copy link
Contributor

@AiraYumi AiraYumi commented Nov 7, 2024

What you need to do before you do this:

  • Add HTTP/2 support to CDN.
  • Check the impact on performance of supporting HTTP/2.
  • Allow you to enable or disable HTTP/2.
  • Check the negotiation between the viewer and the CDN.
  • Update 3p-curl package
  • Update 3p-openssl package (Maybe be needed for 3p-curl updates)

@github-actions github-actions bot added the c/cpp label Nov 7, 2024
@AiraYumi AiraYumi marked this pull request as ready for review November 7, 2024 23:13
@monty-linden
Copy link
Contributor

@akleshchev tapped me on the shoulder and suggested I comment.

Quick question: did you measure the before-and-after performance effects of this change?

Longer response: a great deal of effort went into parameter tuning years ago when the http system was changed, a CDN was introduced, and pipelining was implemented. Throughput and latency were greatly affected by parameter changes and the original settings (a subset of current ones) were a pretty good tradeoff of various factors. Are these tuned correctly today? Perhaps not but I have a fairly strong hunch eliminating pipelining without a compensating change in, say, concurrency, is likely to have a negative performance impact.

And at the moment, we're a bit gun-shy about releases with negative performance impacts.

Fortunately, the tools for a better tomorrow exist and have for more than a decade! The example code in llcorehttp also happens to be a performance testing scaffold. Some specially instrumented viewers can generate real-world asset fetch lists (asset, range, etc.) which feed the tool and allow parameter tuning anywhere in the world. And completely isolated from the full viewer environment and its repeatability problems.

Yeah, we know HTTP/1.1 pipelining needs to go along with the freeze on the libcurl package. The compensating feature for that should probably be HTTP/2. That, in turn, will add the additional cost of crypto to the asset fetching problem but I hope to see it perform comparably without the reliability problems of pipelining. Just a matter of coding and a lot of testing.

@AiraYumi
Copy link
Contributor Author

Thank you @monty-linden .

We are currently checking the viewer's performance after making this change.

If the CDN you are currently using supports HTTP/2, even if you disable HTTP Pileline, you should be able to minimize the impact on performance by also enabling HTTP/2.

Fortunately, libcurl allows you to enable HTTP/2 communication by simply adding a single option.

We will check the performance.

@AiraYumi
Copy link
Contributor Author

I found that libcurl can automatically attempt multiplexing when http/2 is enabled.
I don't know why this wasn't enabled.
Perhaps an asset server issue?

@AiraYumi AiraYumi force-pushed the disable_http_pipelining branch from eb3eff9 to 5d4cf98 Compare November 16, 2024 00:56
@monty-linden
Copy link
Contributor

The larger concern I was hinting at is that libcurl isn't just a library, it is part of infrastructure which is larger than viewer development. Targets need to be compatible and the CDN hasn't been setup yet for http/2 (although it can be used experimentally). Changes in libcurl usually come with changes in crypto. Viewer crypto needs to negotiate with server crypto which isn't always compatible. Server crypto changes can then fail to negotiate with scripters' remote https clients and servers and everyone needs testing and conversion time before switchover. The viewer itself needs debug flags or full settings to disable http/2 when someone can't use it for some reason. And the frozen version of libcurl has an http/2 implementation that is probably unusable.

What looks like flipping two booleans in the viewer code is actually a large infrastructure upgrade project. But that can start with understanding viewer impact. I.e. what happens across the world when pipelining is disabled?

@AiraYumi AiraYumi force-pushed the disable_http_pipelining branch 2 times, most recently from 13f9f26 to d064c80 Compare November 16, 2024 06:16
@AiraYumi AiraYumi force-pushed the disable_http_pipelining branch from d064c80 to 726b425 Compare November 16, 2024 06:17
@AiraYumi
Copy link
Contributor Author

AiraYumi commented Nov 16, 2024

I was looking at the code, and I think that even though mPipelined is set to true, HTTP pipelining is not actually working.
This is because, in the C++ standard, true is changed to 1 and false is changed to 0 when compared with numeric types, but in the code, HTTP pipelining is enabled when the value is greater than 1.

Standard conversions (Integral promotions)
https://timsong-cpp.github.io/cppwp/n4659/conv.prom#6

@Quinn-Elara
Copy link

@akleshchev tapped me on the shoulder and suggested I comment.

Quick question: did you measure the before-and-after performance effects of this change?

Longer response: a great deal of effort went into parameter tuning years ago when the http system was changed, a CDN was introduced, and pipelining was implemented. Throughput and latency were greatly affected by parameter changes and the original settings (a subset of current ones) were a pretty good tradeoff of various factors. Are these tuned correctly today? Perhaps not but I have a fairly strong hunch eliminating pipelining without a compensating change in, say, concurrency, is likely to have a negative performance impact.

And at the moment, we're a bit gun-shy about releases with negative performance impacts.

Fortunately, the tools for a better tomorrow exist and have for more than a decade! The example code in llcorehttp also happens to be a performance testing scaffold. Some specially instrumented viewers can generate real-world asset fetch lists (asset, range, etc.) which feed the tool and allow parameter tuning anywhere in the world. And completely isolated from the full viewer environment and its repeatability problems.

Yeah, we know HTTP/1.1 pipelining needs to go along with the freeze on the libcurl package. The compensating feature for that should probably be HTTP/2. That, in turn, will add the additional cost of crypto to the asset fetching problem but I hope to see it perform comparably without the reliability problems of pipelining. Just a matter of coding and a lot of testing.

The problem with this is that while yes, you can disable pipelining and yes, chances are the performance impact is negative, the CDN itself has HTTP/2 disabled (manually verified by calling cURL from terminal and forcing the use of HTTP/2, which then states that the remote server does not support HTTP/2 ), so any chance to test and fix performance regressions is not possible.

I'd suggest at least enabling HTTP/2 on the CDN side for the beta grid (aditi) so that performance testing and fixes for HTTP/2 can be worked on, rather than the current situation of chicken-and-egg where the viewer work can't go ahead without serverside support, and the serverside switch won't be flipped unless the viewer has support and has been tested with satisfactory performance.

@monty-linden
Copy link
Contributor

and the serverside switch won't be flipped unless the viewer has support and has been tested with satisfactory performance.

No such condition exists. The server side is more than flipping a switch (hints of which can be seen in cert and cipher negotiation if you're looking at curl details). I've been trying to trick some internal viewer dev to take on http/2 without success. But if someone is ready to give it a try, we can look at pushing those infra changes along.

As for the PR: I'll block with changes requested for now. The changes will be gated by Linden moving the grid infra forward to support http/2 dev work.

@AiraYumi
Copy link
Contributor Author

We've created pull request #3101 to enable HTTP/2 support on the viewer side.
However, work is still needed.

We've found that we're not yet ready to disable HTTP pipelining at this stage, so we'll stop work on this pull request until the server side is ready.

@AiraYumi AiraYumi marked this pull request as draft November 20, 2024 07:13
@brad-linden
Copy link
Collaborator

seems like this is the kind of thing that should be discussed in issues to reach consensus on a plan before we start working on PRs

@vldevel
Copy link
Contributor

vldevel commented Nov 25, 2024

Just chiming in to say that HTTP pipelining still works wonders for oversea users such as myself, with a fast viewer and a fast Internet link (1GBps fiber). I do see a big difference with it enabled vs disabled in my viewer (Cool VL Viewer).

Sadly, and as you guys said, HTTP pipelining is no more supported in libcurl, and only super-old (and LL's-patched-to-fix-pipelining) libcurl versions can still use it, not to mention that these versions do not support modern SSL libraries/versions.

But until LL can get their CDN servers to do HTTP/2, I would advise against the abandon of pipelining.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging this pull request may close these issues.

5 participants