[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-Id: <1FB38B5E-F952-421D-8FA7-338678E0E8BC@gmail.com>
Date:   Thu, 8 Apr 2021 15:03:57 -0700
From:   Ishaan Gandhi <ishaangandhi@...il.com>
To:     Willem de Bruijn <willemdebruijn.kernel@...il.com>
Cc:     Ron Bonica <rbonica@...iper.net>, David Ahern <dsahern@...il.com>,
        Zachary Dodds <zdodds@...il.com>,
        Andreas Roeseler <andreas.a.roeseler@...il.com>,
        David Miller <davem@...emloft.net>,
        Network Development <netdev@...r.kernel.org>,
        Stephen Hemminger <stephen@...workplumber.org>,
        "junipeross20@...hmc.edu" <junipeross20@...hmc.edu>
Subject: Re: rfc5837 and rfc8335
> But the patch series under review adds support to generate such packets.
Willem, yes, good point. Let me add some more context.
This quote might be misleading:
>> Therefore, LINUX hosts will  not send RFC 5837 ICMP extensions often
Linux _hosts_ won’t send 5837 extensions often, but Linux is often
used in routers, which may indeed send those extensions often.
(Ron previously added some great context why routers may want to send those
extensions _now_ as opposed to 11 years ago.)
Juniper is adding RFC 5837 support to some of their router line right now, and 
some of their OS’s  are based on Linux.
Contributing these changes to the upstream kernel would be valuable
to Juniper for maintainability. (No re-applying the patch every time Juniper
upgrades to a new kernel version.)
Furthermore, Juniper is not the only router vendor based on Linux.
OpenWrt and DD-WRT are two popular router distributions, both based on Linux.
There are 16 total Linux based router-distributions mentioned on
https://en.wikipedia.org/wiki/List_of_router_and_firewall_distributions alone.
Re, some previous questions
>> What tooling supports it? 
Currently, Wireshark. There are also open merge requests for traceroute in IPUtils,
and TCPDump.
>> With Linux, the ingress interface can lost in the layers (NIC port, vlan, bond, bridge, vrf, macvlan), and to properly support either you need to return information about the right one.
either return the information, or?
Many thanks!
- Ishaan
> On Mar 31, 2021, at 7:04 AM, Willem de Bruijn <willemdebruijn.kernel@...il.com> wrote:
> 
> On Mon, Mar 29, 2021 at 3:40 PM Ron Bonica <rbonica@...iper.net> wrote:
>> 
>> Folks,
>> 
>> Andreas reminds me that you may have the same questions regarding RFC 8335.....
>> 
>> The practice of assigning globally reachable IP addresses to infrastructure interfaces cost network operators money. Normally, they number an interface from a IPv4  /30. Currently, a /30 costs 80 USD and the price is only expected to rise. Furthermore, most IP Address Management (IPAM) systems license by the address block. The more globally reachable addresses you use, the more you pay.
>> 
>> They would prefer to use:
>> 
>> - IPv4 unnumbered interfaces
>> - IPv6 interfaces that have only link-local addresses
>> 
>>                                                                    Ron
> 
> Thanks for the context, Ron.
> 
> That sounds reasonable to me. Andreas's patch series has also been
> merged by now.
> 
> 
>> 
>> 
>> 
>> Juniper Business Use Only
>> 
>> -----Original Message-----
>> From: Ron Bonica
>> Sent: Monday, March 29, 2021 10:50 AM
>> To: David Ahern <dsahern@...il.com>; Zachary Dodds <zdodds@...il.com>; Ishaan Gandhi <ishaangandhi@...il.com>
>> Cc: Andreas Roeseler <andreas.a.roeseler@...il.com>; David Miller <davem@...emloft.net>; Network Development <netdev@...r.kernel.org>; Stephen Hemminger <stephen@...workplumber.org>; Willem de Bruijn <willemdebruijn.kernel@...il.com>; junipeross20@...hmc.edu
>> Subject: RE: rfc5837 and rfc8335
>> 
>> David,
>> 
>> Juniper networks is motivated to promote RFC 5837 now, as opposed to eleven years ago, because the deployment of parallel links between routers is becoming more common
>> 
>> Large network operators frequently require more than 400 Gbps connectivity between their backbone routers. However, the largest interfaces available can only handle 400 Gbps. So, parallel links are required. Moreover, it is frequently cheaper to deploy 4 100 Gbps interfaces than a single 400 Gbps interface. So, it is not uncommon to see two routers connected by many, parallel 100 Gbps links. RFC 5837 allows a network operator to trace a packet interface to interface, as opposed to node to node.
>> 
>> I think that you are correct in saying that:
>> 
>> - LINUX is more likely to be implemented on a host than a router
>> - Therefore, LINUX hosts will  not send RFC 5837 ICMP extensions often
>> 
>> However, LINUX hosts are frequently used in network management stations. Therefore, it would be very useful if LINUX hosts could parse and display incoming RFC 5837 extensions, just as they display RFC 4950 ICMP extensions.
> 
> But the patch series under review adds support to generate such packets.
> 
> 
>> Juniper networks plans to support RFC 5837 on one platform in an upcoming release and on other platforms soon after that.
>> 
>>                                                                                 Ron
>> 
>> 
>> 
>> 
>> Juniper Business Use Only
>> 
>> -----Original Message-----
>> From: David Ahern <dsahern@...il.com>
>> Sent: Wednesday, March 24, 2021 11:19 PM
>> To: Ron Bonica <rbonica@...iper.net>; Zachary Dodds <zdodds@...il.com>; Ishaan Gandhi <ishaangandhi@...il.com>
>> Cc: Andreas Roeseler <andreas.a.roeseler@...il.com>; David Miller <davem@...emloft.net>; Network Development <netdev@...r.kernel.org>; Stephen Hemminger <stephen@...workplumber.org>; Willem de Bruijn <willemdebruijn.kernel@...il.com>; junipeross20@...hmc.edu
>> Subject: Re: rfc5837 and rfc8335
>> 
>> [External Email. Be cautious of content]
>> 
>> 
>> On 3/23/21 10:39 AM, Ron Bonica wrote:
>>> Hi Folks,
>>> 
>>> 
>>> 
>>> The rationale for RFC 8335 can be found in Section 5.0 of that document.
>>> Currently, ICMP ECHO and ECHO RESPONSE messages can be used to
>>> determine the liveness of some interfaces. However, they cannot
>>> determine the liveness of:
>>> 
>>> 
>>> 
>>>  * An unnumbered IPv4 interface
>>>  * An IPv6 interface that has only a link-local address
>>> 
>>> 
>>> 
>>> A router can have hundreds, or even thousands of interfaces that fall
>>> into these categories.
>>> 
>>> 
>>> 
>>> The rational for RFC 5837 can be found in the Introduction to that
>>> document. When a node sends an ICMP TTL Expired message, the node
>>> reports that a packet has expired on it. However, the source address
>>> of the ICMP TTL Expired message doesn't necessarily identify the
>>> interface upon which the packet arrived. So, TRACEROUTE can be relied
>>> upon to identify the nodes that a packet traverses along its delivery
>>> path. But it cannot be relied upon to identify the interfaces that a
>>> packet traversed along its deliver path.
>>> 
>>> 
>> 
>> It's not a question of the rationale; the question is why add this support to Linux now? RFC 5837 is 11 years old. Why has no one cared to add support before now? What tooling supports it? What other NOS'es support it to really make the feature meaningful? e.g., Do you know what Juniper products support RFC 5837 today?
>> 
>> More than likely Linux is the end node of the traceroute chain, not the transit or path nodes. With Linux, the ingress interface can lost in the layers (NIC port, vlan, bond, bridge, vrf, macvlan), and to properly support either you need to return information about the right one.
>> Unnumbered interfaces can make that more of a challenge.
Powered by blists - more mailing lists
 
