RE: Unidirectional streams PR

"Lubashev, Igor" <ilubashe@akamai.com> Fri, 07 July 2017 03:07 UTC

Return-Path: <ilubashe@akamai.com>
X-Original-To: quic@ietfa.amsl.com
Delivered-To: quic@ietfa.amsl.com
Received: from localhost (localhost [127.0.0.1]) by ietfa.amsl.com (Postfix) with ESMTP id 16D2E127698 for <quic@ietfa.amsl.com>; Thu, 6 Jul 2017 20:07:37 -0700 (PDT)
X-Virus-Scanned: amavisd-new at amsl.com
X-Spam-Flag: NO
X-Spam-Score: -0.01
X-Spam-Level:
X-Spam-Status: No, score=-0.01 tagged_above=-999 required=5 tests=[BAYES_00=-1.9, DKIM_SIGNED=0.1, DKIM_VALID=-0.1, DKIM_VALID_AU=-0.1, HTML_MESSAGE=0.001, HTTPS_HTTP_MISMATCH=1.989, RCVD_IN_DNSWL_NONE=-0.0001, SPF_PASS=-0.001, URIBL_BLOCKED=0.001] autolearn=ham autolearn_force=no
Authentication-Results: ietfa.amsl.com (amavisd-new); dkim=pass (2048-bit key) header.d=akamai.com
Received: from mail.ietf.org ([4.31.198.44]) by localhost (ietfa.amsl.com [127.0.0.1]) (amavisd-new, port 10024) with ESMTP id Wg_OfUPdY-4X for <quic@ietfa.amsl.com>; Thu, 6 Jul 2017 20:07:32 -0700 (PDT)
Received: from mx0b-00190b01.pphosted.com (mx0a-00190b01.pphosted.com [IPv6:2620:100:9001:583::1]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by ietfa.amsl.com (Postfix) with ESMTPS id 7E2D0126E3A for <quic@ietf.org>; Thu, 6 Jul 2017 20:07:32 -0700 (PDT)
Received: from pps.filterd (m0050093.ppops.net [127.0.0.1]) by m0050093.ppops.net-00190b01. (8.16.0.21/8.16.0.21) with SMTP id v6737R23017678; Fri, 7 Jul 2017 04:07:27 +0100
DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=akamai.com; h=from : to : cc : subject : date : message-id : references : in-reply-to : content-type : mime-version; s=jan2016.eng; bh=FQw1ZLc35Qvc51o3AQD1SpgfjEAuCg+UIyleoisedWQ=; b=OGQY8O1ZFkg9Nl6i6GmFstmCpaIe9x4UukNMDI4YuQ6Wa1yEe9UmPFTPwcwPDBfxjqkL TRaozNeT+KMVse/4224xf4Z9LccY2jsWFDOGP1KmCbxvHMU8UFFgEi2LxNAZcPD516M8 uMRDlLOFckPXlEfGNBWRWXVqRnwFFLUXbWM5rqoeJKIWSozZYoS6ZfHY2HRDGBIANuAH dZQXNPuirJ+aGqb6KOw9CKOUf12bXmj2oSwtdxpadoYy270Z0oOkp1cZB307xSy9I6a/ Ze4oqKHUTQ0BEaHOpBhHr3+utYxTJlZmokioH/Rf+Xv7hWzMwavJcZAwPgUL/cf6Lbvv Qw==
Received: from prod-mail-ppoint1 (a184-51-33-18.deploy.static.akamaitechnologies.com [184.51.33.18] (may be forged)) by m0050093.ppops.net-00190b01. with ESMTP id 2bhry222mf-1 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=NOT); Fri, 07 Jul 2017 04:07:26 +0100
Received: from pps.filterd (prod-mail-ppoint1.akamai.com [127.0.0.1]) by prod-mail-ppoint1.akamai.com (8.16.0.17/8.16.0.17) with SMTP id v6735b0G029019; Thu, 6 Jul 2017 23:07:25 -0400
Received: from email.msg.corp.akamai.com ([172.27.123.34]) by prod-mail-ppoint1.akamai.com with ESMTP id 2be72uem38-1 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-SHA384 bits=256 verify=NOT); Thu, 06 Jul 2017 23:07:24 -0400
Received: from USMA1EX-DAG1MB5.msg.corp.akamai.com (172.27.123.105) by usma1ex-dag1mb1.msg.corp.akamai.com (172.27.123.101) with Microsoft SMTP Server (TLS) id 15.0.1263.5; Thu, 6 Jul 2017 23:07:23 -0400
Received: from USMA1EX-DAG1MB5.msg.corp.akamai.com ([172.27.123.105]) by usma1ex-dag1mb5.msg.corp.akamai.com ([172.27.123.105]) with mapi id 15.00.1263.000; Thu, 6 Jul 2017 23:07:24 -0400
From: "Lubashev, Igor" <ilubashe@akamai.com>
To: "jri@google.com" <jri@google.com>, "subodh@fb.com" <subodh@fb.com>
CC: "quic@ietf.org" <quic@ietf.org>, "kazuhooku@gmail.com" <kazuhooku@gmail.com>, "martin.thomson@gmail.com" <martin.thomson@gmail.com>, "ianswett@google.com" <ianswett@google.com>, "dtikhonov@litespeedtech.com" <dtikhonov@litespeedtech.com>, "mikkelfj@gmail.com" <mikkelfj@gmail.com>, "thomas.swindells@nokia.com" <thomas.swindells@nokia.com>, "jokulik@google.com" <jokulik@google.com>, "Michael.Bishop@microsoft.com" <Michael.Bishop@microsoft.com>
Subject: RE: Unidirectional streams PR
Thread-Topic: Unidirectional streams PR
Thread-Index: AQHS7K8qFJcNmOfPnkGlJjRXQ/9soKI0ttCAgATMZACAAP5zgIAAEIwAgAAHqgCAAA02gIAAfdKAgAARSAD//8GgUIAAXnCAgAm2IgCAAS8I8IAAXHQAgAFYMoD//9Lj2Q==
Date: Fri, 07 Jul 2017 03:07:23 +0000
Message-ID: <070fb70b3674407b817da845f8ed524c@usma1ex-dag1mb5.msg.corp.akamai.com>
References: <CAN1APdc_ckZu39ZZTETv04iZieogoE_NQCBR-n0jHrC-9dM7Aw@mail.gmail.com> <5d69489d-8f46-ebbe-4e5c-fa6c02ffd8dd@huitema.net> <CAF4GZgBm7525i2GxiN-Pv66g0WqbDH==fRXN27=7ursNA70w1Q@mail.gmail.com> <20170628124221.GA15608@ubuntu-dmitri> <CAN1APdc3YO4-FEc6C--PzFGxzQiAUeBZ96HkjtjS1RR0qigrzw@mail.gmail.com> <CAE=ybzNtSZx9-bj9-n-ieLMB=YvJCjCExugvA3_JPVrdEEqK9A@mail.gmail.com> <DB5PR07MB123748F2AB7374DAC0CC9E1484DD0@DB5PR07MB1237.eurprd07.prod.outlook.com> <MWHPR21MB0141BD23011EB26F882C864787DD0@MWHPR21MB0141.namprd21.prod.outlook.com> <CABkgnnXEq9-jxedU_Rmi4XQ+t0SNUOAMbyWXcnhyLKz+OzP2CQ@mail.gmail.com> <2240c2a68910453e97fc50d42e8a1d4f@usma1ex-dag1mb5.msg.corp.akamai.com> <CAKcm_gMb9PkBKhTRF3ue2KGgwHgKN8rsanD8rqqr_wUFJ3GNZQ@mail.gmail.com> <CANatvzyKsi=+V1rYSjYwtkuGnui=V_1f0bbq1iCB36p2GJXDbQ@mail.gmail.com> <ab4e5580e8c14a8a9f2eecc87e8c9976@usma1ex-dag1mb5.msg.corp.akamai.com> <MWHPR15MB14552E4F7BB6BE5FB43A58FDB6D50@MWHPR15MB1455.namprd15.prod.outlook.com>, <CAGD1bZYapGBZ=giDmUbCx+-abA7DCQmO08rLnRn_+DtTRg=Wug@mail.gmail.com>
In-Reply-To: <CAGD1bZYapGBZ=giDmUbCx+-abA7DCQmO08rLnRn_+DtTRg=Wug@mail.gmail.com>
Accept-Language: en-US
Content-Language: en-US
X-MS-Has-Attach:
X-MS-TNEF-Correlator:
x-ms-exchange-transport-fromentityheader: Hosted
Content-Type: multipart/alternative; boundary="_000_070fb70b3674407b817da845f8ed524cusma1exdag1mb5msgcorpak_"
MIME-Version: 1.0
X-Proofpoint-Virus-Version: vendor=fsecure engine=2.50.10432:, , definitions=2017-07-07_02:, , signatures=0
X-Proofpoint-Spam-Details: rule=notspam policy=default score=0 spamscore=0 suspectscore=0 malwarescore=0 phishscore=0 adultscore=0 bulkscore=0 classifier=spam adjust=0 reason=mlx scancount=1 engine=8.0.1-1703280000 definitions=main-1707070046
X-Proofpoint-Virus-Version: vendor=fsecure engine=2.50.10432:, , definitions=2017-07-07_02:, , signatures=0
X-Proofpoint-Spam-Details: rule=notspam policy=default score=0 priorityscore=1501 malwarescore=0 suspectscore=0 phishscore=0 bulkscore=0 spamscore=0 clxscore=1011 lowpriorityscore=0 impostorscore=0 adultscore=0 classifier=spam adjust=0 reason=mlx scancount=1 engine=8.0.1-1703280000 definitions=main-1707070047
Archived-At: <https://mailarchive.ietf.org/arch/msg/quic/6aPQ220pauXnzae3ZuVu-kgRydg>
X-BeenThere: quic@ietf.org
X-Mailman-Version: 2.1.22
Precedence: list
List-Id: Main mailing list of the IETF QUIC working group <quic.ietf.org>
List-Unsubscribe: <https://www.ietf.org/mailman/options/quic>, <mailto:quic-request@ietf.org?subject=unsubscribe>
List-Archive: <https://mailarchive.ietf.org/arch/browse/quic/>
List-Post: <mailto:quic@ietf.org>
List-Help: <mailto:quic-request@ietf.org?subject=help>
List-Subscribe: <https://www.ietf.org/mailman/listinfo/quic>, <mailto:quic-request@ietf.org?subject=subscribe>
X-List-Received-Date: Fri, 07 Jul 2017 03:07:37 -0000

> I'm not sure I understand what sort of proxy would want to know about stream closures...

Any proxy that keeps per-stream state would want to know about stream closures (just like the endpoint transport implementation would).

Say you have a fast and reliable network to which devices with very limited amount of memory are attached (sensors on a Mars station connected to the station network). But this network is connected to the Internet via a slow and unreliable link (satellite?). To communicate with far-away endpoints over slow and unreliable links, you need a lot of memory, or your throughput suffers. The solution could be a proxy on the border of this network. Such proxy would mediate QUIC connections between the limited-memory devices and Internet endpoints. The proxy would ACK all packets itself, while maintaining big enough buffers to retransmit stream data sent to the Internet and reassemble streams from the Internet. (One can think of similar situations closer to Earth, of course.)

-----Original Message-----
From: Jana Iyengar [jri@google.com]
Received: Thursday, 06 Jul 2017, 9:48PM
To: Subodh Iyengar [subodh@fb.com]
CC: Lubashev, Igor [ilubashe@akamai.com]; Kazuho Oku [kazuhooku@gmail.com]; Ian Swett [ianswett@google.com]; Mike Bishop [Michael.Bishop@microsoft.com]; Dmitri Tikhonov [dtikhonov@litespeedtech.com]; Swindells, Thomas (Nokia - GB/Cambridge, UK) [thomas.swindells@nokia.com]; Jo Kulik [jokulik@google.com]; Mikkel Fahnøe Jørgensen [mikkelfj@gmail.com]; QUIC WG [quic@ietf.org]; Martin Thomson [martin.thomson@gmail.com]
Subject: Re: Unidirectional streams PR

On Wed, Jul 5, 2017 at 10:16 PM, Subodh Iyengar <subodh@fb.com<mailto:subodh@fb.com>> wrote:

> Without such a signal, a generic proxy that is not aware of your application internals is not able to know when to send the FIN

I see, this use case does make somewhat sense, however I'm curious if someone has a concrete use case for a generic QUIC proxy which is not aware of the application protocol at all. In TCP this was more common for middleboxes to do because there was no end to end encryption of the transport, however QUIC is encrypted. Even with cases when we tunneling protocols at our end, we usually have some knowledge of the app that we are running because we need to route them differently to different backends. I was mostly thinking that proxies would at least have some knowledge about HTTP/2 or app protocols.

This is my thinking too. I'm not sure I understand what sort of proxy would want to know about stream closures... but if such a proxy exists, it justifies the explicit signal.

Maybe it is possible to make #656 more palatable, at least to me. I had 2 things against it initially, which were:


  1.  We might need to add another state to the machine to the sender state, i.e. normally when sending a FIN, it is ok to keep receiving stream frames after, however in a uni directional stream it is illegal to get a stream frame.
  2.  In its current form it also has an implicit requirement to not open lower streams. I think opening lower streams have some desirable properties which I've commented on in https://github.com/quicwg/base-drafts/issues/662<https://urldefense.proofpoint.com/v2/url?u=https-3A__github.com_quicwg_base-2Ddrafts_issues_662&d=DwMFaQ&c=96ZbZZcaMF4w0F4jpN6LZg&r=Djn3bQ5uNJDPM_2skfL3rW1tzcIxyjUZdn_m55KPmlo&m=nUIKlIBqPqjVljTh1PhBhHP75fAW7-4WhWrKD26rfz4&s=SZ7WecZx9-JS9RjTS0c2nhWXRlgScSi1XqtFOSDn9W8&e=>.

An implementation could probably implement 1. with not too much trouble by doing a special case in the stream state machine when it receives a stream frame in the half closed local state.

I think this is covered by the current half-closed state. When an outgoing uni stream is created, it should have a final received offset of 0. If any STREAM frames are received that have data at an offset > the final received offset (which is 0 in this case), then the connection is torn down with QUIC_STREAM_DATA_AFTER_TERMINATION error (see Section 11.3<https://urldefense.proofpoint.com/v2/url?u=https-3A__tools.ietf.org_html_draft-2Dietf-2Dquic-2Dtransport-2D04-23section-2D11.3&d=DwMFaQ&c=96ZbZZcaMF4w0F4jpN6LZg&r=Djn3bQ5uNJDPM_2skfL3rW1tzcIxyjUZdn_m55KPmlo&m=nUIKlIBqPqjVljTh1PhBhHP75fAW7-4WhWrKD26rfz4&s=uCU3ExruisXB9KCiImOF2DuRt36XRdn2Tn6n3tqg2YM&e=>).

For 2. thinking about it a bit more I think the underlying question here is who enforces directionality, i.e. did I receive data I should not have. If it is the transport, then we need to answer that question with issue #662, however if it can be the application or a higher layer API between the application and transport that enforces directionality then we don't need to know whether a lower stream is bi-directional or not. I'm leaning towards an API between the transport and application enforcing directionality. The reason for that is that an application that needs to use unidirectionality needs to use a different API anyway. Given that we could leave lower streams to be opened as it is now, but leaving the exact semantics of enforcing bi-directionality or uni-directionality to a higher layer. That should suffice for even a generic proxy right?

I thought about this, and I'm leaning towards having the transport enforce this.

I like your suggestion of moving this logic up to the application. Implicit open is then just "open", and then the stream moves into half-closed state as it receives an application signal or a STREAM frame with the bit set. The tradeoff to consider here is that an implementation will not be able to instantiate an "optimized" uni stream on implicit creation (or will have to swap a bidirectional stream with a uni one). There's value in allowing implementations to implement optimized uni/bi stream objects, which would mean that the transport ought to be able to create one of these two types of objects, therefore allowing (requiring?) enforcement of directionality in the transport.

Can you resolve #662 with a separate state? Meaning that implicitly open streams are now considered "reserved" (or some such). This allows you to have a separate state until you know for sure which type of stream you're constructing, which can happen via an application signal or from a received STREAM frame.

I still prefer do nothing with app directed close though.

Having an explicit bit in the frame does allow for some more flexibility, which may be useful.

> But I do not think that we should require every application protocol built above QUIC to do its own framing.

Second Kazuho on this one.

+1. This is the biggest argument for bidirectionality -- most applications need that, and expecting them to all create their own correlators and state machine to manage bidirectionality goes against what I'd consider useful transport API design. Extremely common design patterns, such as bidirectionality, should be part of the transport.

- jana

Subodh

________________________________
From: QUIC <quic-bounces@ietf.org<mailto:quic-bounces@ietf.org>> on behalf of Lubashev, Igor <ilubashe@akamai.com<mailto:ilubashe@akamai.com>>
Sent: Wednesday, July 5, 2017 8:50:05 PM
To: Kazuho Oku; Ian Swett
Cc: Mike Bishop; Dmitri Tikhonov; Swindells, Thomas (Nokia - GB/Cambridge, UK); Jo Kulik; Mikkel Fahnøe Jørgensen; QUIC WG; Martin Thomson

Subject: RE: Unidirectional streams PR

> If a client needs a way to reset the server's response before observing the first frame, it cannot use FIN as an indicator of the end of the request.

There is a DISINTEREST frame proposal (PR #171: https://github.com/quicwg/base-drafts/pull/171<https://urldefense.proofpoint.com/v2/url?u=https-3A__github.com_quicwg_base-2Ddrafts_pull_171&d=DwMFaQ&c=96ZbZZcaMF4w0F4jpN6LZg&r=Djn3bQ5uNJDPM_2skfL3rW1tzcIxyjUZdn_m55KPmlo&m=nUIKlIBqPqjVljTh1PhBhHP75fAW7-4WhWrKD26rfz4&s=vUU1jpQB1L_xAsDNdBWa6XhQ8_fzM4EF2uP5uq57dEo&e=>).  That's something that I believe is valuable independent of this Unidirectional streams PR.

- Igor


-----Original Message-----
From: Kazuho Oku [mailto:kazuhooku@gmail.com]
Sent: Wednesday, July 05, 2017 1:41 AM
To: Ian Swett <ianswett@google.com<mailto:ianswett@google.com>>
Cc: Lubashev, Igor <ilubashe@akamai.com<mailto:ilubashe@akamai.com>>; Mike Bishop <Michael.Bishop@microsoft.com<mailto:Michael.Bishop@microsoft.com>>; Dmitri Tikhonov <dtikhonov@litespeedtech.com<mailto:dtikhonov@litespeedtech.com>>; Swindells, Thomas (Nokia - GB/Cambridge, UK) <thomas.swindells@nokia.com<mailto:thomas.swindells@nokia.com>>; Jo Kulik <jokulik@google.com<mailto:jokulik@google.com>>; Mikkel Fahnøe Jørgensen <mikkelfj@gmail.com<mailto:mikkelfj@gmail.com>>; QUIC WG <quic@ietf.org<mailto:quic@ietf.org>>; Martin Thomson <martin.thomson@gmail.com<mailto:martin.thomson@gmail.com>>
Subject: Re: Unidirectional streams PR

2017-06-29 10:23 GMT+09:00 Ian Swett <ianswett@google.com<mailto:ianswett@google.com>>:
> I updated my PR(#656) today, sorry for the delay.  I attempted to
> address the issues identified with text.  Some may prefer more tweaks
> to the state diagram, which are also possible, so I'm open to suggestions.

After all, I think that the approach proposed here is the most well-balanced one.

As much as I think that having first-class support for unidirectional streams is preferable, I also think that we should keep the overall architecture (i.e. sum of the complexity in the transport layer and the application layer) as simple as possible.

IMO having support for bidirectional streams (along with support for unidirectional streams) aligns with such intention.

Most of the application protocols that will be deployed over the QUIC transport will be in request-response style, at least to some extent.
Hence it is preferable for the transport layer to provide a framework that fits such style.

Bidirectional streams provide the necessary features. FIN provides a way to indicate the end of the message. RST provides a way to cancel the exchange of the message in both directions.

IMO the biggest issue with the unidirectional-only approach is that you cannot have the two features together. If a client needs a way to reset the server's response before observing the first frame, it cannot use FIN as an indicator of the end of the request.

It is true that the issue can be evaded by doing one's own framing in the application layer. #643 does that by introducing a CANCEL_REQUEST frame.

But I do not think that we should require every application protocol built above QUIC to do its own framing. In addition to that, need to keep two uni-directional streams open would consume more resources than being able to close one direction of a bi-directional stream at an earlier moment.

> In the meantime, I've been considering other alternatives, including
> variations on Mike's direction and a variation of the "Do Nothing"
> option which involved the application signaling to the transport that
> streams of a certain sort(ie: server to client for server push) were
> unidirectional, as GQUIC does today.  Overall, I think the approach
> I've outlined does a good job of iterating on existing deployment
> experience and adding explicit signaling for unidirectional streams
> instead of implicit signaling at the application layer.  There are
> pros and cons to both explicit and implicit signaling, but I think
> explicit signaling is more complete and less prone to application error.
>
> Thanks, Ian
>
>
> On Wed, Jun 28, 2017 at 8:14 PM, Lubashev, Igor <ilubashe@akamai.com<mailto:ilubashe@akamai.com>> wrote:
>>
>> > unless what the transport provides is a perfect fit for application
>> > semantics, you end up building those semantics into the application anyway.
>>
>> I agree with this. We should avoid adding complexity into transport
>> for rare use cases, since it goes against KISS principle.
>>
>> On the other hand, adding support for a by far the most common use
>> case makes a lot of sense.  This helps apps avoid screwing up
>> implementing that common case and lets us optimize that common case
>> in the lower layer. BiDi streams are such common cases. Uni streams
>> are likely to be the second-most-common cases (hence you offered this PR to optimize them).
>>
>>
>> The Associated Streams proposal offers extra semantic flexibility at
>> a cost of some semantic complexity (someone would need to verify that
>> the associated stream numbers make sense -- api? apps?) and a few extra bytes.
>>
>> I'd like to wait to see Ian's revised proposal.  The initial proposal
>> offered to do only one thing -- offer a choice of uni/bi-directional
>> streams
>> -- but it did it in a very simple way, which is nice.
>>
>> - Igor
>>
>>
>> -----Original Message-----
>> From: Martin Thomson [mailto:martin.thomson@gmail.com]
>> Sent: Wednesday, June 28, 2017 7:28 PM
>> To: Mike Bishop <Michael.Bishop@microsoft.com<mailto:Michael.Bishop@microsoft.com>>
>> Cc: Swindells, Thomas (Nokia - GB/Cambridge, UK)
>> <thomas.swindells@nokia.com<mailto:thomas.swindells@nokia.com>>; QUIC WG <quic@ietf.org<mailto:quic@ietf.org>>; Mikkel Fahnøe
>> Jørgensen <mikkelfj@gmail.com<mailto:mikkelfj@gmail.com>>; Dmitri Tikhonov
>> <dtikhonov@litespeedtech.com<mailto:dtikhonov@litespeedtech.com>>; Jo Kulik <jokulik@google.com<mailto:jokulik@google.com>>
>> Subject: Re: Unidirectional streams PR
>>
>> There is probably a simpler approach here, take a bit (as Ian did)
>> and say that if that bit is set, then the stream is in response to
>> another and the stream ID of the stream to which this is responding
>> follows immediately after the stream ID of the stream itself.  You
>> could then include that only at the start of the stream, or in multiple frames (or as we decide).
>>
>> The problem with this, as with several of the other issues we're
>> discussing, is that unless what the transport provides is a perfect
>> fit for application semantics, you end up building those semantics
>> into the application anyway.  HTTP certainly can't survive without
>> its own association semantics for pushes.  That suggests to me that
>> having bidirectional semantics in the transport creates more
>> duplication than otherwise.  Hence my proposal.
>>
>> On 28 June 2017 at 15:26, Mike Bishop <Michael.Bishop@microsoft.com<mailto:Michael.Bishop@microsoft.com>>
>> wrote:
>> > As promised, a PR for adding “associated streams” is at
>> > https://github.com/quicwg/base-drafts/pull/672<https://urldefense.proofpoint.com/v2/url?u=https-3A__github.com_quicwg_base-2Ddrafts_pull_672&d=DwMFaQ&c=96ZbZZcaMF4w0F4jpN6LZg&r=Djn3bQ5uNJDPM_2skfL3rW1tzcIxyjUZdn_m55KPmlo&m=nUIKlIBqPqjVljTh1PhBhHP75fAW7-4WhWrKD26rfz4&s=BpuekjI8WR8_GGDuIgRp0wW2dylR52OtLbuxONJGujY&e=>.  This very
>> > deliberately builds on top of MT’s PR – it’s adding a primitive
>> > which can be used to construct various abstractions atop
>> > unidirectional streams, but the lifecycle is still fundamentally unidirectional.
>> >
>> >
>> >
>> > Copying my notes here for list discussion purposes.
>> >
>> > Major changes
>> >
>> > Leveraging @igorlord's insight that OO=00 only occurs on the first
>> > STREAM frame of a stream, I used that as the trigger for a Stream
>> > Properties byte.
>> > Two bits of that byte describe the directionality of the stream:
>> >
>> > Unidirectional (no response expected) Initial bidirectional (one
>> > response expected) Initial multi-response (one or more responses
>> > expected; needs a better name) Response
>> >
>> > If the type is Response, there's an Associated Stream ID field,
>> > length given by two more bits following the same pattern as the SS
>> > bits in the STREAM frame ID.
>> >
>> > Personal Opinion
>> >
>> > On the plus side, these stream types seem to cover the abstractions
>> > I can envision for most applications. You can unilaterally send
>> > something (unidirectional), do request/response (bidirectional), or
>> > pub/sub (single subscription stream, series of update streams).
>> >
>> > I don't care for the fact that I still need the stream type header
>> > in HTTP after putting this in the transport. That will be
>> > ameliorated if we go back to one stream per request, since all
>> > unidirectional streams will be push streams. (As a side-note, I
>> > considered using the multiple-response option in the HTTP mapping,
>> > but then I need a stream header again to indicate which is the
>> > response and which the pushes.)
>> >
>> > I particularly don't like that you now have to look at the frame
>> > type header to find out whether a field exists which tells you the
>> > length of something else in the header. I'd like to simplify that.
>> > I went with this model over a CREATE_STREAM frame because of
>> > @mikkelfj's use-case of very small messages
>> > -- this adds only one byte to the first frame on a stream in one
>> > direction and 2-5 bytes to the first frame of response streams. A
>> > separate frame type would be somewhat larger, but could be cleaner
>> > in that respect.
>> >
>> >
>> >
>> >
>> >
>> > From: QUIC [mailto:quic-bounces@ietf.org] On Behalf Of Swindells,
>> > Thomas (Nokia - GB/Cambridge, UK)
>> > Sent: Wednesday, June 28, 2017 7:56 AM
>> > To: Jo Kulik <jokulik@google.com<mailto:jokulik@google.com>>; Mikkel Fahnøe Jørgensen
>> > <mikkelfj@gmail.com<mailto:mikkelfj@gmail.com>>
>> > Cc: QUIC WG <quic@ietf.org<mailto:quic@ietf.org>>; Dmitri Tikhonov
>> > <dtikhonov@litespeedtech.com<mailto:dtikhonov@litespeedtech.com>>
>> > Subject: RE: Unidirectional streams PR
>> >
>> >
>> >
>> > I agree that looking at the layers of abstraction is useful. In
>> > principle having the wire protocol just have constructs for
>> > unidirectional streams does not in itself limit creating
>> > bi-directional communication flows, supported at either the library
>> > or application layer.
>> >
>> >
>> >
>> > However, there need to be a standard way of doing bi-directional
>> > communication for migrating applications implemented using a socket
>> > style api. It needs to be easy to move an existing application from
>> > TCP to QUIC.
>> > This move may be attractive in many situations as QUIC gives
>> > improved security and may allow greater throughput due to the more
>> > modern (and
>> > customizable) congestion control algorithms compared to the OS TCP
>> > stack.
>> >
>> >
>> >
>> > For migrating standard socket api applications I don’t think it
>> > would be appropriate to leave the work to the application to do
>> > correlation, at least the library should be providing this service
>> > using the wire protocol as appropriate. Clearly we want a client
>> > written with one library to be able to communicate successfully
>> > with a server written using a different library.
>> > This needs some form of standardization of the signalling. This
>> > could either be a building block overlay on top of QUIC, or
>> > implemented at the wire protocol level.
>> >
>> >
>> >
>> > In terms of patterns I think the following may be some of the most
>> > common patterns (with potential to be provided at the library and
>> > or wire protocol level).
>> >
>> > I/O pattern  : Example
>> >
>> > 1/0   : An input only flow, perhaps a data logger like syslog with no
>> > confirmation/feedback
>> >
>> > 0/1  : an output only flow, perhaps a topic message bus service
>> > with no confirmation/feedback
>> >
>> > 1/1 : standard TCP applications with a single flow per connection
>> >
>> > 1/* : single input, many output, modelling STDIN/STDOUT+STDERR
>> >
>> > (1/1)* : multiplexed pairs of flows – supporting multiple sockets
>> > muxed onto a single QUIC connection
>> >
>> >
>> >
>> > Obviously, an application would always have the option to combine
>> > any single direction flows with application level correlators to
>> > construct more complex flows if desired.
>> >
>> >
>> >
>> > At the moment my gut says the 1/1 use-case is common enough that
>> > the wire protocol should provide a standard mechanism to support it
>> > as a standard overlay would probably end up being treated as part
>> > of the wire format anyway.
>> >
>> >
>> >
>> > Perhaps streams should be explicitly created with a CREATE_STREAM
>> > frame which would be capable of defining multiple related streams?
>> >
>> > There is the option of whether only (1/1) pairs can be created this
>> > way, or
>> > (1/n) combinations could be supported (with an application defined
>> > way to identify the use of each of the output streams). A step
>> > further may be that there is a transport parameter that defines
>> > whether the server is allowed to create additional streams, or if
>> > stream creation is purely client driven (like TCP). I don’t know if
>> > either of these would simplify how to handle stream accounting, and
>> > in particular only creating a flow when all parties have sufficient allowances left.
>> >
>> >
>> >
>> > Thomas
>> >
>> >
>> >
>> > From: QUIC [mailto:quic-bounces@ietf.org] On Behalf Of Jo Kulik
>> > Sent: 28 June 2017 15:09
>> > To: Mikkel Fahnøe Jørgensen <mikkelfj@gmail.com<mailto:mikkelfj@gmail.com>>
>> > Cc: QUIC WG <quic@ietf.org<mailto:quic@ietf.org>>; Dmitri Tikhonov
>> > <dtikhonov@litespeedtech.com<mailto:dtikhonov@litespeedtech.com>>
>> > Subject: Re: Unidirectional streams PR
>> >
>> >
>> >
>> > I'd like to pop back up to a comment Igor made last week, because I
>> > find it helpful in thinking about the design space:
>> >
>> >
>> >
>> > I think of three layers of abstraction:
>> >
>> > 1.       QUIC Wire Protocol (the thing described by the QUIC Transport
>> > RFC)
>> > 2.       QUIC Library API (a library exposing some useful abstractions
>> > --
>> > such as blocking/non-blocking unidirectional streams and
>> > bidirectional “sockets” -- and implementing them using QUIC Wire Protocol)
>> > 3.       Application (something that uses QUIC Library APIs)
>> >
>> > I think there is some argument to be made that Martin's original
>> > proposal did not take into account how we would achieve (2) for
>> > bi-directional streams.  (I don't think it strictly said "thou
>> > shalt not do (2)" either, but that is up to interpretation.)
>> >
>> >
>> >
>> > Several people have argued that we do not want every application to
>> > have to re-implement bi-directional streams (3) for every
>> > application, and this is not how g-quic (our largest deployment) works right now.
>> > These arguments make sense to me, but YMMV.
>> >
>> >
>> >
>> > Just because the particular *mechanism* that is being proposed has
>> > some issues, however, doesn't scream out to me, at least, that we
>> > should abandon this particular *design goal*.  The goal being a
>> > transport protocol that can elegantly fit with a uni/bi stream model.
>> > Now, if we conclude that there can never be an elegant model that
>> > achieves this goal, then so be it.  But I also feel like we haven't
>> > reached that point in the discussion yet.  (At the very least, this
>> > discussion has been fruitful to me in terms of mapping the design
>> > space and elucidating requirements).
>> >
>> >
>> >
>> > One of the reasons I still think this design goal is under
>> > consideration is that Ian and Igor/Mike have been talking about
>> > alternate solutions which have a similar flavor.  During the recent
>> > "quiet"ness on the thread, personally, I've been waiting to hear
>> > more from them.
>> >
>> >
>> >
>> > On Wed, Jun 28, 2017 at 9:41 AM, Mikkel Fahnøe Jørgensen
>> > <mikkelfj@gmail.com<mailto:mikkelfj@gmail.com>> wrote:
>> >
>> > In reply to Ranjeeth
>> >
>> >
>> >
>> > It is not only a matter of simplicity for the sake of simplicity:
>> >
>> >
>> >
>> > - A complex transport layer might end up being poorly implemented
>> > leading to reduced interoperability and ultimately adoption. This
>> > complexity is not only in implementation but also in understanding
>> > the exact semantics of stream lifetime. Even if the spec is
>> > sufficiently clear, it will still be open to misinterpretations.
>> >
>> >
>> >
>> > - Bi-directional state may have to be maintained longer and with
>> > more overhead than with uni-directional streams, especially under
>> > loss, potentially leading to poor performance and poor resource
>> > utilisation because the transport layer has insufficient information.
>> >
>> >
>> >
>> > - The extra complexity at the application layer may be overstated -
>> > it is significantly simpler to manage a map that associates to two
>> > streams than it is to maintain bi-directional state at the
>> > transport layer. It is even possible to implicitly link streams
>> > with same identifiers, e.g. in a RPC scenario. That said, I do see
>> > a potential benefit of a wrapper that implements the common bi-directional case.
>> >
>> >
>> >
>> > - Complexity at the application layer may be duplicated, but
>> > implementation errors are also isolated to that application.
>> > Specifically for HTTP I would assume that QUIC transport and QUIC
>> > HTTP implementers would be large the same for a long time to come,
>> > so I would not expect the tradeoff here to be particularly concerning.
>> >
>> >
>> >
>> > - Unix pipes are traditionally constructed as a pair of
>> > uni-directional file descriptors and that is a reasonably proven
>> > model. C’s standard library stdin, stdout and stderr is an example
>> > of an asymmetric model with implicit linkage between
>> > uni-directional file descriptors.
>> >
>> >
>> >
>> > - There are lots of use cases for non-HTTP like connectivity -
>> > Kafka high volume message queuing for example. The industry trend
>> > appears to move towards asynchronous processing and messaging. It
>> > depends on whether you look at QUIC as a TCP + TLS replacement, or
>> > as a HTTPS / REST RPC replacement.
>> >
>> >
>> >
>> > - Uni-directional streams may currently be unproven in the wild,
>> > but a proposal is needed before an implementation can be made and
>> > testet. I agree that it is easy to design into wrong assumptions
>> > without real world testing.
>> >
>> >
>> >
>> > - There will hopefully not be a large number of successors to QUIC
>> > - perhaps some purpose specific variants, e.g. for embedded use.
>> > Widespread adaptation and compatibility is very necessary so it
>> > makes sense to have QUIC being sufficiently simple and expressive
>> > to achieve this goal. A polymorf QUIC will not achieve that goal.
>> > On the other hand, a solid QUIC foundation can be used for a large
>> > number of application protocols.
>> >
>> >
>> >
>> > - Finally, it may turn out that uni-directional streams just is a
>> > bad idea - I doubt it, but I do believe real world tests are needed.
>> >
>> >
>> >
>> > Kind Regards,
>> >
>> > Mikkel Fahnøe Jørgensen
>> >
>> >
>> >
>> > On 28 June 2017 at 14.42.36, Dmitri Tikhonov
>> > (dtikhonov@litespeedtech.com<mailto:dtikhonov@litespeedtech.com>)
>> > wrote:
>> >
>> > On Tue, Jun 27, 2017 at 02:31:38PM -0700, Ranjeeth Kumar Dasineni wrote:
>> >> 2. We are overplaying the simplicity of design. Even if we deem
>> >> deployment experience not a concern, if every application layer
>> >> protocol that needs support for bidirectional streams has to
>> >> implement some correlators and such above, that's a net negative
>> >> in terms of complexity.
>> >
>> > This is an important point: we want QUIC adoption to be made easy.
>> > A program that speaks HTTP today should be able to use an existing
>> > QUIC library without having to emulate bidirectional streams in
>> > order to fit it into HTTP usage pattern. Forcing every one of these
>> > programs to do this is certainly a hurdle.
>> >
>> > - Dmitri.
>> >
>> >
>>
>



--
Kazuho Oku