You are viewing a plain text version of this content. The canonical link for it is here.
Posted to issues@mesos.apache.org by "Armand Grillet (JIRA)" <ji...@apache.org> on 2018/01/02 17:03:00 UTC
[jira] [Created] (MESOS-8368) Improve HTTP parser to support HTTP/2
messages.
Armand Grillet created MESOS-8368:
-------------------------------------
Summary: Improve HTTP parser to support HTTP/2 messages.
Key: MESOS-8368
URL: https://issues.apache.org/jira/browse/MESOS-8368
Project: Mesos
Issue Type: Improvement
Reporter: Armand Grillet
We currently use [http-parser|https://github.com/nodejs/http-parser] to parse HTTP messages. This parser does not work with HTTP/2 requests and responses which as an issue as curl enables HTTP/2 by default for HTTPS connections since its version 7.47.
The issue has been discovered in some of our tests (e.g. ProvisionerDockerTest) where it crashes with the message {{Failed to decode HTTP responses: Decoding failed}}. See [MESOS-8335|https://issues.apache.org/jira/browse/MESOS-8335] for more details.
Possible long-term solutions:
* Upgrade the parser to be compatible with HTTP/2 messages. [http-parser|https://github.com/nodejs/http-parser] has not been updated regularly this past year in favor of [nghttp2|https://github.com/nghttp2/nghttp2] which has a much broader scope. [There is no equivalent of http-parser for HTTP/2 yet|https://users.rust-lang.org/t/is-there-anything-similar-to-http-parser-but-for-http2/10721].
* Test which version of curl is used at startup and report an error if the version is >= 7.47 and the flag {{--http1.0}} is not used in curl (more details regarding this flag are available [here|https://curl.haxx.se/docs/manpage.html].
In the meantime, we are upgrading our testing machines using a recent version of curl to run with the flag {{--http1.0}} ([MESOS-8335|https://issues.apache.org/jira/browse/MESOS-8335]).
--
This message was sent by Atlassian JIRA
(v6.4.14#64029)