Re: [netmod] [Netconf] Alternative YANG library structure for 7895bis

Juergen Schoenwaelder <j.schoenwaelder@jacobs-university.de> Mon, 11 December 2017 16:17 UTC

Return-Path: <j.schoenwaelder@jacobs-university.de>
X-Original-To: netmod@ietfa.amsl.com
Delivered-To: netmod@ietfa.amsl.com
Received: from localhost (localhost [127.0.0.1]) by ietfa.amsl.com (Postfix) with ESMTP id 68DE3126DEE; Mon, 11 Dec 2017 08:17:33 -0800 (PST)
X-Virus-Scanned: amavisd-new at amsl.com
X-Spam-Flag: NO
X-Spam-Score: -1.9
X-Spam-Level:
X-Spam-Status: No, score=-1.9 tagged_above=-999 required=5 tests=[BAYES_00=-1.9, RCVD_IN_DNSWL_NONE=-0.0001] 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 BMpnbDLxCFIN; Mon, 11 Dec 2017 08:17:30 -0800 (PST)
Received: from atlas5.jacobs-university.de (atlas5.jacobs-university.de [212.201.44.20]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by ietfa.amsl.com (Postfix) with ESMTPS id 94441126D73; Mon, 11 Dec 2017 08:17:30 -0800 (PST)
Received: from localhost (demetrius5.irc-it.jacobs-university.de [10.70.0.222]) by atlas5.jacobs-university.de (Postfix) with ESMTP id E36E269A; Mon, 11 Dec 2017 17:17:28 +0100 (CET)
X-Virus-Scanned: amavisd-new at jacobs-university.de
Received: from atlas5.jacobs-university.de ([10.70.0.217]) by localhost (demetrius5.jacobs-university.de [10.70.0.222]) (amavisd-new, port 10032) with ESMTP id ap06WK_SdQYN; Mon, 11 Dec 2017 17:17:25 +0100 (CET)
Received: from hermes.jacobs-university.de (hermes.jacobs-university.de [212.201.44.23]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (Client CN "hermes.jacobs-university.de", Issuer "Jacobs University CA - G01" (verified OK)) by atlas5.jacobs-university.de (Postfix) with ESMTPS; Mon, 11 Dec 2017 17:17:28 +0100 (CET)
Received: from localhost (demetrius2.jacobs-university.de [212.201.44.47]) by hermes.jacobs-university.de (Postfix) with ESMTP id CDFF92012E; Mon, 11 Dec 2017 17:17:28 +0100 (CET)
X-Virus-Scanned: amavisd-new at jacobs-university.de
Received: from hermes.jacobs-university.de ([212.201.44.23]) by localhost (demetrius2.jacobs-university.de [212.201.44.32]) (amavisd-new, port 10024) with ESMTP id hV-QL91UCLau; Mon, 11 Dec 2017 17:17:27 +0100 (CET)
Received: from elstar.local (elstar.jacobs.jacobs-university.de [10.50.231.133]) by hermes.jacobs-university.de (Postfix) with ESMTP id 326C820129; Mon, 11 Dec 2017 17:17:27 +0100 (CET)
Received: by elstar.local (Postfix, from userid 501) id F33E3419454C; Mon, 11 Dec 2017 17:15:56 +0100 (CET)
Date: Mon, 11 Dec 2017 17:15:56 +0100
From: Juergen Schoenwaelder <j.schoenwaelder@jacobs-university.de>
To: Vladimir Vassilev <vladimir@transpacket.com>
Cc: Robert Wilton <rwilton@cisco.com>, "netmod@ietf.org" <netmod@ietf.org>, Netconf <netconf@ietf.org>
Message-ID: <20171211161556.me7thzsos2ywai3r@elstar.local>
Reply-To: Juergen Schoenwaelder <j.schoenwaelder@jacobs-university.de>
Mail-Followup-To: Vladimir Vassilev <vladimir@transpacket.com>, Robert Wilton <rwilton@cisco.com>, "netmod@ietf.org" <netmod@ietf.org>, Netconf <netconf@ietf.org>
References: <20171208.160306.109290175567894287.mbj@tail-f.com> <20171208150614.axuynu4atpg7aaj2@elstar.local> <b3159aa5-93e4-23eb-406e-083289a4767d@transpacket.com> <20171208153442.roomf7rhixtckrfk@elstar.local> <1512750289.11843.3.camel@nic.cz> <C030AD08-2E8B-4248-994B-04C802296024@juniper.net> <CABCOCHQZLirVDqGNysAkRFXruPKxyXrBQ+xyagU9y3QHRV6d0g@mail.gmail.com> <9b62952b-d3e6-2db2-6aac-9a544a991078@transpacket.com> <3aac1b82-9cfb-97af-cecb-c469587c37d1@cisco.com> <137c9dac-acb8-69ba-6b9d-20c92d5aeec0@transpacket.com>
MIME-Version: 1.0
Content-Type: text/plain; charset="iso-8859-1"
Content-Disposition: inline
X-Clacks-Overhead: GNU Terry Pratchett
Content-Transfer-Encoding: 8bit
In-Reply-To: <137c9dac-acb8-69ba-6b9d-20c92d5aeec0@transpacket.com>
User-Agent: NeoMutt/20170714 (1.8.3)
Archived-At: <https://mailarchive.ietf.org/arch/msg/netmod/vqA_62jFK3SmJzzV_j-cAnNORXA>
Subject: Re: [netmod] [Netconf] Alternative YANG library structure for 7895bis
X-BeenThere: netmod@ietf.org
X-Mailman-Version: 2.1.22
Precedence: list
List-Id: NETMOD WG list <netmod.ietf.org>
List-Unsubscribe: <https://www.ietf.org/mailman/options/netmod>, <mailto:netmod-request@ietf.org?subject=unsubscribe>
List-Archive: <https://mailarchive.ietf.org/arch/browse/netmod/>
List-Post: <mailto:netmod@ietf.org>
List-Help: <mailto:netmod-request@ietf.org?subject=help>
List-Subscribe: <https://www.ietf.org/mailman/listinfo/netmod>, <mailto:netmod-request@ietf.org?subject=subscribe>
X-List-Received-Date: Mon, 11 Dec 2017 16:17:33 -0000

I do not fully understand why you think it is worth to preserve the
old YANG module library structure. Clearly, it won't be backwards
compatible since an NMDA implementation may list modules that are not
implemented in all datastores and an old client talking to a new
server will thus misunderstand what is exposed via the old YANG module
library structure. Your proposal "looks" backwards compatible but it
is not if one takes a closer look.

One can start making changes to say the conformance-type but then this
does not solve the problem since an old client does not know what a
new conformance type value means. The design team did look into the
option of keeping the old structure unchanged some weeks ago and we
finally arrived at the conclusion that it gets (i) ugly and (ii) does
not really provide backwards compatibility for a client written agains
the old YANG module library structure.

Note that with the new proposals on the table, it should be possible
to provide a backwards compatible view on YANG library for systems
that implement the exact same module set (with the exact same set of
features and deviations) on all datastores they support. But for
systems where this is not true, it seems better to use new
definitions instead of tweaking semantics.

Perhaps it helps if you can clearly phrase the objective of keeping
the old structure. What is the goal you want to achieve with that?

/js

On Mon, Dec 11, 2017 at 04:53:30PM +0100, Vladimir Vassilev wrote:
> On 12/11/2017 12:16 PM, Robert Wilton wrote:
> 
> > Hi Vladimir,
> > 
> > 
> > On 09/12/2017 11:49, Vladimir Vassilev wrote:
> > > On 12/08/2017 07:01 PM, Andy Bierman wrote:
> > > 
> > > > Hi,
> > > > 
> > > > A library per datastore sounds too complicated.
> > > I am not proposing that.
> > I'm slightly lost, because I thought that was exactly what you were
> > proposing! ;-)
> I propose a solution that keeps ietf-yang-library a data model of a single
> YANG context specification doing the datastore specific modeling in
> ietf-datastores model instead. The solution can be both flexible
> (independent yang-library data instances per datastore as my example was
> focused on) or constrained ('not-implemented-in' modules leaf-list). Here is
> everything that is needed:
> 
> module: ietf-datastores
>     +--ro datastores-state
>        +--ro datastore* [name]
>        +--ro (model)?
>           +--:(same-as-operational)
>           +--:(constrained-to-operational)
>           |  +--ro not-implemented-in*       ->
> /yanglib:module-state/module/name
>           +--:(unconstrained)
>              +--ro yang-library-datastore?   identityref
> 
> YANG:
> ...
> container datastores-state {
>     config false;
>     list datastore {
>       key name;
>     }
>     choice model {
>         case same-as-operational {
>         }
>         case constrained-to-operational {
>           leaf-list not-implemented-in {
>             type leafref {
>               path "/yanglib:module-state/yanglib:module/yanglib:name";
>             }
>           }
>         }
>         case unconstrained {
>           leaf yang-library-datastore {
>             type identityref {
>               base ds:datastore;
>           }
>         }
>       }
>     }
>   }
> ...
> 
> IMO ietf-yang-library as defined in rfc7895 is modular and reusable. I do
> not see why this has to be compromised.
> > > 
> > > The fundamental point proposed is that the datastore relevant bits
> > > are kept in the ietf-datastores module instead of merging everything
> > > in a new ietf-yang-library entangled monster module. If needed
> > > ietf-datastores can augment ietf-yang-library but ietf-yang-library
> > > should be usable on its own without ietf-datastores. The solution is
> > > coherent and modular and addresses the problem statement.
> > 
> > The issue with this is that datastore augmentations to YANG library
> > would end up changing the meaning of the existing YANG library nodes. 
> > E.g. an old client that ignores the datastore augmentations is going to
> > get a nasty surprise when the server does not behave how it expects. 
> > E.g. because the configuration node that it thinks should be there isn't
> > there because it only supported in <operational>.
> > 
> > This was one of the reasons for changing YANG library.
> A well written client that finds out unsupported newer versions of
> ietf-yang-library (which is reported in the capabilities) or any of the NMDA
> modules is deployed should not do any damage. How exactly did you solve the
> problem for the bad clients by changing the structure of yang-library in a
> incompatible way is something I do not understand.
> > 
> > In terms of the idea of just re-using YANG library but export a separate
> > copy for each datastore I think that this has its own problems:
> > - I don't like the idea of returning meta-data along with configuration
> > for a <get-data> on any of the configuration datastores.
> There is no meta data. The datastores contain only the config false;
> /modules-state tree. I think I explained that very clearly.
> > - How does a client know whether the YANG library for <running> applies
> > to the whole server (as it does today) vs just applies to the <running>
> > datastore (as it would for an NMDA server)?
> All datastore models are "case same-as-operational" for such systems.
> > - It requires more handshaking between the client and server to get the
> > schema, since a separate request would be required for each datastore
> > that is supported.
> Correct. Flexibility and modularity come at a price. IMO modularity is more
> important in this case. And there are solutions for the problem e.g. send
> all <get-data> requests before waiting for replies. NETCONF supports this.
> > 
> > So, for me, I think that the only way that this solution works, would be
> > to define a new <get-server-metadata> RPC, but even then I think that it
> > would make sense to combine the data together into a new YANG library
> > structure.
> As I said my focus is on keeping ietf-yang-library modular (single YANG
> model context). <get-server-metadata> or just adding datastore identities
> allowing the client to use <get-data> to achieve the retrieval of the data
> is of little importance to me.
> 
> > 
> > At the end of the day, I don't think that a new YANG library is going to
> > be were the real cost for supporting NMDA comes from.  I think that the
> > real work is supporting <operational> independently from <running> both
> > in the client and servers. But I also think that once servers start
> > implementing this properly that it will simplify automation, because
> > rather than a client having to guess what state a server is in, it can
> > actually querey, or be notified of it, without having to write a lot of
> > model specific code.
> +1
> 
> Vladimir
> > 
> > Thanks,
> > Rob
> > 
> > 
> > > > I prefer the proposal that was made at the IETF meeting that had
> > > > a 'not-implemented-in' leaf-list and a single module list.
> > > This constraint is already specified in the text of the revised
> > > datastores draft. Clients conforming to the draft can expect servers
> > > to comply with the MUST requirement even if there is a separate
> > > yang-library data tree for each datastore the constraint of
> > > configuration stores mapping to 'operational' should be enforced
> > > according to the draft. There is no contradiction here.
> > > 
> > > That said I would be also be OK with ietf-datastores augmenting
> > > ietf-yang-library with such a leaf-list ('not-implemented-in'
> > > leaf-list) as a more constrained flavor of the same approach instead
> > > of going for independent copies of yang-library data. For any of
> > > that to happen change in ietf-datastores.yang is needed and change
> > > in the original rfc7895 ietf-yang-library is not needed at all.
> > > 
> > > Vladimir
> > > 
> > > > 
> > > > Why is it interesting to have a separate module list for regular
> > > > modules and imported modules?
> > > > I prefer to keep the conformance leaf and not change the module list.
> > > > 
> > > > NMDA needs to be possible to implement with a single schema tree
> > > > such that a module
> > > > is implemented in all datastores, or a subset of all
> > > > datastores.  Otherwise it probably won't
> > > > get supported in clients.
> > > > 
> > > > 
> > > > Andy
> > > > 
> > > > 
> > > > 
> > > > On Fri, Dec 8, 2017 at 9:21 AM, Kent Watsen <kwatsen@juniper.net
> > > > <mailto:kwatsen@juniper.net>> wrote:
> > > > 
> > > >     CC-ing NETCONF, where the draft is being worked on.
> > > > 
> > > >     Kent
> > > > 
> > > > 
> > > >     On Fri, 2017-12-08 at 16:34 +0100, Juergen Schoenwaelder wrote:
> > > >     > On Fri, Dec 08, 2017 at 04:19:28PM +0100, Vladimir
> > > > Vassilev wrote:
> > > >     > >
> > > >     > > Yes. The default value for yang-library-datastore leaf is
> > > >     ds:operational
> > > >     > > (the only possible one for the ds:operational datastore). This
> > > >     is backward
> > > >     > > compatible. If one needs different model for 'running', etc.
> > > >     then a new
> > > >     > > datastore identity has to be defined  and set in place of the
> > > >     default value.
> > > >     > > Then this identity can be used to read the yang-library
> > > > data with
> > > >     > > <get-data>.
> > > >     > >
> > > >     >
> > > >     > Sorry, but I have to ask this: How do I obtain the schema for the
> > > >     > datastore (lets call it <running-library>) that reports the
> > > >     schema for
> > > >     > <running>? Is there another <running-library-library> datastore?
> > > >     Will
> > > >     > the recursion end? Perhaps it does since
> > > > <running-library-library>
> > > >     > might have itself listed as the schema defining datastore.
> > > > I guess
> > > >     > Lada will like these kind of meta and meta-meta datastores.
> > > > 
> > > >     Not really. Metadata needn't be in datastores.
> > > > 
> > > >     Lada
> > > > 
> > > >     >
> > > >     > /js
> > > >     >
> > > >     --
> > > >     Ladislav Lhotka
> > > >     Head, CZ.NIC Labs
> > > >     PGP Key ID: 0xB8F92B08A9F76C67
> > > > 
> > > >     _______________________________________________
> > > >     netmod mailing list
> > > >     netmod@ietf.org <mailto:netmod@ietf.org>
> > > > https://urldefense.proofpoint.com/v2/url?u=https-3A__www.ietf.org_mailman_listinfo_netmod&d=DwICAg&c=HAkYuh63rsuhr6Scbfh0UjBXeMK-ndb3voDTXcWzoCI&r=9zkP0xnJUvZGJ9EPoOH7Yhqn2gsBYaGTvjISlaJdcZo&m=5qj6BQUSwqYmkAVeKz5axFV8k3gxYEPSJ5Cp0RSnxrE&s=I7fR1GY5lN2hVMkDuvryrhDeRypike3wPeFRrvQI5l8&e=
> > > > 
> > > > <https://urldefense.proofpoint.com/v2/url?u=https-3A__www.ietf.org_mailman_listinfo_netmod&d=DwICAg&c=HAkYuh63rsuhr6Scbfh0UjBXeMK-ndb3voDTXcWzoCI&r=9zkP0xnJUvZGJ9EPoOH7Yhqn2gsBYaGTvjISlaJdcZo&m=5qj6BQUSwqYmkAVeKz5axFV8k3gxYEPSJ5Cp0RSnxrE&s=I7fR1GY5lN2hVMkDuvryrhDeRypike3wPeFRrvQI5l8&e=>
> > > > 
> > > > 
> > > > 
> > > >     _______________________________________________
> > > >     netmod mailing list
> > > >     netmod@ietf.org <mailto:netmod@ietf.org>
> > > >     https://www.ietf.org/mailman/listinfo/netmod
> > > >     <https://www.ietf.org/mailman/listinfo/netmod>
> > > > 
> > > > 
> > > > 
> > > > 
> > > > _______________________________________________
> > > > netmod mailing list
> > > > netmod@ietf.org
> > > > https://www.ietf.org/mailman/listinfo/netmod
> > > 
> > > _______________________________________________
> > > Netconf mailing list
> > > Netconf@ietf.org
> > > https://www.ietf.org/mailman/listinfo/netconf
> > 
> 
> _______________________________________________
> netmod mailing list
> netmod@ietf.org
> https://www.ietf.org/mailman/listinfo/netmod

-- 
Juergen Schoenwaelder           Jacobs University Bremen gGmbH
Phone: +49 421 200 3587         Campus Ring 1 | 28759 Bremen | Germany
Fax:   +49 421 200 3103         <http://www.jacobs-university.de/>