Re: [Int-area] WG Adoption Call: IP Fragmentation Considered Fragile

Tom Herbert <tom@herbertland.com> Sat, 28 July 2018 18:48 UTC

Return-Path: <tom@herbertland.com>
X-Original-To: int-area@ietfa.amsl.com
Delivered-To: int-area@ietfa.amsl.com
Received: from localhost (localhost [127.0.0.1]) by ietfa.amsl.com (Postfix) with ESMTP id 6F6B013108E for <int-area@ietfa.amsl.com>; Sat, 28 Jul 2018 11:48:26 -0700 (PDT)
X-Virus-Scanned: amavisd-new at amsl.com
X-Spam-Flag: NO
X-Spam-Score: -1.909
X-Spam-Level:
X-Spam-Status: No, score=-1.909 tagged_above=-999 required=5 tests=[BAYES_00=-1.9, DKIM_SIGNED=0.1, DKIM_VALID=-0.1, RCVD_IN_DNSWL_NONE=-0.0001, T_DKIMWL_WL_MED=-0.01, URIBL_BLOCKED=0.001] autolearn=ham autolearn_force=no
Authentication-Results: ietfa.amsl.com (amavisd-new); dkim=pass (2048-bit key) header.d=herbertland-com.20150623.gappssmtp.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 EQsFOcPpxseA for <int-area@ietfa.amsl.com>; Sat, 28 Jul 2018 11:48:23 -0700 (PDT)
Received: from mail-qt0-x241.google.com (mail-qt0-x241.google.com [IPv6:2607:f8b0:400d:c0d::241]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by ietfa.amsl.com (Postfix) with ESMTPS id CEAE812D7F8 for <int-area@ietf.org>; Sat, 28 Jul 2018 11:48:23 -0700 (PDT)
Received: by mail-qt0-x241.google.com with SMTP id c15-v6so8377022qtp.0 for <int-area@ietf.org>; Sat, 28 Jul 2018 11:48:23 -0700 (PDT)
DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=herbertland-com.20150623.gappssmtp.com; s=20150623; h=mime-version:in-reply-to:references:from:date:message-id:subject:to :cc:content-transfer-encoding; bh=zHJKJ5eUt/iEcvLG6ydTHHLuP2BBStEc3UFEUoKoP5g=; b=DWf4gRZLfqH2hwU2VV2ATATyDXNoJa6eIiID1cGzZG6C/zjQTb4tOenCBCmC/yCY8c bKb0E0mxvqzhIi+rhI4ufax8sjPZe7fqDcDWhbm0Y6n3rADOnLuvS0maV/tZmw6cFhkY hKrGe+Pn9+3o8wRT/O/UCp1w4ja9wrmtMYS35Dr+07n9lv4qjINACxjkBNxMrZwbipcx 7odJJSWm4cgpE5/0Eo0bBUFQ99RnV9lF3HLd1Vodoa2EHmhw4mIL3xwA+VBwbihRCXVR RAI64zbTAwlbNHJSjYdoYbAvwbaYlaomhAN4nFhgCQ2k48FVC0eg8cXE/KpnyxsYE0TF ykXg==
X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:mime-version:in-reply-to:references:from:date :message-id:subject:to:cc:content-transfer-encoding; bh=zHJKJ5eUt/iEcvLG6ydTHHLuP2BBStEc3UFEUoKoP5g=; b=paJetJH0YrBWP8LEtJygzX9EM0OT6Z7aJrN9L4eTbA6jMS7gz6OhtI+3GvicWjVm+Z srTd4Eiy+9WF5RohSS1CiLjtMmNRBdRO6z4L1oJxeGxpy4VQM4/kR2jPGL78EIvI7T3+ VM/FlWxFEm1W4nUD0hdV3++hqNRLSxLiF39nlHoapogXkRilbp0tyagCK0T0zjeykchv H+uFPjswef4V/gZTLvKke6QapyQrqgPv2NBow6gB63bbsPDj+JIKJKseNb8llk45nLyy dkje7bGYch4MiKcmNVdQPvAsNmEc9Rtu38jWLSUK4MordAXoB7waJXRJ7dOUco9OfmEd 82tg==
X-Gm-Message-State: AOUpUlEKWUEAUpL8OZxBJrf5b4Ro2CTl6Bl2W5WhZ6xA6QrnR7H9sRIZ OCkElJB22TR2J9uLohgstpOZI7GlKZMv02tkErfKSA==
X-Google-Smtp-Source: AAOMgpdWl90LfiJRrJzMQY2gB7PuNYTqj6MzYxxlGpskqUAZcCXmyV53TQ8VgDIcLK+NsoqBdK7tnjaJWZD0ZwLfe1g=
X-Received: by 2002:ac8:611c:: with SMTP id a28-v6mr10993803qtm.130.1532803702640; Sat, 28 Jul 2018 11:48:22 -0700 (PDT)
MIME-Version: 1.0
Received: by 2002:ac8:3304:0:0:0:0:0 with HTTP; Sat, 28 Jul 2018 11:48:21 -0700 (PDT)
In-Reply-To: <FFF1C23B-7A24-46BC-929E-DD56C77D69A2@employees.org>
References: <F227637E-B12D-45AA-AD69-74C947409012@ericsson.com> <0466770D-C8CA-49BB-AC10-5805CFDFB165@strayalpha.com> <6EDF0F79-C8F3-4F05-8442-FF55576ADDD0@employees.org> <alpine.DEB.2.20.1807271530280.14354@uplift.swm.pp.se> <CALx6S35LthDLRry7k-pF8KSoX4BXBA8kyArOpDUAcJMDCoLQpQ@mail.gmail.com> <alpine.DEB.2.20.1807280811540.14354@uplift.swm.pp.se> <8640DCF6-A525-4CF7-A89D-2DEDBF0FADC8@strayalpha.com> <FFF1C23B-7A24-46BC-929E-DD56C77D69A2@employees.org>
From: Tom Herbert <tom@herbertland.com>
Date: Sat, 28 Jul 2018 11:48:21 -0700
Message-ID: <CALx6S37HKoav8ZpZP=S_p-YuQ1GAM4yqPS8C8L9xnveFS1Cdtw@mail.gmail.com>
To: Ole Troan <otroan@employees.org>
Cc: Joe Touch <touch@strayalpha.com>, "internet-area@ietf.org" <int-area@ietf.org>, "intarea-chairs@ietf.org" <intarea-chairs@ietf.org>
Content-Type: text/plain; charset="UTF-8"
Content-Transfer-Encoding: quoted-printable
Archived-At: <https://mailarchive.ietf.org/arch/msg/int-area/C7m8MoKhq6y9dkfWxJ39VVTt118>
Subject: Re: [Int-area] WG Adoption Call: IP Fragmentation Considered Fragile
X-BeenThere: int-area@ietf.org
X-Mailman-Version: 2.1.27
Precedence: list
List-Id: IETF Internet Area Mailing List <int-area.ietf.org>
List-Unsubscribe: <https://www.ietf.org/mailman/options/int-area>, <mailto:int-area-request@ietf.org?subject=unsubscribe>
List-Archive: <https://mailarchive.ietf.org/arch/browse/int-area/>
List-Post: <mailto:int-area@ietf.org>
List-Help: <mailto:int-area-request@ietf.org?subject=help>
List-Subscribe: <https://www.ietf.org/mailman/listinfo/int-area>, <mailto:int-area-request@ietf.org?subject=subscribe>
X-List-Received-Date: Sat, 28 Jul 2018 18:48:27 -0000

On Sat, Jul 28, 2018 at 11:24 AM, Ole Troan <otroan@employees.org> wrote:
>> Here’s the thing about fragmentation:
>>
>>       1. all links have a maximum packet size
>>       2. all tunneling/encapsulation/layering increases payload size
>>
>> 1+2 implies there is always the need for fragmentation at some layer:
>
> 1 implies that.
> There is enough head room designed in 1 to accommodate 2.
>
Ole,

I'm not sure I follow what you're saying here. Ethernet MTU, the most
common value, is 1500 bytes. There's no reference to headroom for
that. If you're referring to the idea of artificially lowering MTUs to
account for potential overhead introduced in encapsulation that can be
done. However to avoid fragmentation _entirely_ one would need to
determine the maximum possible overhead ever added in encapsulation(s)
(plural in case of nested encapsulations). In a sprawling and dynamic
network that has different sub-domains and simultaneously uses
different encapsulation protocols, determining that specific magic
number might be infeasible. There is also the problem that some 0.01%
corner case of encapsulation might need extra large 100s of bytes of
overhead. Lowering the MTU for everyone just to avoid fragmentation
for that case is a poor tradeoff-- it's better to fragment for that
case.

Tom


>>
>>       3. fragmentation always splits info across packets
>>
>> And there’s something important about layering:
>>
>>       4. layering intends to isolate the behavior of one layer from another, such that
>>       it will always be impossible for an upper layer to know exactly what is going on below,
>>       i.e., to determine that limiting size across an entire path of possibly virtual tunnels
>>
>> The next two are where we get into trouble:
>>
>>       5. network devices increasingly WANT to inspect contents beyond the layer at which they are intended to operate
>
> not that network devices have an intent in themselves, but yes, it seems like network operators want to inspect content or are forced into it because of the necessity of IPv4 address sharing.
>
>>       6. inspecting contents ultimately means reassembly, at some level
>
> _some_ content inspection would require that, but I don't think you can make that the general rule.
> e.g. a NAT or an L4 ACL only needs access to the L4 header.
>
>> Which brings us to the punchline:
>>
>>       7. but network device vendors want to save money, so they don’t want to reassemble at any layer
>
> We'd all wish it to be that simple. Can you substantiate that claim?
> You can easily make the speculation that customers don't want to pay what it costs to be able to do reassembly at terabit speeds...
> Or accept that it's technically hard.
>
> The implementations of e.g. NATs, IPv4 address sharing implementations I'm aware of do flavours of network layer reassembly.
> However much money you throw at it, you can't reassemble fragments travelling on different paths, nor can you trivially make network layer reassembly not be an attack vector on those boxes.
>
>>
>> So I agree, IP fragmentation has its flaws - but those flaws are created not only because it leaves out the transport port numbers, but also because DPI and NAT devices don’t reassemble. And they don’t because it’s cheaper to sell devices that say they run at 1 Gbps (e.g.) that don’t bother to reassemble.
>
> I don't agree with your conclusion.
> NATs extend the network layer to include the L4 ports. NAT implementations of course do reassemble.
>
>> I.e., it will never matter what layering we add to fix this - GRE, GUE, Aero, etc. - ultimately, we’re doomed to need fragmentation support down to IP exactly because:
>>
>>       a. #1-4 mean we need frag/reassembly at any tunnel ingress
>>       b. vendors want to sell #5 at a price that is too low for them to support #6 (i.e., point #7)
>
>>
>> So pushing this to another layer will never solve it. What will solve it will only be a compliance requirement for #6 - which could be done right now, and has to be done for ANY solution to work.
>
> For IPv4 address sharing specifically removing network layer fragmentation would be a solution.
>
>> NOTE: even rewriting EVERY application won’t fix this, nor will deploying a new layer at any level.
>
> For some type of content inspection that would require reassembling the whole application context.
> But that's quite different from IPv4 address sharing, which we have unfortunately made an integral part of the Internet architecture.
>
>> And yes, I do intend to add this to draft-ietf-tunnels, so it can be referred to elsewhere.
>
> Ole
>
>
> _______________________________________________
> Int-area mailing list
> Int-area@ietf.org
> https://www.ietf.org/mailman/listinfo/int-area
>