Re: New Version Notification for draft-kazuho-httpbis-priority-00.txt

Kazuho Oku <> Wed, 10 July 2019 01:28 UTC

Return-Path: <>
Received: from localhost (localhost []) by (Postfix) with ESMTP id 09804120141 for <>; Tue, 9 Jul 2019 18:28:33 -0700 (PDT)
X-Virus-Scanned: amavisd-new at
X-Spam-Flag: NO
X-Spam-Score: -2.75
X-Spam-Status: No, score=-2.75 tagged_above=-999 required=5 tests=[BAYES_00=-1.9, DKIM_SIGNED=0.1, DKIM_VALID=-0.1, DKIM_VALID_AU=-0.1, HEADER_FROM_DIFFERENT_DOMAINS=0.249, HTML_MESSAGE=0.001, MAILING_LIST_MULTI=-1, SPF_PASS=-0.001, URIBL_BLOCKED=0.001] autolearn=ham autolearn_force=no
Authentication-Results: (amavisd-new); dkim=pass (2048-bit key)
Received: from ([]) by localhost ( []) (amavisd-new, port 10024) with ESMTP id 5rC5s8L76kTh for <>; Tue, 9 Jul 2019 18:28:29 -0700 (PDT)
Received: from ( [IPv6:2603:400a:ffff:804:801e:34:0:38]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by (Postfix) with ESMTPS id A5D2C12001E for <>; Tue, 9 Jul 2019 18:28:28 -0700 (PDT)
Received: from lists by with local (Exim 4.89) (envelope-from <>) id 1hl1NH-0006Od-K6 for; Wed, 10 Jul 2019 01:26:23 +0000
Resent-Date: Wed, 10 Jul 2019 01:26:23 +0000
Resent-Message-Id: <>
Received: from ([2603:400a:ffff:804:801e:34:0:4c]) by with esmtps (TLS1.2:ECDHE_RSA_AES_256_GCM_SHA384:256) (Exim 4.89) (envelope-from <>) id 1hl1NF-0006Ns-U5 for; Wed, 10 Jul 2019 01:26:21 +0000
Received: from ([2a00:1450:4864:20::233]) by with esmtps (TLS1.2:ECDHE_RSA_AES_128_GCM_SHA256:128) (Exim 4.89) (envelope-from <>) id 1hl1NB-00021r-Nd for; Wed, 10 Jul 2019 01:26:21 +0000
Received: by with SMTP id t28so322318lje.9 for <>; Tue, 09 Jul 2019 18:25:57 -0700 (PDT)
DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed;; s=20161025; h=mime-version:references:in-reply-to:from:date:message-id:subject:to :cc; bh=ybSiymcdhG4dwpscGKPxH7oH5cZp8JZaLpHxMYayLAM=; b=ds+DWhAYijcQqlLm/ZSyBKhFyW8HbOGoXhKJGhch4ovtxNl8FZbJLqFKOXeXFuSqCT PaWJary/oJ8B3Hzf1vPt05K7lus0CyckJXXqNpTh4QuZOrenAcS14AJhj5xgVZmolDic 0Lg8cHRr/2ydFaW2FFgeAje/gLCBgXLuaOXG1Iynqyez0/XMH3zcS/oSujoDyGWJ0ehN WgJScq/L2SIZo+pi2z5F1lPJoG+8PfjppZXAvCCm+zPMKw3ZP01hesdbKqfs5mq1U7og SBfNE1sl320b/huq09YEX3KRlCk9ocKI/DNS2nuZL8X+ps1tmD/BJWPQi3xleyUgCiGh MSgA==
X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed;; s=20161025; h=x-gm-message-state:mime-version:references:in-reply-to:from:date :message-id:subject:to:cc; bh=ybSiymcdhG4dwpscGKPxH7oH5cZp8JZaLpHxMYayLAM=; b=iiKANL/mn7eM6LFG2gZjTcGTiKDrBsFjGCY8/XIs+42+s8YIp+H6W+NL6UXfb6QuOo S+OZuXaKTPDGYd8gjXm2xdHdKdciKnMi2dQU/sJdS5ykG29jvznM/CQmzu7ijndMYhm3 AAdoQ0ghjwrjdIzaTQjUSg+1VIjzHx/1gs2Q/W/nvOg2mgJEgOXLME4CSxmpfm0JnlGl yosOE8TLhT5JJ8ku2ozBC7hZwn0gb+kVHV6/yMFTw2xkNyy4IpWOkf4fvLwVwAqmT2/w t6itwEY3/+H07buNeXeesuc4UMMZyGm7ne+EEuDAc8+O6g5KThRtHmz6Sw9C6lVbYD4o npZA==
X-Gm-Message-State: APjAAAWSY/0Tv0z9rbgdPnCq9dm7dD5RjpbMvZN7wBPG3Fg2Yq4z3hHT AyfW767kfIRz4B56PEjvaoX16F/wG+MHc5ar1js=
X-Google-Smtp-Source: APXvYqzIKa0vXc1ovikUVvtFFyDruwAWkNQXq62b5/7apDqAVcMklJXo/4D9v4c/PCFT2HOFdXJFXSgx0V8lw/oAZFY=
X-Received: by 2002:a2e:6c07:: with SMTP id h7mr12943177ljc.177.1562721955718; Tue, 09 Jul 2019 18:25:55 -0700 (PDT)
MIME-Version: 1.0
References: <> <> <> <> <>
In-Reply-To: <>
From: Kazuho Oku <>
Date: Wed, 10 Jul 2019 10:25:44 +0900
Message-ID: <>
To: Robin MARX <>
Cc: HTTP Working Group <>
Content-Type: multipart/alternative; boundary="0000000000000dac9a058d498fce"
Received-SPF: pass client-ip=2a00:1450:4864:20::233;;
X-W3C-Hub-Spam-Status: No, score=-2.8
X-W3C-Hub-Spam-Report: AWL=1.332, BAYES_00=-1.9, DKIM_SIGNED=0.1, DKIM_VALID=-0.1, DKIM_VALID_AU=-0.1, DKIM_VALID_EF=-0.1, FREEMAIL_FROM=0.001, HTML_MESSAGE=0.001, RCVD_IN_DNSWL_NONE=-0.0001, SPF_HELO_NONE=0.001, SPF_PASS=-0.001, W3C_AA=-1, W3C_WL=-1
X-W3C-Scan-Sig: 1hl1NB-00021r-Nd fee384d781d98b1e68e949ba801b3b89
Subject: Re: New Version Notification for draft-kazuho-httpbis-priority-00.txt
Archived-At: <>
X-Mailing-List: <> archive/latest/36779
Precedence: list
List-Id: <>
List-Help: <>
List-Post: <>
List-Unsubscribe: <>

Hi Robin,

2019年7月9日(火) 22:56 Robin MARX <>be>:

> Hello Kazuho,
> Thanks for the comments, most of which I agree with. The clarification
> from Lucas elsewhere that the frame could contain an "opaque encoded
> header" makes things a bit more pleasant for me.
> I have created some issues on github to further explain some of my points,
> as I feel some of your comments don't really answer my other reservations.
> 5) and 7) On the semantics of the used header names and values:
>     My point was more general that the semantics of what you have now do
> not map (perfectly) to the semantics that are already in-place when talking
> about browser resource loading and this can create confusion down the road.
>     Simply clarifying what your "re-defined" blocking means does not help
> prevent confusion all that much imo.
>     With your examples at the end as well, for me you are "abusing" the
> blocking indicator to manipulate sending behaviour, rather than
> communicating the actual semantics of a blocking resource (a CSS in the
> document is still render blocking, even if it is less important than one in
> the <head>).

By saying "communicating the actual semantics of a blocking resource", I
assume that you are suggesting to send something like "this is a request
initiated by a style tag in body." Generally speaking, I think signaling
that sort of signal is a good idea.

OTOH, that's going to be a research project. I am open to defining such
signals alongside "urgency" that's being proposed by the document. OTOH,
"switching" to that approach would mean that it'd be less likely that we'd
have an alternative prioritization scheme adopted when we ship H3.

Therefore, it is my view that what we should do now is encode the priority
levels that the browsers use today, at the same time assigning meanings to
each of the priority levels.

We need to assign meanings so that servers can tweak the prioritization
scheme, because the server needs to know what type of resource is assigned
to each level.

Consider the case where a server wants to send HTML before CSS (it's not a
terrible idea, that's what Chrome suggests using the H2 scheme now). That'd
be only possible when the client uses a signal like "document", "blocking".
If the signals were named like "highest" or "medium" (or "5" or "4"), and
without the knowledge of to which of the two HTML and CSS will be
associated to, it would be impossible for a server to prioritize HTML above
CSS (or in the opposite order).

>     Resolution to this can be as simple as re-naming the values to prevent
> confusion.

We can discuss about the names.

> 6) On the array of use cases / semantics that can be represented/should be
> representable:
>     You say for example that promoting an image to a hero image is not the
> intent of the example. I can then ask: how would you indicate a hero-image
> server to client then? There doesn't seem to be a way in the current setup
> to (properly) do this.

You can set the urgency. For example, if the server believes that an image
is as important as the document itself in terms of "using" the document, it
can set the value of the response header to "Priority: urgency=document."
That would be the instruction to the H2/H3 terminator that the response
should be given the same priority level as the HTML.

>     You could say that the server simply uses its internal knowledge and
> sends that image first, but then the whole "this is usable by
> intermediates"-argument becomes less powerful.
>     I feel we should communicate as much metadata as possible back to the
> server to allow it to make complex decisions, if it so chooses. The server
> can still ignore most of the metadata if it decides to implement a simpler
> scheme.
>     In essence, the metadata communicated in the header should, imo, be
> relatively de-coupled from the concrete implementations at the server (and
> the current HTTP/2 setups)
> With best regards,
> Robin
> On Tue, 9 Jul 2019 at 03:42, Kazuho Oku <> wrote:
>> Hi Robin,
>> Thank you for the comments. My responses below.
>> 2019年7月8日(月) 23:56 Robin MARX <>be>:
>>> Hello Kazuho and Lucas,
>>> Thank you for the draft. Most of this feedback I've given elsewhere as
>>> well, but to keep everything in one place:
>>> 1) I really like the header-based approach. It's extensible, allows us
>>> to make progress on H3, is easier to use/understand,
>>> can be "backported" to H2, has other nice properties which you touch
>>> upon in the text (intermediates, caching, etc.)
>> I'm delighted to hear that.
>>> 2) I really dislike the header-based approach. It makes
>>> re-prioritization a mess. You don't touch upon this (yet) in the draft,
>>> but the discussion on github (
>>> proposes
>>> using a separate, special H3/H2 level frame to provide this. This just
>>> feels -very- dirty to me. The problem is that I can't really think
>>> of a (much) better solution, other than referring to re-prioritized
>>> resource A in resource B's headers, which is a whole other can of worms.
>>> I'm not
>>> really opposed to using the separate frame if that's the only option,
>>> but it still takes away some of the nice properties of 1)
>> While I can see how you feel sad, I am not worried, because
>> reprioritization can also be HTTP-version-independent in terms of API. The
>> only difference would be how the prioritization hints (in text) are encoded
>> as frames.
>>> 3) I really like the switch to "absolute"/"stateless" priority
>>> levels/semantics (as you're referred to them elsewhere), as opposed to
>>> building the tree directly.
>>> This really helps for (partial) server-side (re-)prioritization. It does
>>> require the server (implementers) to know a bit more about how browsers
>>> work, but
>>> I don't really see that as a big issue (given that we provide guidance
>>> and examples on proper options)
>> :+1:
>>> 4) I don't feel the current defined priority fields+values cover the use
>>> cases though. You touch upon this in section 5.2, but I disagree with you
>>> there:
>>> For me, these new priority primitives are the core of the proposal (not
>>> the header-based approach. I would champion these new semantics in a
>>> frame-based setup as well)
>>> and imo these should be nailed down (semi-)completely before considering
>>> this approach. There should probably be more degrees of "urgency" \
>>> (e.g., as Patrick Meenan mentioned things like "deferred" and
>>> "background'), and there should maybe be something like
>>> "importance"/"weight"/"precedence"/...
>>> to be more fine-grained within resources of the same "urgency" level.
>> I think that adding "deferred" is easy, assuming that we would agree on
>> the meaning. It would mean the responses that should be sent _after_ the
>> "non-blocking" responses.
>> Re "background," I think we need to discuss how we want to prioritize
>> them. Should we assign it a yet lower precedence (than "deferred")? Or
>> should we state that it should be given some amount of bandwidth regardless
>> of other responses?
>> As mentioned in
>>>, it
>>> might be good
>>> to look at the existing work on the Priority Hints spec, seeing as they
>>> probably have already looked at much of this as well.
>>> 5) I am also not sure about the interpretation of the current fields.
>>> For example, as noted by Patrick (
>>> blocking has a specific meaning and it doesn't map 100% to your current
>>> text.
>> I assume this to have been fixed by
>> IIUC,
>> Patrick's concern was that "blocks the processing of the document" seems to
>> be applicable to JavaScript files loaded in <BODY>. In #14 we've changed
>> the text to "blocks using the document", and I think it's clearer that
>> urgency=blocking does not necessarily apply to such JavaScript files.
>>> Similarly, what does progressive mean exactly? IIUC JS and CSS can be
>>> parsed/compiled
>>> in a streaming fashion in modern engines as well, it's mainly their
>>> application that is delayed until they are fully available.
>> When used by a client, it is a signal that indicates if the client
>> prefers receiving the responses with the bandwidth being distributed among
>> similar responses, or if it prefers receiving the response one by one.
>> Similarly, is a non-progressively encoded jpeg
>>> counted as "progressive"? How does the browser know if a JPEG will be
>>> progressive or not when making the request? I feel you've got the answers,
>>> but the usage of these
>>> specific terms can make it more difficult to actually use this scheme in
>>> practice.
>> For images, a browser should set progressive to 1, when it can assume
>> that the image can be rendered progressively, as doing so improves user
>> experience.
>> Servers would benefit from setting progressive to 0 for baseline JPEG
>> images, assuming that sending the first few percent of the file does not
>> improve user experience.
>> Assuming that what I've stated here makes sense, I think it might be a
>> good idea to clarify these points using examples in the draft.
>>> 6) This is also clear a bit from the example in section 3 (switching
>>> image from progressive to non-progressive). I -assume- the goal here is to
>>> do something like a "hero" image,
>>> which you want to send before other images. However, it feels to me that
>>> "abusing" the progressive field for this is not the best way to go about
>>> that.
>> As stated above, that's not the intent.
>>> 7) Most of this comes together in the fact that I'm having a hard time
>>> thinking of how to represent existing H2 logic/browser use cases in this
>>> new scheme.
>>> E.g., how would you derive Chrome's current "dynamic fifo" from this
>>> metadata? How would you implement Patrick Meenan's proposed 'ideal' setup
>>> from these directives?
>>> Having a couple of concrete examples would help to understand your
>>> intents and probably also to ferret out some missing pieces.
>> I agree that talking about mappings is a good idea. I think it would be
>> something like:
>> HTML -> urgency=document, progressive=?1
>> JS, CSS in HEAD -> urgency=blocking, progressive=?0
>> images -> urgency=non-blocking, progressive=?1
>> async-loaded JS -> urgency=deferred, progressive=?0
>> There's some wiggle room for fonts and JS, CSS being used inside BODY.
>> Depending on how important they seem to be, a client can set urgency to
>> "blocking" (if it essentially prevents the document from being used), to
>> "document" (if it thinks that the resources are as important as characters
>> and tags inside the HTML document), to "non-blocking" (if it thinks that
>> they are not important in terms of using the document), or even to
>> "deferred" (consider the case of a script tag at the body of the HTML
>> loading some analytic script).
>> If we are to be fine with one particular approach, I think we can
>> recommend that. But we do not need to struggle to reach consensus on one
>> particular algorithm, because in the proposed approach, servers can correct
>> the precedence of mis-prioritized requests under the proposed scheme.
>>> TL;DR: I see this draft as a combination of two proposals:
>>> A) a new way to define priority levels/semantics (i.e., "how will the
>>> resource be used " rather than "when should you send it") : all for this!
>>>          Needs more work though, current draft doesn't (fully) support
>>> use cases and imo, it should.
>>> B) sending those new levels via headers instead of frames: many
>>> advantages, and "feels right"
>>>         Except for the re-prioritization bit...
>>> With best regards,
>>> Robin
>>> On Mon, 8 Jul 2019 at 15:00, Kazuho Oku <> wrote:
>>>> Hi,
>>>> Today, Lucas and I have submitted the following draft, that defines an
>>>> HTTP header field for driving prioritization.
>>>> In short, the draft defines an end-to-end HTTP header field called
>>>> "Priority" for transmitting prioritization hints in absolute values
>>>> that have meanings. It is much simpler than the prioritization scheme
>>>> of H2 that communicates and uses a "tree". Not only the client, but
>>>> also the server can send the prioritization hints, in order to improve
>>>> the way the responses are prioritized. The prioritization scheme is
>>>> independent to HTTP versions; it can be used on both H2 and H3 (and
>>>> also on H1 for providing hints to intermediaries).
>>>> For more detail, please refer to the draft.
>>>> Background: back in May in London, the QUIC WG had a discussion on if
>>>> porting the prioritization scheme of H2 to H3 is the way to go [1].
>>>> I think there were two major arguments for having something different:
>>>> * Prioritization scheme of H2 is complex, and porting it to H3
>>>> increases the complexity [2].
>>>> * With the H2 scheme, it is hard for the server to tweak the
>>>> prioritization tree, because clients build their trees in their own
>>>> ways [3][4].
>>>> The arguments against were:
>>>> * Redesigning prioritization for H3 is likely to delay the
>>>> standardization and time-to-market.
>>>> * Having something different in H3 is an act of "adding" complexity to
>>>> HTTP as a whole.
>>>> This discussion has led us to wonder if there could be a technical
>>>> solution that resolves the issues of the H2 scheme (see the pro
>>>> arguments), at the same time minimizing the downsides.
>>>> And we came up with this proposal. I think the key selling points of
>>>> the proposal are:
>>>> * Much simpler thanks to each request carrying an absolute priority
>>>> value. No need to synchronize a "tree".
>>>> * Because the priority value sent by the client indicates how each
>>>> request / response affects the use of other responses (e.g.,
>>>> "blocking", "non-blocking"), the server can understand the intent of
>>>> the client and further optimize the delivery order.
>>>> * Use of the HTTP header field as the conveyer of the priority value
>>>> allows an origin server to indicate hints to an intermediary that
>>>> terminates the H2/H3 connections from the client. For example, an
>>>> origin server can indicate higher precedence for some images that
>>>> matter more to the user, while giving lower precedence to others.
>>>> * Another benefit of using an HTTP header field instead of a frame is
>>>> that prioritization logic becomes independent from HTTP versions. That
>>>> would help both clients and servers improve the quality of their
>>>> implementation, as well as fostering website owners fine-tune the
>>>> prioritization through the use of the Priority response header.
>>>> * A header-based prioritization scheme can be improved as time goes,
>>>> as HTTP headers are extensible by their nature. It also means that a
>>>> header-based design can be rolled out at an earlier stage than a
>>>> frame-based design.
>>>> To paraphrase, the header-based design provides simplicity,
>>>> extensibility, room to evolve, and the possibility to roll out early.
>>>> This could be the only prioritization scheme for H3. Separating
>>>> prioritization into a version-independent approach simplifies H3,
>>>> taking some load away from QUIC WG.
>>>> Of course, H3 needs to hit the market with a prioritization scheme, we
>>>> need to agree on that particular scheme. But I think we might be able
>>>> to agree on the need for a header-based prioritization scheme, that a
>>>> server can tweak, that uses absolute priorities. If that is the case,
>>>> I think we have fair chance on agreeing on something pretty soon.
>>>> To summarize, with the proposed design, I think we have the chance of
>>>> making prioritization better as we roll out HTTP/3, without getting
>>>> the standardization process delayed.
>>>> Please let us know what you think. Thank you in advance.
>>>> [1]
>>>> [2]
>>>> [3]
>>>> [4] In
>>>> Robin points out that server intervention is necessary for best
>>>> performance.
>>>> ---------- Forwarded message ---------
>>>> From: <>
>>>> Date: 2019年7月8日(月) 21:51
>>>> Subject: New Version Notification for
>>>> draft-kazuho-httpbis-priority-00.txt
>>>> To: Kazuho Oku <>om>, Lucas Pardue <
>>>> A new version of I-D, draft-kazuho-httpbis-priority-00.txt
>>>> has been successfully submitted by Kazuho Oku and posted to the
>>>> IETF repository.
>>>> Name:           draft-kazuho-httpbis-priority
>>>> Revision:       00
>>>> Title:          The Priority HTTP Header Field
>>>> Document date:  2019-07-08
>>>> Group:          Individual Submission
>>>> Pages:          9
>>>> URL:
>>>> Status:
>>>> Htmlized:
>>>> Htmlized:
>>>> Abstract:
>>>>    This document describes the Priority HTTP header field.  This header
>>>>    field can be used by endpoints to specify the absolute precedence of
>>>>    an HTTP response in an HTTP-version-independent way.
>>>> Please note that it may take a couple of minutes from the time of
>>>> submission
>>>> until the htmlized version and diff are available at
>>>> The IETF Secretariat
>>>> --
>>>> Kazuho Oku
>>> --
>>> Robin Marx
>>> PhD researcher - web performance
>>> Expertise centre for Digital Media
>>> T +32(0)11 26 84 79 - GSM +32(0)497 72 86 94
>>> Universiteit Hasselt - Campus Diepenbeek
>>> Agoralaan Gebouw D - B-3590 Diepenbeek
>>> Kantoor EDM-2.05
>> --
>> Kazuho Oku
> --
> Robin Marx
> PhD researcher - web performance
> Expertise centre for Digital Media
> T +32(0)11 26 84 79 - GSM +32(0)497 72 86 94
> Universiteit Hasselt - Campus Diepenbeek
> Agoralaan Gebouw D - B-3590 Diepenbeek
> Kantoor EDM-2.05

Kazuho Oku