[tsvwg] Re: [EXTERNAL] Re: [gwhiteCL/NQBdraft] Should traffic protection be mandatory to implement? (Issue #48)

Sebastian Moeller <moeller0@gmx.de> Wed, 24 July 2024 06:41 UTC

Return-Path: <moeller0@gmx.de>
X-Original-To: tsvwg@ietfa.amsl.com
Delivered-To: tsvwg@ietfa.amsl.com
Received: from localhost (localhost [127.0.0.1]) by ietfa.amsl.com (Postfix) with ESMTP id 09CFDC1D4CEF; Tue, 23 Jul 2024 23:41:21 -0700 (PDT)
X-Virus-Scanned: amavisd-new at amsl.com
X-Spam-Flag: NO
X-Spam-Score: -6.853
X-Spam-Level:
X-Spam-Status: No, score=-6.853 tagged_above=-999 required=5 tests=[BAYES_00=-1.9, DKIM_SIGNED=0.1, DKIM_VALID=-0.1, DKIM_VALID_AU=-0.1, DKIM_VALID_EF=-0.1, FREEMAIL_ENVFROM_END_DIGIT=0.25, FREEMAIL_FROM=0.001, RCVD_IN_DNSWL_HI=-5, RCVD_IN_MSPIKE_H3=0.001, RCVD_IN_MSPIKE_WL=0.001, RCVD_IN_ZEN_BLOCKED_OPENDNS=0.001, SPF_HELO_NONE=0.001, SPF_PASS=-0.001, T_SCC_BODY_TEXT_LINE=-0.01, URIBL_BLOCKED=0.001, URIBL_DBL_BLOCKED_OPENDNS=0.001, URIBL_ZEN_BLOCKED_OPENDNS=0.001] autolearn=ham autolearn_force=no
Authentication-Results: ietfa.amsl.com (amavisd-new); dkim=pass (2048-bit key) header.d=gmx.de
Received: from mail.ietf.org ([50.223.129.194]) by localhost (ietfa.amsl.com [127.0.0.1]) (amavisd-new, port 10024) with ESMTP id Ggfp-0xfRfeE; Tue, 23 Jul 2024 23:41:16 -0700 (PDT)
Received: from mout.gmx.net (mout.gmx.net [212.227.15.18]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange ECDHE (P-256) server-signature RSA-PSS (2048 bits) server-digest SHA256) (No client certificate requested) by ietfa.amsl.com (Postfix) with ESMTPS id 490B5C1388B7; Tue, 23 Jul 2024 23:41:16 -0700 (PDT)
DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmx.de; s=s31663417; t=1721803269; x=1722408069; i=moeller0@gmx.de; bh=MbuM5Krytw7Rqs/NFmEvPKbOaScAMRKzFfzJ0kQcC40=; h=X-UI-Sender-Class:Date:From:To:CC:Subject:In-Reply-To:References: Message-ID:MIME-Version:Content-Type:Content-Transfer-Encoding:cc: content-transfer-encoding:content-type:date:from:message-id: mime-version:reply-to:subject:to; b=gfFxz7CUAU1jHtTfJ0U/LWz7ejFJEliwuju/IaS152qYvZ2R7HPlMX19Kd2vTs1/ Wk5Q94dwTjdzdkQLL+DbwAD8QVCVZuOO41TkJSTMWXRCD/L+x2YMgkQrR5rFxddd3 NojRqyM7v5PUg4pldFHE330jnI1UHaEhu8WkWLHbNc+Che/StMsgcnZy66xNWorpz fxT13qVem8nJdfnEKottQbHiEDAL5ljXcVKXVSqoLA2+ZkBbaSCFUAFObRunJ4MoU io7bqxTJCWpM6w7yy2It5JM9GrrvRQMNDEv5zgQQava5CDU/ZIUy11OPxpGEeGFdN NC9uEfKkezkgoIZT2w==
X-UI-Sender-Class: 724b4f7f-cbec-4199-ad4e-598c01a50d3a
Received: from [127.0.0.1] ([80.187.120.69]) by mail.gmx.net (mrgmx005 [212.227.17.190]) with ESMTPSA (Nemesis) id 1MPXhA-1st8uU46Hy-00LBCR; Wed, 24 Jul 2024 08:41:09 +0200
Date: Wed, 24 Jul 2024 08:41:05 +0200
From: Sebastian Moeller <moeller0@gmx.de>
To: tsvwg@ietf.org, "Overcash, Michael (CCI-Atlanta)" <michael.overcash=40cox.com@dmarc.ietf.org>, "Black, David" <David.Black=40dell.com@dmarc.ietf.org>, gwhiteCL/NQBdraft <reply+AB2VULW2XRH6MPK23ABRZQOEVLRFREVBNHHI5USV5Y@reply.github.com>, gwhiteCL/NQBdraft <NQBdraft@noreply.github.com>
User-Agent: K-9 Mail for Android
In-Reply-To: <LV2PR01MB7622B7EA53C95951987C9B0B9FA92@LV2PR01MB7622.prod.exchangelabs.com>
References: <gwhiteCL/NQBdraft/issues/48@github.com> <gwhiteCL/NQBdraft/issues/48/2244060936@github.com> <MN2PR19MB404591B9BAA1AEED7BBB900983A92@MN2PR19MB4045.namprd19.prod.outlook.com> <LV2PR01MB7622B7EA53C95951987C9B0B9FA92@LV2PR01MB7622.prod.exchangelabs.com>
Message-ID: <26D2AD7F-108B-4655-87F6-EF5E127B3BB8@gmx.de>
MIME-Version: 1.0
Content-Type: text/plain; charset="utf-8"
Content-Transfer-Encoding: quoted-printable
X-Provags-ID: V03:K1:OYwBIuOLlvuNopflj2MVSTPxIxeBG1u6t+CiNHyUmi9ZC3xzDPC Oyy8VGUeR/peeocChqveuE4avXMtLVar7G6FSVm+xvQZPGgP9X6PW+uQZe504oSRsA/yWoV Kn+YmKCovAWeeMmMoJEDKTt0AqtrZy6jZS3FrIiL6U2hV7S6uitY4/AapKBXy1n/pdjrIEW V8uQa7L7cHHv8JcgE2YCw==
UI-OutboundReport: notjunk:1;M01:P0:oGXimycLes0=;5bnBFJUeicic49ubwN0K9RM5+My iaPYFTgbhGFmwRt/y9YVcpV9yfniw30RWGyfPuc0wUTgyfTIZCe2+kuDQXiZT60IMfUjIxNbM NKux8WzXKS0PXXvWkFgjpa5uSUS/vpT4DnsrfwbDfbzzXBrKzrmN9NmFS+HPXI3hcM8lOSibs SP5CnkJpPtuHj7UppJML3NgLdEdT8Y6lteFKyI2B+ywNaoxr8wkLoVolIzN3OfdJEnb1XzIB4 y/mQCUJscigiMDb/QxJ5ikMjNWZUgRrX0LiOnWtwCr6l8nI6bp0PFq9O5bMKvjK78gcjCP75h d7lqxzPRetuIKPZt81/XVWyhhHDtnw4p+IiYLpOBmTwEx+Y8a57kBA+1Y6JcYMr9xUT+S0EO2 kp2U3SzjlBzffMEeWzKjOUIWBBAgD/9NnM2ZRIDkp9eCbTZRmXYOglN9CAOwYgK+8/7OI5vSj vQMJ3te3WFycgUB+L5PKA6by7VPmLksgO/2/YwExrgK9ErFa5U+9vrnTY8aJaSEL/b4mg68Lz FSZKObZFbleTbGvb2MWAkSTylNkIon2hfEQlwSCqB4sHkSMUjmztKoJAqK8naevt4rZjkuLJ5 aA62MbDta8Ckvc4FTwIEA9iX3OqeyIJoHS7Vu44sSOzqeAFgmIWN6jkAMW3IDqmR3JxKVX4Q/ IqS7XyVrPMCgJuqY07I64uC9FWp4eFhC27LQU6KrdKtVz0tOnhefz9oNSGdMvyQrNpq+d46WO HRwc03pIKLRDvijrjHpMPRyNRfPTkKBgCf2y8nUfI4PhRhRO3CAvQhGIoi+wW/g5Yevm/kdRh bUiKZ4DfdjM0MZOTWumwfd9uTIzH2I+702tGQs/dWT4dE=
Message-ID-Hash: KAE6NUNMLLZU6KCSLR7WW2SFVZP7PJ4P
X-Message-ID-Hash: KAE6NUNMLLZU6KCSLR7WW2SFVZP7PJ4P
X-MailFrom: moeller0@gmx.de
X-Mailman-Rule-Misses: dmarc-mitigation; no-senders; approved; emergency; loop; banned-address; member-moderation; header-match-tsvwg.ietf.org-0; nonmember-moderation; administrivia; implicit-dest; max-recipients; max-size; news-moderation; no-subject; digests; suspicious-header
CC: "Black, David" <David.Black@dell.com>, tsvwg IETF list <tsvwg@ietf.org>
X-Mailman-Version: 3.3.9rc4
Precedence: list
Subject: [tsvwg] Re: [EXTERNAL] Re: [gwhiteCL/NQBdraft] Should traffic protection be mandatory to implement? (Issue #48)
List-Id: Transport Area Working Group <tsvwg.ietf.org>
Archived-At: <https://mailarchive.ietf.org/arch/msg/tsvwg/_c01OPhHN075WQtPPGWPLW6lRgg>
List-Archive: <https://mailarchive.ietf.org/arch/browse/tsvwg>
List-Help: <mailto:tsvwg-request@ietf.org?subject=help>
List-Owner: <mailto:tsvwg-owner@ietf.org>
List-Post: <mailto:tsvwg@ietf.org>
List-Subscribe: <mailto:tsvwg-join@ietf.org>
List-Unsubscribe: <mailto:tsvwg-leave@ietf.org>

See [SM] below...

On 23 July 2024 21:52:11 CEST, "Overcash, Michael (CCI-Atlanta)" <michael.overcash=40cox.com@dmarc.ietf.org> wrote:
>I don't think you've really fully addressed Greg's main point here.
>
>"if the NQB queue is configured as specified (i.e. with a shallow buffer), there is a disincentive for QB applications to mis-mark their traffic because they will see excessive packet drops."
>
>Traditional QoS/Priority approaches created an incentive to cheat by creating a "fast lane" for latency sensitive services. This is emphatically not how L4S and other similar AQM based methods work. 

[SM] Both DualQ and the low latency DOCSIS scheduler it was based upon are at their core (conditional) priority schedulers. This is pretty much the same technology that in traditional QoS approaches is used to implement higher priority fast lanes. L4S adds a few heuristics to ameliorate this (like the coupling between the queues) but for these to work traffic in the L queue needs to respond properly to CE marks. 
So if we think about reasonably well-paced mischievous traffic that happens to be application limited to under the default 80 to 90% capacity share of the L-queue that ignores CE marks, this will pretty much get its way without suffering adverse effects. 
I predict that if you deploy an non-policed priority scheduler into the wild, people will find ways to abuse it.
I wonder, what makes you believe that L4S is so special that abuse will not happen?



The shallow-buffer queue is not a fast lane
[SM] Indeed it is not the shallow buffer but the underlaying priority scheduler, but IMHO that distinction is not all that important, the gist is l4s attempts to deploy a priority scheduler into the wild where the main admission control is whether a flow set the ECT(1) ECN codepoint. This is a rather risky proposition, and IMHO not helped by arguing that the priority scheduler itself is an implementation and not an architechtural feature of l4s... (l4s really needs a priority scheduler explicit or implicit, as that is exactly what it promises to do, prioritise ECT(1) packets over other packets and treat them to lower queuing delay, but I understand that I appear to be in the rough with this analysis).

 and will only improve latency performance for endpoints that implement the appropriate algorithms. An endpoint that tries to "cheat" will just end up policed and will experience worse performance. 

[SM] How? And what if that flow is well paced and stays below the l-queue capacity share, how can you assert that this flow will reliably get targeted by the policer? Keep in mind that queue protection has no concept of relative throughput of flows , but only looks at the queuing a flow causes. That is the goal of an attacker, likely getting an unfair throughput advantage is only policed indirectly. This is not what I would consider robust and reliable engineering...

>Why would anyone go out of their way to use the shallow-buffer queue to get worse performance?

[SM] Again, what makes you so certain an attacker would get worse performance?

>
>I don't think it is productive to rigorously define "shallow buffered" here. The exact buffer depth is a function of the algorithm and vendor implementation.
>
>I also don't think it is necessary or helpful to try to solve for malicious actors here. Any malicious actor can fill up queues and crowd out other traffic simply by sending high rate UDP. Shallow buffers are not uniquely vulnerable here.
On the contrary, there is no buffer so large that a malicious actor cannot easily fill it.

[SM] I gently disagree you can always opt to drop packets even before putting them into a queue.

>
>Just my two cents...
>
>Michael Overcash
>Principal Architect, Cox Communications
>michael.overcash@cox.com
>
>From: Black, David <David.Black=40dell.com@dmarc.ietf.org>
>Sent: Tuesday, July 23, 2024 11:12 AM
>To: gwhiteCL/NQBdraft <reply+AB2VULW2XRH6MPK23ABRZQOEVLRFREVBNHHI5USV5Y@reply.github.com>; gwhiteCL/NQBdraft <NQBdraft@noreply.github.com>
>Cc: Black, David <David.Black@dell.com>; tsvwg IETF list <tsvwg@ietf.org>
>Subject: [EXTERNAL] [tsvwg] Re: [gwhiteCL/NQBdraft] Should traffic protection be mandatory to implement? (Issue #48)
>
>[+tsvwg list]
>
>> I continue to disagree that traffic protection needs to be made mandatory to implement, and I have some suggestions on a way forward that provides a compromise.
>This overall direction looks promising, but the suggested compromise is not (yet) good enough.  Significant work on the draft will be needed, specifically on items 1 and 4:
>
>> 1. Necessity: NQB is a shallow-buffered best-effort service. It is understood that performance is not guaranteed for any best-effort service.
>I understand the overall intent, and I'm fine with that as a high-level goal/direction.  The problem is that in the -24 version of the draft, "shallow-buffered" is an all-but-undefined term.
>
>To do better, the draft needs to provide a concrete specification of "shallow-buffered" and require that NQB implementations use shallow buffers. If this specification of "shallow-buffered" requirements is done well, it should lead to corresponding (hopefully minor) revisions of the incentives framework discussion that result in an acceptable resolution to points 2 and 3 on Incentives.
>
>OTOH, the comment that "performance is not guaranteed for any best-effort service" appears to have missed the point. I definitely agree that the draft is not guaranteeing any performance for NQB traffic, but this line of reasoning is claiming to guarantee non-performance(!) for QB traffic that uses (abuses) the NQB service. Specifically, the claim is being made that a shallow-buffered NQB service provides a sufficient non-performance guarantee to ensure that QB traffic has nothing to gain (and quite a bit to lose) by using (abusing) the shallow-buffered NQB service. The detailed requirements for sufficiently shallow buffers that realize that non-performance guarantee need to be specified and mandated, e.g., in Section 5.1 of the draft.
>
>> 4. Security: The incentives above don't address malicious sources. While traffic protection is the remedy for this, some network environments have other ways to address malicious sources
>> (e.g. only approved applications are deployed in the network, or traffic conditioning is performed at the network edge).
>
>Proceeding in this direction ... if traffic protection is not mandatory to implement, then the draft will need to restrict NQB implementation and usage (using "MUST" and "MUST NOT" or equivalent RFC 2119 keywords) to network environments that have "other ways to address malicious sources."  The nature and/or results of those "other ways" will need to be specified in a sufficiently concrete fashion that a network operator can readily determine whether or not her network has sufficient "other ways to address malicious sources."
>
>Turning to the suggested compromise:
>
>> Specifically, the suggestion is that we address your concern about abuse of the code point by adding a mandatory requirement
>> that NQB PHB implementations provide statistics that can be used by the network operator to detect whether abuse is occurring.
>> These statistics could be as simple as packet and drop counters.
>That could work in combination with a solution to the "4. Security" problem suggested above.  By themselves, requiring collection/provision of statistics is not sufficient to resolve the security problem.
>
>> Regarding the paragraph in 5.2 discussing situations where traffic protection is potentially not needed, we could rework the paragraph ...
>That would help ... after the security problem (4) is resolved (see above)..
>
>The bottom line is that items 1 (e.g., What is the concrete specification of "shallow-buffered" ?) and 4 (e.g., What are other ways that are sufficient to address malicious sources?) need to be addressed.
>
>Thanks, --David
>
>From: gwhiteCL <notifications@github.com<mailto:notifications@github.com>>
>Sent: Monday, July 22, 2024 9:03 PM
>To: gwhiteCL/NQBdraft <NQBdraft@noreply.github.com<mailto:NQBdraft@noreply.github.com>>
>Cc: Black, David <David.Black@dell.com<mailto:David.Black@dell.com>>; Mention <mention@noreply.github.com<mailto:mention@noreply.github.com>>
>Subject: Re: [gwhiteCL/NQBdraft] Should traffic protection be mandatory to implement? (Issue #48)
>
>
>[EXTERNAL EMAIL]
>
>@dlb237 [github.com]<https://urldefense.com/v3/__https:/github.com/dlb237__;!!LpKI!jyiVIyRb0wHGFj6E5pa6Rm73RYDbMxjO3w3_EPIu0Igv6c7N8-NWOQisrmDR8o9RxjsUqJKazSDQ4_HKgrTj_EGiYA$> I continue to disagree that traffic protection needs to be made mandatory to implement, and I have some suggestions on a way forward that provides a compromise. Here are some of the reasons why I disagree:
>
>1.      Necessity: NQB is a shallow-buffered best-effort service. It is understood that performance is not guaranteed for any best-effort service. For example, the IETF doesn't mandate that implementations of the Default PHB provide mechanisms to police/prevent applications from inducing delay and/or loss.
>
>2.      Incentives: As I wrote in #47 (comment) [github.com]<https://urldefense.com/v3/__https:/github.com/gwhiteCL/NQBdraft/issues/47*issuecomment-2215318283__;Iw!!LpKI!jyiVIyRb0wHGFj6E5pa6Rm73RYDbMxjO3w3_EPIu0Igv6c7N8-NWOQisrmDR8o9RxjsUqJKazSDQ4_HKgrT6fDk_CQ$>, even without traffic protection, if the NQB queue is configured as specified (i.e. with a shallow buffer), there is a disincentive for QB applications to mis-mark their traffic because they will see excessive packet drops. So, I disagree with your assertion that the incentives framework fundamentally depends on the presence of traffic protection. Traffic protection as defined in DOCSIS Queue Protection [ietf.org]<https://urldefense.com/v3/__https:/www.ietf.org/archive/id/draft-briscoe-docsis-q-protection-07.html__;!!LpKI!jyiVIyRb0wHGFj6E5pa6Rm73RYDbMxjO3w3_EPIu0Igv6c7N8-NWOQisrmDR8o9RxjsUqJKazSDQ4_HKgrSwpL2vsw$> arguably provides less of a disincentive for inappropriate marking than would be the case in the absence of QP, because it results in significantly less packet loss for the offending application.
>
>3.      Incentives: Incentives apply more broadly than on a hop-by-hop basis, and also generally apply more broadly than on a path-by-path basis. In other words, a QB application developer would (generally) need to make a decision as to whether to mark their packets as NQB without specific knowledge whether the traffic would be subjected to traffic protection or not. So, again, I disagree with the assertion that the incentives framework fundamentally depends on the presence of traffic protection.
>
>4.      Security: The incentives above don't address malicious sources. While traffic protection is the remedy for this, some network environments have other ways to address malicious sources (e.g. only approved applications are deployed in the network, or traffic conditioning is performed at the network edge).
>
>I definitely agree that traffic protection is the preferred implementation, but I disagree that it needs to be made mandatory to implement.
>
>As a compromise, I'd like to suggest that we strengthen the recommendation around the implementation of traffic protection, and eliminate some of the language that seems of offer rationales to ignore that recommendation, futher I'd like to suggest that we mandate some mechanism that a network operator can use to detect and avoid abuse.
>
>Specifically, the suggestion is that we address your concern about abuse of the code point by adding a mandatory requirement that NQB PHB implementations provide statistics that can be used by the network operator to detect whether abuse is occurring. These statistics could be as simple as packet and drop counters. This requirement would ensure that operators who configure the NQB PHB have the ability to track the amount of packet drop that is occurring due to traffic overrunning the shallow buffer, and then take action if they feel as though the PHB is causing more issues than it is solving in their environment. Those actions could include disabling the PHB, identifying and dealing with the sources of malicious traffic directly, or pursuing a feature request with the equipment manufacturer to add a traffic protection function.
>
>In addition, I think we can delete the words in section 10: "but recognizes that other options might be more desirable in certain situations." so that the recommendation to implement traffic protection isn't watered down.
>
>Regarding the paragraph in 5.2 discussing situations where traffic protection is potentially not needed, we could rework the paragraph to emphasize that the decision by an implementer to not implement traffic protection might limit the deployment/usage of their NQB PHB implementation to a small subset of potential sitations, and it would put the onus on the operator to monitor usage and take remediations manually rather than automatically dealing with misbehaving traffic. We can also add text to more fully specify the implications of ignoring the recommendation. That, I think, would strengthen the SHOULD as opposed to offering rationales for ignoring it.
>
>-
>Reply to this email directly, view it on GitHub [github.com]<https://urldefense.com/v3/__https:/github.com/gwhiteCL/NQBdraft/issues/48*issuecomment-2244060936__;Iw!!LpKI!jyiVIyRb0wHGFj6E5pa6Rm73RYDbMxjO3w3_EPIu0Igv6c7N8-NWOQisrmDR8o9RxjsUqJKazSDQ4_HKgrRJn3skGw$>, or unsubscribe [github.com]<https://urldefense.com/v3/__https:/github.com/notifications/unsubscribe-auth/AB2VULQNPSLLSSFSGIZRZP3ZNWTVRAVCNFSM6AAAAABKRH2VICVHI2DSMVQWIX3LMV43OSLTON2WKQ3PNVWWK3TUHMZDENBUGA3DAOJTGY__;!!LpKI!jyiVIyRb0wHGFj6E5pa6Rm73RYDbMxjO3w3_EPIu0Igv6c7N8-NWOQisrmDR8o9RxjsUqJKazSDQ4_HKgrRNUJ0Ebg$>.
>You are receiving this because you were mentioned.Message ID: <gwhiteCL/NQBdraft/issues/48/2244060936@github.com<mailto:gwhiteCL/NQBdraft/issues/48/2244060936@github.com>>

-- 
Sent from my Android device with K-9 Mail. Please excuse my brevity.