[GROW] BMP local-rib and rib-out drafts (draft-evens-grow-bmp-local-rib/adj-rib-out)

Jeffrey Haas <jhaas@pfrc.org> Mon, 27 March 2017 15:26 UTC

Return-Path: <jhaas@slice.pfrc.org>
X-Original-To: grow@ietfa.amsl.com
Delivered-To: grow@ietfa.amsl.com
Received: from localhost (localhost [127.0.0.1]) by ietfa.amsl.com (Postfix) with ESMTP id DB4E812940C for <grow@ietfa.amsl.com>; Mon, 27 Mar 2017 08:26:19 -0700 (PDT)
X-Virus-Scanned: amavisd-new at amsl.com
X-Spam-Flag: NO
X-Spam-Score: -1.903
X-Spam-Level:
X-Spam-Status: No, score=-1.903 tagged_above=-999 required=5 tests=[BAYES_00=-1.9, RP_MATCHES_RCVD=-0.001, SPF_HELO_PASS=-0.001, SPF_PASS=-0.001] autolearn=ham autolearn_force=no
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 lDh7CPytoqpY for <grow@ietfa.amsl.com>; Mon, 27 Mar 2017 08:26:17 -0700 (PDT)
Received: from slice.pfrc.org (slice.pfrc.org [67.207.130.108]) by ietfa.amsl.com (Postfix) with ESMTP id 533B1128954 for <grow@ietf.org>; Mon, 27 Mar 2017 08:26:17 -0700 (PDT)
Received: by slice.pfrc.org (Postfix, from userid 1001) id 707881E1DA; Mon, 27 Mar 2017 11:32:48 -0400 (EDT)
Date: Mon, 27 Mar 2017 11:32:48 -0400
From: Jeffrey Haas <jhaas@pfrc.org>
To: grow@ietf.org
Message-ID: <20170327153248.GV27015@pfrc.org>
MIME-Version: 1.0
Content-Type: text/plain; charset="us-ascii"
Content-Disposition: inline
User-Agent: Mutt/1.5.21 (2010-09-15)
Archived-At: <https://mailarchive.ietf.org/arch/msg/grow/WhYg8x4WnCL3jkOUWHrKjsAoSoQ>
Subject: [GROW] BMP local-rib and rib-out drafts (draft-evens-grow-bmp-local-rib/adj-rib-out)
X-BeenThere: grow@ietf.org
X-Mailman-Version: 2.1.22
Precedence: list
List-Id: Grow Working Group Mailing List <grow.ietf.org>
List-Unsubscribe: <https://www.ietf.org/mailman/options/grow>, <mailto:grow-request@ietf.org?subject=unsubscribe>
List-Archive: <https://mailarchive.ietf.org/arch/browse/grow/>
List-Post: <mailto:grow@ietf.org>
List-Help: <mailto:grow-request@ietf.org?subject=help>
List-Subscribe: <https://www.ietf.org/mailman/listinfo/grow>, <mailto:grow-request@ietf.org?subject=subscribe>
X-List-Received-Date: Mon, 27 Mar 2017 15:26:20 -0000

Grow Working Group,

I see that we have some timely BMP documents being presented during today's
Working Group session in Chicago.  I had considered submitting something
very similar for next IETF but I'm quite happy to say someone beat me to the
work.  However, since the BFD session has been cross-scheduled against
today's session, I'll have to give my comments here.

The encodings are, I believe, quite reasonable.  I will, however, note that
the drafts all squat on code points at the moment.  Please work with the
chairs to go through early IANA allocation.  This is particularly critical
for the peer flags field, which has scarce bits.

I would propose that an additional rib-out encoding should be specified.
While rib-out is of interest in many cases, it will often be redundant and
quite noisy for several use cases.  In BGP implementations supporting
peer-groups/update-groups, all peers in the group will receive a copy of the
same route.  Thus, I think a new message covering peer-group may be
sufficient for those cases and would significantly reduce the noise in the
system.  In cases where it is critical to know *exactly* what a peer is
getting, the per-peer version could be used.

I can send my notes on such an encoding at a later date.

There has been some desire by BMP users to know whether a given rib-in route
is a multipath contributor for BGP ECMP.  While this is technically a rib-in
feature, the discussion about how loc-rib is specified suggests it's a good
time to raise the question.

One highly important issue that these changes raise is stability of
information in the BMP data stream and prioritization of the different
message types.  Rib-in learning is already very highly noisy in BMP.
Loc-rib incremental re-convergence events will generate a similar amount of
noise, even with some amount of state compression (or I hope we're
compressing!). And more importantly, the rib out will exacerbate the amount
of noise we see in loc-rib convergence.

In many BMP use cases, rib-in state may be more important than loc-rib or
rib-out state.  In other cases, loc-rib is more important.  Thus, finding a
way to prioritize the messages may become a critical piece of procedure.

There's also some matter raised operationally about not making inferences
about event ordering of rib-in to loc-rib to rib-out based on message
ordering.  The timestamp may be most appropriate, but as noted above some
implementations that implement peer groups may not maintain things such as
advertisement time of a given prefix to a given peer.  Rib-in learning time
seems to be pretty consistently kept by most implementations I'm familiar
with.

Final point is that the procedure for loc-rib changing from the RFC is
enough that it raises backward compatibility considerations.  Since BMP is a
write-only protocol and it's not possible to negotiate such behaviors this
change might necessitate a BMP version change.

---

I hope to be able to make the BoF after the session to discuss these things
further.

-- Jeff