I've read most of the posts in this thread as an operator who may be looking
at an overlay solution in the future.

So the crux of the discussion is whether to extend the functionality of an
existing protocol or introduce a brand new protocol.

I would like to see the VNI space extended to 32 bits instead of 24 in
whatever encapsulation method is being chosen.  24 seems like a holdover
from the 802.1ah I-SID value and other adapted tunnel protocol limitations
and I'm not sure it's really necessary anymore.

I also believe there has to be a protocol identifier in the encapsulation
header identifying what comes next.  Static provisioning of this kind of
information at the endpoints or midpoints in the case of monitoring gear,
etc. is too cumbersome and not extensible.   I think Tom said it initially,
but I also don't believe inserting an Ethernet header just for the sake of
it is efficient and the overlay encapsulation protocol should be able to
encapsulate IP directly.

I do not think the metadata should be a part of the encapsulation protocol,
the encapsulation header should be a fixed length.   I think the majority of
simple overlay networks will not require additional metadata information and
will likely be using the encapsulation with nothing following it but IP
packets or Ethernet frames.    Having a variable length suffix is just going
to add implementation headaches for hardware vendors and will be a quick way
to see it not get adopted, IMHO.    If someone needs additional hardware
support for the next header, whether it be a security integrity header, or
some sort of additional metadata, let that be sorted out elsewhere.

Just my 2c.  

-Phil


From:  Pankaj Garg <[email protected]>
Date:  Sunday, March 2, 2014 at 2:06 PM
To:  "Larry Kreeger (kreeger)" <[email protected]>, "[email protected]"
<[email protected]>
Subject:  Re: [nvo3] Comments on Draft Geneve

My responses are inline marked with PG.
 

From: Larry Kreeger (kreeger) [mailto:[email protected]]
Sent: Sunday, March 2, 2014 9:16 PM
To: Pankaj Garg; [email protected]
Subject: Re: Comments on Draft Geneve
 

My responses are inline marked with LK>.  - Larry

 

From: Pankaj Garg <[email protected]>
Date: Saturday, March 1, 2014 4:22 AM
To: Larry Kreeger <[email protected]>, "[email protected]" <[email protected]>
Subject: RE: Comments on Draft Geneve

 

My comments are inline marked with [PG].
 

From: nvo3 [mailto:[email protected]] On Behalf Of Larry Kreeger
(kreeger)
Sent: Saturday, March 1, 2014 3:28 AM
To: [email protected]
Subject: [nvo3] Comments on Draft Geneve
 

I see that a healthy discussion has broken out around draft-gross-geneve-00
which I see has a slot in the agenda for the NVO3 WG meeting on Monday.
Here are my thoughts.

 

I will be comparing Geneve to an encapsulation that is near and dear to my
heart, VXLAN.  When I do this, I see an encapsulation that is very similar
to VXLAN (e.g. uses UDP, uses a 24-bit segment identifier at the same
offset).  I see three things that Geneve adds beyond what is available in
draft-mahalingam-dutt-dcops-vxlan:

 

1) The ability to encapsulate any protocol with an Ethertype (not just
Ethernet frames), by adding a Protocol Type field.  This is certainly
useful, and has already been covered in draft-quinn-vxlan-gpe as a backward
compatible extension to VXLAN by using a P bit flag to signal its presence.
The field is even at the same offset as draft-quinn-vxlan-gpe, but is
missing the P bit for backwards compatibility.
 
[PG] The backward compatibility argument is invalid since a frame with P bit
set (let me call it VXLAN V2) cannot be processed by the older endpoint,
thus having no backward compatibility.

 

LK> By backward compatibility, I mean that new implementations of VXLAN
(VXLAN V2 as you call it) can understand packets sent by older
implementations (VXLAN V1) as well as from new ones.  If older endpoints
could understand the future bits, I would call that forward compatibility.
[PG] My point was that the VXLAN V2 endpoint would have to support
generating and understanding VXLAN V1 format packets. Is it much different
than an endpoint supporting both Geneve and VXLAN V1?

 

[PG] Essentially, what you are saying is that one can generate packets in
VXLAN V1 for older endpoint and VXLAN V2 for newer endpoints. So the
question is, why is VXLAN V2 better than Geneve? In fact, switching on a top
level UDP port, provides a cleaner processing pipeline.

 

LK> By enhancing VXLAN, there is no need to get a new UDP port assigned and
all the current parsing logic for VXLAN V1 can be applied.
[PG] I am not sure if allocating a new port is the meta issue here. The main
issue here seems to be whether new protocol should _require_ support for
VXLAN V1 or not. Coming from NVGRE side, the same argument would apply to
Geneve where one can say that Geneve should be backward compatible with
NVGRE. I feel this might be a slippery slope where a new protocol cannot
start with a clean slate.

 

2) The addition of an OAM bit to signal that the packet should be processed
by the tunnel endpoint and not forwarded to a tenant.  This also seems
useful, and seems identical in usage to the (IMO, poorly named) "Router
Alert" bit extension to VXLAN covered in (the currently expired)
draft-singh-nvo3-vxlan-router-alert.
 
[PG] Yes, the OAM bit usage is similar. However, this is another extension
which is incompatible with older implementation of VXLAN thus breaking
backward compatibility.

 

LK> Again, I would call what you are referring to "forward compatibility".

 

3) Last, but not least is the addition of a variable length options field,
which the draft suggests is used to carry metadata along with the payload.
As mentioned by some others, IMO, the encapsulation transport header is not
the right place to define and carry metadata.  Architecturally, metadata
should be defined independent of transport so it can be carried inside of
whatever transport is desired (e.g. VXLAN, NVGRE, MPLSoGRE, L2TPV3 etc).
One example of an effort to do this is in the Network Service Header draft
(draft-quinn-sfc-nsh) being discussed in the SFC WG.  I am guessing that
since the Geneve options field is optional, that the metadata it contains is
not related to basic network connectivity, but more to providing higher
level network services (aka Service Functions).  The Network Service Header
contains two separate parts, the service path (used to guide the packets
through the service chain) and context (metadata).  I can certainly see the
context part of NSH being used to carry metadata even if the service chain
is null (all services are fully distributed to the tunnel endpoints).
 
[PG] The meta-data should be defined by their respective group. Different
encapsulation protocols can carry those meta-data in their headers as
needed. One clear example of how Geneve is better is that it can carry that
meta-data without breaking hardware offloads, whereas VXLAN and NVGRE cannot
do that. Btw I want to be clear, Geneve is not defining the meta-data, and
it is not tying meta-data to Geneve, it is only defining a general purpose
ability to carry meta-data, which is tremendously useful to have in the
encapsulation header.
 
On a side note, I don¹t believe that the design of NSH is suitable for
carrying general purpose meta-data. In fact in its current definition, it is
not defining service chaining primitives clearly either, however we can
discuss that in SFC forum, and focus the discussion on encapsulation header
in this forum.

 

In short, I don't see anything in Geneve that cannot be accomplished by
using the backward compatible extensions to VXLAN proposed in
draft-quinn-vxlan-gpe and draft-singh-nvo3-vxlan-router-alert, combined with
the addition of NSH.
 
[PG] Yes, one can put multiple (incompatible) extensions on top of VXLAN,
and achieve many things that Geneve is supporting. But at that point, aren¹t
we creating a new encapsulation format altogether? This new protocol with
all such extensions would require new hardware, new software, break existing
NIC offloads etc. and still carry the legacy baggage with no clear
advantage. At that point, I am not sure, why it is better?

 

LK> As I wrote above, extending VXLAN allows the same UDP port to be used
and reuse of the existing VXLAN parsing logic.
[PG] The crux of the discussion seems to be, whether Geneve should have a
mode that is compatible with VXLAN V1 or not. Even though it might be a
slippery slope, I think it is something to think about and debate further.

 

When the current NVO3 WG charter was being written, there seemed to be
consensus that we have no shortage of encapsulation options, but what was
lacking was a standard control plane.  The Geneve draft seems to turn that
on its head by saying "There is a clear advantage in settling on a data
format: most of the protocols are only superficially different and there is
little advantage in duplicating effort.  However, the same cannot be said of
control planes, which are diverse in very fundamental ways.  The case for
standardization is also less clear given the wide variety in requirements,
goals, and deployment scenarios.".  I agree with the first part of this, so
why define a completely new, non-backward compatible encapsulation?  I
disagree with the second part, since this is clearly the goal of the NVO3
WG.

 

I see that there is an agenda slot to discuss the Geneve draft, but I'm not
clear what the goals are of the authors within the IETF since the draft name
does not target it to any particular WG, and it is currently marked as
"Informational".  I would suggest that the authors consider extending
currently implemented encapsulations rather than starting from scratch, e.g.
by moving a few bits around in the first word of the Geneve header, it could
be made backward compatible with VXLAN.

 

Thanks, Larry
_______________________________________________ nvo3 mailing list
[email protected] https://www.ietf.org/mailman/listinfo/nvo3

_______________________________________________
nvo3 mailing list
[email protected]
https://www.ietf.org/mailman/listinfo/nvo3

Reply via email to