Re: http/2 prioritization/fairness bug with proxies

Amos Jeffries <squid3@treenet.co.nz> Wed, 13 February 2013 04:42 UTC

Return-Path: <ietf-http-wg-request@listhub.w3.org>
X-Original-To: ietfarch-httpbisa-archive-bis2Juki@ietfa.amsl.com
Delivered-To: ietfarch-httpbisa-archive-bis2Juki@ietfa.amsl.com
Received: from localhost (localhost [127.0.0.1]) by ietfa.amsl.com (Postfix) with ESMTP id 7425C21F86CB for <ietfarch-httpbisa-archive-bis2Juki@ietfa.amsl.com>; Tue, 12 Feb 2013 20:42:19 -0800 (PST)
X-Virus-Scanned: amavisd-new at amsl.com
X-Spam-Flag: NO
X-Spam-Score: -10.276
X-Spam-Level:
X-Spam-Status: No, score=-10.276 tagged_above=-999 required=5 tests=[AWL=0.323, BAYES_00=-2.599, RCVD_IN_DNSWL_HI=-8]
Received: from mail.ietf.org ([12.22.58.30]) by localhost (ietfa.amsl.com [127.0.0.1]) (amavisd-new, port 10024) with ESMTP id fTK-RAfLZDxp for <ietfarch-httpbisa-archive-bis2Juki@ietfa.amsl.com>; Tue, 12 Feb 2013 20:42:18 -0800 (PST)
Received: from frink.w3.org (frink.w3.org [128.30.52.56]) by ietfa.amsl.com (Postfix) with ESMTP id 5D3DA21F870C for <httpbisa-archive-bis2Juki@lists.ietf.org>; Tue, 12 Feb 2013 20:42:15 -0800 (PST)
Received: from lists by frink.w3.org with local (Exim 4.72) (envelope-from <ietf-http-wg-request@listhub.w3.org>) id 1U5U8e-0003kr-Ne for ietf-http-wg-dist@listhub.w3.org; Wed, 13 Feb 2013 04:40:08 +0000
Resent-Date: Wed, 13 Feb 2013 04:40:08 +0000
Resent-Message-Id: <E1U5U8e-0003kr-Ne@frink.w3.org>
Received: from lisa.w3.org ([128.30.52.41]) by frink.w3.org with esmtp (Exim 4.72) (envelope-from <squid3@treenet.co.nz>) id 1U5U8R-0002QJ-N0 for ietf-http-wg@listhub.w3.org; Wed, 13 Feb 2013 04:39:55 +0000
Received: from ip-58-28-153-233.static-xdsl.xnet.co.nz ([58.28.153.233] helo=treenet.co.nz) by lisa.w3.org with esmtp (Exim 4.72) (envelope-from <squid3@treenet.co.nz>) id 1U5U8Q-0006Jr-2t for ietf-http-wg@w3.org; Wed, 13 Feb 2013 04:39:55 +0000
Received: from [192.168.1.103] (unknown [14.1.64.4]) by treenet.co.nz (Postfix) with ESMTP id 4B7ADE6FE5 for <ietf-http-wg@w3.org>; Wed, 13 Feb 2013 17:39:26 +1300 (NZDT)
Message-ID: <511B18FA.1000304@treenet.co.nz>
Date: Wed, 13 Feb 2013 17:39:22 +1300
From: Amos Jeffries <squid3@treenet.co.nz>
User-Agent: Mozilla/5.0 (Windows NT 6.1; WOW64; rv:17.0) Gecko/20130107 Thunderbird/17.0.2
MIME-Version: 1.0
To: ietf-http-wg@w3.org
References: <CAA4WUYjiBZpShKKFfHQnixc94aOLrck0oR4ykARB=hF5h8nkfA@mail.gmail.com> <3430.1359961022@critter.freebsd.dk> <510F72CE.8030003@treenet.co.nz> <CAA4WUYiBJrLjM0-vurFOuJfUaabXtK=W8N5z28yshSfrvD9crg@mail.gmail.com> <1516.1360002578@critter.freebsd.dk> <42A54D15-0AA3-4172-94F7-E94C86E84D7F@niven-jenkins.co.uk> <2346.1360010079@critter.freebsd.dk> <CAA4WUYiyu+JvFuKooqa4xVdCJP=Mngu9dgHjhH99_SEac1kCZQ@mail.gmail.com> <CABaLYCtX04se2BJ0c1yCYkwH2xvkcETdu7Pe+B8fy=DJrouo6Q@mail.gmail.com> <CAA4WUYitNR0js+5m5RHfLp-7=k-mfTUKDcayW-uzJwTgOgMyYQ@mail.gmail.com> <CABkgnnUYKDe4rZ0ZpqASkwDF2Foa_ni1rEFJH1P03k1Bv_NCog@mail.gmail.com> <CAA4WUYg+evqEMdiYSv+EZ7668eCq_dwqKiYmA4Lq-xZkoD_9Fw@mail.gmail.com> <CAK3OfOi7So1KWXdfv+UEqKAr-o1TaXiZmSmJx61WFR3J0zW_JA@mail.gmail.com> <4613980CFC78314ABFD7F85CC3027721119A440A@IL-EX10.ad.checkpoint.com> <CAK3OfOiLVfq7y4SJmoP-JyvgQc5uB8sDTrkDySMZfWqAdYf0yg@mail.gmail.com> <CAP+FsNchpZRLEfHVptV=tsLFHRP_N62QCbAcacvxoCoVhUxqkQ@mail.gmail.com>
In-Reply-To: <CAP+FsNchpZRLEfHVptV=tsLFHRP_N62QCbAcacvxoCoVhUxqkQ@mail.gmail.com>
Content-Type: text/plain; charset="ISO-8859-1"; format="flowed"
Content-Transfer-Encoding: 7bit
Received-SPF: pass client-ip=58.28.153.233; envelope-from=squid3@treenet.co.nz; helo=treenet.co.nz
X-W3C-Hub-Spam-Status: No, score=-3.5
X-W3C-Hub-Spam-Report: AWL=-3.449, SPF_HELO_PASS=-0.001, SPF_PASS=-0.001
X-W3C-Scan-Sig: lisa.w3.org 1U5U8Q-0006Jr-2t b70cd430f86afb72caad848c4e09747d
X-Original-To: ietf-http-wg@w3.org
Subject: Re: http/2 prioritization/fairness bug with proxies
Archived-At: <http://www.w3.org/mid/511B18FA.1000304@treenet.co.nz>
Resent-From: ietf-http-wg@w3.org
X-Mailing-List: <ietf-http-wg@w3.org> archive/latest/16592
X-Loop: ietf-http-wg@w3.org
Resent-Sender: ietf-http-wg-request@w3.org
Precedence: list
List-Id: <ietf-http-wg.w3.org>
List-Help: <http://www.w3.org/Mail/>
List-Post: <mailto:ietf-http-wg@w3.org>
List-Unsubscribe: <mailto:ietf-http-wg-request@w3.org?subject=unsubscribe>

On 13/02/2013 7:18 a.m., Roberto Peon wrote:
>
> The problem that we have here is that the TCP API isn't sufficiently 
> rich to allow us to do the right thing (e.g. read bytes without 
> allowing the sender to send more). As a result, we have to have 
> another level of flow control which we'd otherwise be able to do 
> without. Unfortunately, per priority TCP connections don't work well 
> for large loadbalancers where each of these connections will likely be 
> terminating at a different place. This would create a difficult 
> synchronization problem server side, full of races and complexity, and 
> likely quite a bit worse in complexity than getting flow control 
> working well.

As opposed to HTTP/1.x where each request may have its own TCP 
connection, end up at a different endpoint, and faces identical situation?
Sure this is not a solution to *that* problem, but nothing will.
1) The load balancers very existence purpose is to *create* that problem.

2) HTTP is meant to be stateless remember, so no request depends on any 
other for semantic handling. These high priority and low-priority 
requests you speak of.

3) the frames where statefulness and priority actually matters are 
per-hop control frames. Which the endpoint needing to send is perfectly 
capable of injecting for delivery between any other frames it may have 
queued. Regardless of how or when any other party along the channel 
believes they should be delivered.

So I agree with Nico on this one. Separate TCP connections *are* an 
option. It just has to be made clear in the spec how to identify them at 
the server and how it is expected to prioritize those connections from 
any other more important ones it may be handling in parallel. Any 
endpoint screwups caused by load balancing as a result of handling two 
*independent* requests via different pathways is the responsibility of 
the server admin, site author, or network admins to sort out - not the 
HTTP protocol.

Amos