Re: [MBONED] mboned: UDP port conflict mtrace/traceroute

Warren Kumari <warren@kumari.net> Wed, 18 September 2019 00:54 UTC

Return-Path: <warren@kumari.net>
X-Original-To: mboned@ietfa.amsl.com
Delivered-To: mboned@ietfa.amsl.com
Received: from localhost (localhost [127.0.0.1]) by ietfa.amsl.com (Postfix) with ESMTP id 06AFF12006F for <mboned@ietfa.amsl.com>; Tue, 17 Sep 2019 17:54:06 -0700 (PDT)
X-Virus-Scanned: amavisd-new at amsl.com
X-Spam-Flag: NO
X-Spam-Score: -1.899
X-Spam-Level:
X-Spam-Status: No, score=-1.899 tagged_above=-999 required=5 tests=[BAYES_00=-1.9, DKIM_SIGNED=0.1, DKIM_VALID=-0.1, RCVD_IN_DNSWL_NONE=-0.0001, SPF_HELO_NONE=0.001, SPF_PASS=-0.001, URIBL_BLOCKED=0.001] autolearn=unavailable autolearn_force=no
Authentication-Results: ietfa.amsl.com (amavisd-new); dkim=pass (2048-bit key) header.d=kumari-net.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 0DsTnb63M14Q for <mboned@ietfa.amsl.com>; Tue, 17 Sep 2019 17:54:00 -0700 (PDT)
Received: from mail-qk1-x730.google.com (mail-qk1-x730.google.com [IPv6:2607:f8b0:4864:20::730]) (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 9B1A912008A for <mboned@ietf.org>; Tue, 17 Sep 2019 17:54:00 -0700 (PDT)
Received: by mail-qk1-x730.google.com with SMTP id f16so6138344qkl.9 for <mboned@ietf.org>; Tue, 17 Sep 2019 17:54:00 -0700 (PDT)
DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=kumari-net.20150623.gappssmtp.com; s=20150623; h=mime-version:references:in-reply-to:from:date:message-id:subject:to :cc:content-transfer-encoding; bh=iN4LwsIsM/3dQrbpDlCYIf5ww2d8fBiF81JXdywf2bk=; b=Z2iFCLjl+XyLCoGF0/6sCd8J8oTRivCrxIkk88DR4ATHZ4OSDzGNnjh+dGh0IxP/iC 2OMClr2HTPhg6RYCujeCV0OrQP3eP7RrpHpkcOpVi9faFjVEfNy8vx6px/Bs/HVjGVKt Clnr+ypjHW16bXaSQc70IXivhCpo6bxcsZIICHjp4bg3/FXqkuy+slgE9hT/MbA7jvcr ViTI3AdH2nUAGPhqQliiLV/wMBaWpRBUzsmI/3/m6Zq30d74SW/VmH7URm4lDTWK7epQ CtUBBDzH+SzwYyElDnk546SRxXeyIl2+GBYA1K8mhygzNAQ8oLhPPU1WZtDKT7xU4RZu YaMA==
X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:mime-version:references:in-reply-to:from:date :message-id:subject:to:cc:content-transfer-encoding; bh=iN4LwsIsM/3dQrbpDlCYIf5ww2d8fBiF81JXdywf2bk=; b=B7sjC9lxG4Hh4liL3x0jZTAugovokzJyVsPfsBJ+loeaWFeBOZyEauTjwyaRfThE3y WXEEXcpoWrCV8G202OAv29eEysXp+1lG2m73cOa21rRPoF03HapK+Pi/0oIhA4Wb8JST qW6tnqWqUY4L3fRar2jm9hOxtgqo033s5afGDd0qIE1h7tOXkGo3eFHrolG7Ocjlsrbe bzS0s2rcKGmNmS0Plbww8FmXqQFQVIzhgSjkeBvM7CF0qYUqE4rYdBcwR/8qGHSg9BOz 8zPaF9vIuDJMpd1cdVV1fw+dqI7SfL1lf5Bww1srjHUNPV1TVD0O74HfcCbdImAsOObg PiUg==
X-Gm-Message-State: APjAAAW8XIin9r7TZHQYd/Kl1SVDDoIXkMvxH01ohZLUgYq8xASB1ZXh OnWZ5FoZkIj407RL0YcedfxbOf3FUsero85BVKT6DA==
X-Google-Smtp-Source: APXvYqwQU6HPYhoNhEUAQpXL476s8uIy103Pu7qGTHjypGFrSxFyN0bERyoau406igmP0JBvEOZzxkJ9ncFdrzz8c10=
X-Received: by 2002:a37:4d02:: with SMTP id a2mr1480492qkb.63.1568768038911; Tue, 17 Sep 2019 17:53:58 -0700 (PDT)
MIME-Version: 1.0
References: <CAH8Jh6DSMMyjtzTn5yKqWdsio40nMjkreUMyMkc8mJGAFdYK4Q@mail.gmail.com> <BA0AA020-AE9D-441A-9AF2-DF847F1D9597@strayalpha.com> <CAHw9_iJCk6ym_CoXca8zgSsN7qCx-iAzsTg2-hV+SWHRz2D17g@mail.gmail.com> <2ba7bbf42e6d007b83d024ef11c24070@strayalpha.com> <CAHw9_iJsHGyttCw6UCQYzc2gEy4Rf+v=dTa9OyKOTaoZxEFtPQ@mail.gmail.com> <aec642641abccd91e5bd39deba049e39@strayalpha.com> <CAHw9_iKf25RTQuESdyW9a1U1n3EnR54yOo42+0nbW922Yxj8-g@mail.gmail.com> <CAHw9_i+oy36uDoBLSn5uF4UKkTpcZ9Up_ziDW6pfwwmkEG41jg@mail.gmail.com> <85BF58BB-3CAE-4B48-BD98-014FBEAFBCD5@ieee.org> <DB7PR07MB4745C1F40ADB032D985628EF918F0@DB7PR07MB4745.eurprd07.prod.outlook.com> <e45d5732-48ff-11df-e079-bf9fc26686a0@nokia.com> <AM6PR07MB5747206B0DD47E190183B58D888F0@AM6PR07MB5747.eurprd07.prod.outlook.com> <16ac7967-d94f-cdf4-98cb-eaeb6c6a24e3@nokia.com>
In-Reply-To: <16ac7967-d94f-cdf4-98cb-eaeb6c6a24e3@nokia.com>
From: Warren Kumari <warren@kumari.net>
Date: Tue, 17 Sep 2019 17:53:20 -0700
Message-ID: <CAHw9_iK=i4DNseDn9FBnJonu=44pEE2t9S9C3BrQdjCyQ4jGpg@mail.gmail.com>
To: "Mcconnochie, William (Nokia - CA/Ottawa)" <william.mcconnochie@nokia.com>
Cc: "Stojc, Stephane (Nokia - CA/Ottawa)" <stephane.stojc@nokia.com>, "Bidgoli, Hooman (Nokia - CA/Ottawa)" <hooman.bidgoli@nokia.com>, Hitoshi Asaeda <asaeda@ieee.org>, "Boone, Larry (Nokia - CA/Ottawa)" <larry.boone@nokia.com>, Joe Touch <touch@strayalpha.com>, "James A. (Jim) Stevens" <james.a.stevens=40collins.com@dmarc.ietf.org>, MBONED WG <mboned@ietf.org>
Content-Type: text/plain; charset="UTF-8"
Content-Transfer-Encoding: quoted-printable
Archived-At: <https://mailarchive.ietf.org/arch/msg/mboned/nCeajUpb9M8AskjNlIwTBsazKHY>
Subject: Re: [MBONED] mboned: UDP port conflict mtrace/traceroute
X-BeenThere: mboned@ietf.org
X-Mailman-Version: 2.1.29
Precedence: list
List-Id: Mail List for the Mboned Working Group <mboned.ietf.org>
List-Unsubscribe: <https://www.ietf.org/mailman/options/mboned>, <mailto:mboned-request@ietf.org?subject=unsubscribe>
List-Archive: <https://mailarchive.ietf.org/arch/browse/mboned/>
List-Post: <mailto:mboned@ietf.org>
List-Help: <mailto:mboned-request@ietf.org?subject=help>
List-Subscribe: <https://www.ietf.org/mailman/listinfo/mboned>, <mailto:mboned-request@ietf.org?subject=subscribe>
X-List-Received-Date: Wed, 18 Sep 2019 00:54:06 -0000

On Tue, Sep 17, 2019 at 12:56 PM Mcconnochie, William (Nokia -
CA/Ottawa) <william.mcconnochie@nokia.com> wrote:
>
> Ignoring our internal processing :-)...you are correct.
>
> Bottom line is that if you reach the destination then a destination unreachable message is generated with the icmp type set to 'port unreachable' but this will not occur if another application is listening on that port as the port is now reachable, i.e. in use.
>

Yes, that is what I also said in my explanation, but:
"As far as I can see then, the only case where there might be an issue is:
1: the router running mtrace2 is the target of the traceroute (so it
is actually listening on the port) and
2: the router is the very first hop (that's the only case where the
port number will be 33435).

In this case, we would get an output showing:
traceroute to 10.0.1.1, 64 hops max, 52 byte packets
 1  10.0.1.1 (10.0.1.1)  *  1 ms  0.8 ms"

This seems a *little* sad, and definitely suboptimal, but it is much
less concerning than what I'd initially understood. If this occurred a
few more hops out I'd actually view it as a larger issue...



W

> William
>
> On 09/17/2019 03:23 PM, Stojc, Stephane (Nokia - CA/Ottawa) wrote:
>
> I think there might be a typo here:
>
> If the ttl expires and the destination address is for the router the ttl expires on then that is when a destination unreachable message is generated, however, if something else is listening on that port then you have an application conflict which is the problem at have with mtrace/traceroute and port 33435.
>
> Packets don't age out on the nodes they're destined to. The CPM code only decrements TTL when attempting to forward a packet. The final packet of a traceroute probe is expected to generate a "port unreachable", not a TTL expiry, since the packet is extracted under a generic "PKT_COPY_CODE_IP_EXP_CANT_HANDLE" copy code due to having a local IP. As the error type implies, the port must be unreachable on that final node (i.e. not in use) for this error to be generated.
>
> Stephane
>
>
>
> ________________________________
> From: Mcconnochie, William (Nokia - CA/Ottawa) <william.mcconnochie@nokia.com>
> Sent: Tuesday, September 17, 2019 2:45 PM
> To: Bidgoli, Hooman (Nokia - CA/Ottawa) <hooman.bidgoli@nokia.com>; Hitoshi Asaeda <asaeda@ieee.org>; Warren Kumari <warren@kumari.net>; Boone, Larry (Nokia - CA/Ottawa) <larry.boone@nokia.com>
> Cc: Joe Touch <touch@strayalpha.com>; James A. (Jim) Stevens <james.a.stevens=40collins.com@dmarc.ietf.org>; MBONED WG <mboned@ietf.org>; Stojc, Stephane (Nokia - CA/Ottawa) <stephane.stojc@nokia.com>
> Subject: Re: [MBONED] mboned: UDP port conflict mtrace/traceroute
>
>
> As per "It was reported that enabling this protocol on routers where the traffic ransites (e.g router1) breaks traceroute, but I've sufficiently managed to confuse myself that I'm having a hard time understanding *why* -- the packet isn't destined to the router, it is destined for the target of the traceroute..."
>
> When the ttl expires but the destination address is not for the router the ttl expired on, then a time exceeded message is generated.
> If the ttl expires and the destination address is for the router the ttl expires on then that is when a destination unreachable message is generated, however, if something else is listening on that port then you have an application conflict which is the problem at have with mtrace/traceroute and port 33435.
>
> William
>
>
>
>
> On 09/17/2019 12:48 PM, Bidgoli, Hooman (Nokia - CA/Ottawa) wrote:
>
> Hi Hitoshi
>
> Sorry for delay. Adding two of the Nokia engineers.
>
> So I think you are seeing what we are pointing out, a packet to the port 33435 is lost. Even that this is a single packet still it would create confusion.
>
> Larry and William from Nokia can comment in more details
>
> Regards
>
> Hooman
>
>
>
> -----Original Message-----
> From: Hitoshi Asaeda <asaeda@ieee.org>
> Sent: Monday, September 16, 2019 9:24 PM
> To: Warren Kumari <warren@kumari.net>; Bidgoli, Hooman (Nokia - CA/Ottawa) <hooman.bidgoli@nokia.com>
> Cc: Joe Touch <touch@strayalpha.com>; James A. (Jim) Stevens <james.a.stevens=40collins.com@dmarc.ietf.org>; MBONED WG <mboned@ietf.org>
> Subject: Re: [MBONED] mboned: UDP port conflict mtrace/traceroute
>
> Hooman,
>
> Could you follow up this Warren's discussion?
> Thanks.
>
> Regards,
>
> Hitoshi
>
>
>
> On Sep 14, 2019, at 5:13, Warren Kumari <warren@kumari.net> wrote:
>
> [ TOP-POST]
>
>
> Aaaaarggh! As Leonard pointed out (offlist, to save me the
> embarrassment of being an idiot) I have a typo throughout this -- the
> Dst is 10.0.4.1, not 10.0.5.1 (I'd initially had 2 and hosts, and 4
> routers, but that was overly verbose, and so I removed the last
> router, and forgot to renumber). Also, in Step 4, the TTL should
> clearly be 4, not 43.
> That'll larn me to try type long emails on a phone...
>
> w
>
> On Thu, Sep 12, 2019 at 4:04 PM Warren Kumari <warren@kumari.net> wrote:
>
> Hitoshi / MBONED,
>
> Can you please explain in baby words (small enough that even I can
> understand!) how the failures actually occur.
>
> I keep going through it step by step, and it all makes sense... and
> then suddenly I confuse myself and it all escapes... <insert confused
> baby meme here>
>
> Let's use this as the scenario (I'm using RFC1918 space because the
> documentation prefix isn't really big enough for this).
>
> I'm 10.0.0.1, and I'm running traceroute (from Linux / BSD box) to a
> destination machine of 10.0.4.1. There are routers numbered 10.0.1.1,
> 10.0.2.1 and 10.0.3.1
>
> Step 1: I send 3 packets with TTL=1, Dst 10.0.5.1, ports 33435,33436,33437.
> The first hop router, 10.0.1.1 decrements the TTL, realizes that the
> packet has now expired, and sends me back (Src 10.0.1.1, Dst
> 10.0.0.1)
> 3 ICMP TTL expired messages.
> Traceroute draws:
> traceroute to 10.0.4.1, 64 hops max, 52 byte packets
> 1  10.0.1.1 (10.0.1.1)  2 ms  1 ms  0.8 ms
>
> 2: I now send 3 packets, with TTL=2,  Dst 10.0.5.1, ports 33438,33439,33440.
> Router1 decrements the TTL and forwards it to Router2, which
> decrements the TTL and sends back  (Src 10.0.2.1, Dst 10.0.0.1) 3
> ICMP TTL expired messages.
> I see:
> traceroute to 10.0.4.1, 64 hops max, 52 byte packets
> 1  10.0.1.1 (10.0.1.1)  2 ms  1 ms  0.8 ms
> 2  10.0.2.1 (10.0.2.1)  3ms  2 ms 5ms
>
> 3: I send 3 packets with TTL3, Dst 10.0.5.1, ports 33441,33442,33443
> Router1 and router2 forward the packet, router3 expires it, I get a
> TTL expired from 10.0.3.1, and now I see:
> traceroute to 10.0.4.1, 64 hops max, 52 byte packets
> 1  10.0.1.1 (10.0.1.1)  2 ms  1 ms  0.8 ms
> 2  10.0.2.1 (10.0.2.1)  3ms  2 ms 5ms
> 3  10.0.3.1 (10.0.3.1)  4 ms 5ms 3ms.
>
> 4: I send 3 packets with TTL=43, Dst 10.0.5.1, ports 33444,33445,33446.
> The TTL is now high enough that it makes it to the end host. There is
> nothing listening on the end host on ports 33444, 33445, 33446, and
> so I get back (from 10.0.4.1) ICMP port unreachables for 33444,
> 33445, 33446. I know I've reached my destination, and I'm happy.
> traceroute to 10.0.4.1, 64 hops max, 52 byte packets
> 1  10.0.1.1 (10.0.1.1)  2 ms  1 ms  0.8 ms
> 2  10.0.2.1 (10.0.2.1)  3ms  2 ms 5ms
> 3  10.0.3.1 (10.0.3.1)  4 ms 5ms 3ms
> 4  10.0.4.1 (10.0.4.1) 5ms 3ms 4ms
>
>
>
> In all of the above steps the destination address of the traceroute
> packet is the target of the traceroute.
> A transit router decrements the TTL, and if is cannot forward the
> packet it generates an ICMP unreachable -- but it doesn't care about
> the destination port or IP. When the TTL is high enough that it
> reaches the end host, the port number *is* important, because we
> don't want the end host to actually accept the packet, we want it to
> instead return an ICMP Port Unreachable (or admin prohibited, or
> something else useful).
>
> As far as I can see then, the only case where there might be an issue is:
> 1: the router running mtrace2 is the target of the traceroute (so it
> is actually listening on the port) and
> 2: the router is the very first hop (that's the only case where the
> port number will be 33435).
>
> In this case, we would get an output showing:
> traceroute to 10.0.1.1, 64 hops max, 52 byte packets
> 1  10.0.1.1 (10.0.1.1)  *  1 ms  0.8 ms
>
> (the first packet (port 33435) gets eaten by the mtrace2 process, but
> the 2nd and 3rd packets will have ports 33436, 33437).
>
> It was reported that enabling this protocol on routers where the
> traffic ransites (e.g router1) breaks traceroute, but I've
> sufficiently managed to confuse myself that I'm having a hard time
> understanding *why* -- the packet isn't destined to the router, it is
> destined for the target of the traceroute...
>
> I'm sure I'm missing something obvious here, so, again, slowly and in
> baby words please...
>
> W
>
>
> On Wed, Sep 11, 2019 at 12:29 PM Joe Touch <touch@strayalpha.com> wrote:
>
> Hi, Warren,
>
> On 2019-09-11 08:27, Warren Kumari wrote:
>
> On Mon, Jul 29, 2019 at 1:36 PM Joe Touch <touch@strayalpha.com> wrote:
>
>
> On 2019-07-29 10:09, Warren Kumari wrote:
>
> ...
>
> Just FYI, I sent email to IANA letting them know that ports 33435 -
> 33534 should probably be listed it as "Known Unauthorized Use".
> From some archaeology, 33434 is apparently 2^15 + 666, and the
> "standard" traceroutes use up to 100 ports.
> I based this on the Van Jacobson (van@ee.lbl.gov) - 1988 which he
> "stole" (credited) from Steve Deering -- easiest location of code is:
> https://github.com/freebsd/freebsd/blob/master/contrib/traceroute/tr
> aceroute.c
>
> I don't much like referring to it as "Known Unauthorized Use" but
> that's technically what it is -- the important bit to me seems to be
> that we make in some way so they don't get handed out, exactly what
> they should be called is a less pressing problem.
>
>
> Although that's helpful to those seeing traffic on those ports, it does not prevent IANA from assigning those values when requested.
>
> The only way to do that would be to make them ASSIGNED. That happens by the process indicated in RFCs 6335 and 7605 and notably is not driven by this sort of "squatting".
>
> NOTE: at the time that code was originally developed (1988), that range was OK for such uses without registration, but times changed in 1992.
>
> That code ought to be fixed.
>
>
> Yes, that is true -- that code ought to be fixed; however, it
> doesn't change the fact that mtrace cannot realistically be deployed
> using this port -- enabling it on a router breaks traceroutes
> through that router, leading to asterisks (I'd thought that we'd
> agreed on that, but while looking back through my mail on this
> topic, it's possible I'd misunderstood, and you don't actually agree
> that this port isn't fit *for this particular purpose*).
>
>
>
> No, I don't. I don't understand the issue. On machines where traceroute is deployed, I would assume it is already possible to acquire those ports (bind to them) as needed, at which point the only components that don't play nice are those where mtrace isn't deployed yet.
>
> Now if you are saying you don't WANT to do that because you WANT to support traceroute's use of squatted ports, that's not IANA's business IMO - and, more importantly, it's not justification for changing a port. IANA's policies on this are that squatter's use of ports are simply not a factor at all. They can't be, otherwise there's no point in having an assignment process.
>
>
> Just wanting to make sure we are all on the same page, and they
> MBONED will be publishing a -bis, deprecating this RFC and
> publishing a new one with a different port...
>
>
> At best, that would requires releasing the current assignment, which requires a statement as to the extent of the current deployment using that assignment since 2012 and a plan for changing that codebase - all this is described in RFC 6335.
>
> Joe
>
> --
> I don't think the execution is relevant when it was obviously a bad
> idea in the first place.
> This is like putting rabid weasels in your pants, and later
> expressing regret at having chosen those particular rabid weasels and
> that pair of pants.
>   ---maf
>
> --
> I don't think the execution is relevant when it was obviously a bad
> idea in the first place.
> This is like putting rabid weasels in your pants, and later expressing
> regret at having chosen those particular rabid weasels and that pair
> of pants.
>   ---maf
>
>
>


-- 
I don't think the execution is relevant when it was obviously a bad
idea in the first place.
This is like putting rabid weasels in your pants, and later expressing
regret at having chosen those particular rabid weasels and that pair
of pants.
   ---maf