Re: [netmod] Comments on schema mount draft

Rohit Ranade <rohitrranade@outlook.com> Fri, 06 April 2018 13:04 UTC

Return-Path: <rohitrranade@outlook.com>
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 E8C27126CC7 for <netmod@ietfa.amsl.com>; Fri, 6 Apr 2018 06:04:33 -0700 (PDT)
X-Virus-Scanned: amavisd-new at amsl.com
X-Spam-Flag: NO
X-Spam-Score: -2.009
X-Spam-Level:
X-Spam-Status: No, score=-2.009 tagged_above=-999 required=5 tests=[BAYES_00=-1.9, DKIM_SIGNED=0.1, DKIM_VALID=-0.1, DKIM_VALID_AU=-0.1, FREEMAIL_FROM=0.001, HTML_MESSAGE=0.001, RCVD_IN_DNSWL_NONE=-0.0001, SPF_PASS=-0.001, T_RP_MATCHES_RCVD=-0.01] autolearn=ham autolearn_force=no
Authentication-Results: ietfa.amsl.com (amavisd-new); dkim=pass (2048-bit key) header.d=outlook.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 83hRNkKBHmcD for <netmod@ietfa.amsl.com>; Fri, 6 Apr 2018 06:04:30 -0700 (PDT)
Received: from APC01-PU1-obe.outbound.protection.outlook.com (mail-oln040092254066.outbound.protection.outlook.com [40.92.254.66]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-SHA384 (256/256 bits)) (No client certificate requested) by ietfa.amsl.com (Postfix) with ESMTPS id AC1191201FA for <netmod@ietf.org>; Fri, 6 Apr 2018 06:04:29 -0700 (PDT)
DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=outlook.com; s=selector1; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version; bh=hvEaxPVX2fVBj35m0EvSO66oy+jt5UrxM43ZDaYaPwA=; b=WhDYeJS4cUdvy1w5dpWCH/zOffKdjVLBHQvtPIl/jzrIPR3yyWEaiuhMfTQIzHMxLkvulnRTmpOs8dV1qqN8W+bd1kbcye9jP7NOXf+x5WBrw4ZPHvY+ID2flEVFMUjpA2g1BEP34xo9g3QzP1XcQH5SijC4ui0hjLHN2mNu3rDqZAwRZt322Tr5Pr+PgyVwiRvQuu2P9y2p65UWsX+P+Ikw+GH+fTPzGXvAWQ6foxo4QSDHeBEEg8Va8KiWOM8rzAYRD2YxI6vOrvgiO6D6s76W5y4CPzyTJblgRiVoJpAJoZkKa6/3mCd6O642t3BU5QA1V54yh6akyIzUUokZzw==
Received: from PU1APC01FT015.eop-APC01.prod.protection.outlook.com (10.152.252.51) by PU1APC01HT004.eop-APC01.prod.protection.outlook.com (10.152.252.120) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA384_P256) id 15.20.653.8; Fri, 6 Apr 2018 13:04:27 +0000
Received: from HK2PR0401MB1265.apcprd04.prod.outlook.com (10.152.252.56) by PU1APC01FT015.mail.protection.outlook.com (10.152.252.227) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA384_P256) id 15.20.653.8 via Frontend Transport; Fri, 6 Apr 2018 13:04:27 +0000
Received: from HK2PR0401MB1265.apcprd04.prod.outlook.com ([fe80::2db2:49db:7b47:d80]) by HK2PR0401MB1265.apcprd04.prod.outlook.com ([fe80::2db2:49db:7b47:d80%4]) with mapi id 15.20.0653.012; Fri, 6 Apr 2018 13:04:27 +0000
From: Rohit Ranade <rohitrranade@outlook.com>
To: Martin Bjorklund <mbj@tail-f.com>
CC: "netmod@ietf.org" <netmod@ietf.org>
Thread-Topic: [netmod] Comments on schema mount draft
Thread-Index: AQHTxDbT1I3AIjMZP0GUUq533JigqqPiK6iAgAIEP92AAqcggIAIV7nqgAMAT4CAAZXZ7g==
Date: Fri, 06 Apr 2018 13:04:26 +0000
Message-ID: <HK2PR0401MB12652B45BACC5902890EADA4DBBA0@HK2PR0401MB1265.apcprd04.prod.outlook.com>
References: <KL1PR0401MB1272858515A76DF861B73D21DBAC0@KL1PR0401MB1272.apcprd04.prod.outlook.com> <20180329.092953.1063547768163198657.mbj@tail-f.com> <KL1PR0401MB12720644E171A6A8AC738545DBA50@KL1PR0401MB1272.apcprd04.prod.outlook.com>, <20180405.144349.1531327560930954458.mbj@tail-f.com>
In-Reply-To: <20180405.144349.1531327560930954458.mbj@tail-f.com>
Accept-Language: en-US
Content-Language: en-US
X-MS-Has-Attach:
X-MS-TNEF-Correlator:
x-incomingtopheadermarker: OriginalChecksum:FE6C3440F4081A1A158932BD7513C1B45A465653C8B45FFFDCC64CEC5B8F924A; UpperCasedChecksum:C277EA6E15E757FD81E4FF1BBA42574E1FBDD3513528305B4CA87B78BA463EB2; SizeAsReceived:7332; Count:47
x-ms-exchange-messagesentrepresentingtype: 1
x-tmn: [xUejEMfoIoWvH24cmzp+T1hjiBLhodx+]
x-ms-publictraffictype: Email
x-microsoft-exchange-diagnostics: 1; PU1APC01HT004; 7:feZFB/DcoMnz9ZFsmQsP4DKL1r3XPCmqnBrv5MSfinYluMAlTRmBAiXJmzvw0cG+tSOwfmvrpm79fR4t9K91LeijIJEgNPNTILL3kWg+cGu+3RXKkoRpR5rxFn/W5e5cmTKXZ1zBYrtUPLw2myUsl4ECmgwU7Pky7v6ZmadONHz7KZStKbX8mCJim7lb8L45P58JozS+MxGopTV0KJe9MDnIEjqywy7I7/JddEaEeNmc6a/bURUUg9kcYSfi2AqA
x-incomingheadercount: 47
x-eopattributedmessage: 0
x-microsoft-antispam: UriScan:; BCL:0; PCL:0; RULEID:(7020095)(201702061078)(5061506573)(5061507331)(1603103135)(2017031320274)(2017031324274)(2017031323274)(2017031322404)(1603101448)(1601125374)(1701031045); SRVR:PU1APC01HT004;
x-ms-traffictypediagnostic: PU1APC01HT004:
x-ms-office365-filtering-correlation-id: 597a19cd-11cf-4705-df35-08d59bbeed5d
x-exchange-antispam-report-cfa-test: BCL:0; PCL:0; RULEID:(444000031); SRVR:PU1APC01HT004; BCL:0; PCL:0; RULEID:; SRVR:PU1APC01HT004;
x-forefront-prvs: 0634F37BFF
x-forefront-antispam-report: SFV:NSPM; SFS:(7070007)(98901004); DIR:OUT; SFP:1901; SCL:1; SRVR:PU1APC01HT004; H:HK2PR0401MB1265.apcprd04.prod.outlook.com; FPR:; SPF:None; LANG:;
x-microsoft-antispam-message-info: MKDqZSIaiMx2vQdrpybkQ8jUeVD/mW7ZbKAR7THSaxrOvsAWYBiRkjecdSsABjT+DtmIBRfkg4WjEqkyCCb3odBNupNYpoTsbeTyYrugLNBQwgTXbbFnc7LcFq2iA41p5bSUC39JN5cwZ8MQwnv6qwE9aeKzUbsDe2docWxs0t/WS6N6kFkeCL0ObuOMwNFv
spamdiagnosticoutput: 1:99
spamdiagnosticmetadata: NSPM
Content-Type: multipart/alternative; boundary="_000_HK2PR0401MB12652B45BACC5902890EADA4DBBA0HK2PR0401MB1265_"
MIME-Version: 1.0
X-OriginatorOrg: outlook.com
X-MS-Exchange-CrossTenant-Network-Message-Id: 597a19cd-11cf-4705-df35-08d59bbeed5d
X-MS-Exchange-CrossTenant-originalarrivaltime: 06 Apr 2018 13:04:26.3530 (UTC)
X-MS-Exchange-CrossTenant-fromentityheader: Internet
X-MS-Exchange-CrossTenant-id: 84df9e7f-e9f6-40af-b435-aaaaaaaaaaaa
X-MS-Exchange-Transport-CrossTenantHeadersStamped: PU1APC01HT004
Archived-At: <https://mailarchive.ietf.org/arch/msg/netmod/GpxBbx1B-uZ5DabnIl9TMBHFOYs>
Subject: Re: [netmod] Comments on schema mount draft
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: Fri, 06 Apr 2018 13:04:34 -0000

Hi Martin,



For below point:

“

> 4. NETCONF has some "rpc" which work on multiple mount-instances.
>
>    ==> For example <edit-config> , <get-config> or <lock>. Whether we need to give a
>
>    guideline for how to handle such "rpc", so that other protocols which implement schema mount   also adapt accordingly ?
>
>    Eg: Something like, for transaction management, better to operate on one mount-instance.

This would not be correct.  I think you are assuming one use case;
where schema mount is used in a (primitive) orchestrator that actually
talks to multiple devices (w/o transaction control).

Note that this document just defines how the *schema* is built; not
how instance data is stored or accessed.

”

As per example shown in section 4:

     +--rw network-instances

        +--rw network-instance* [name]

           +--rw name

           +--rw root

              +--rw routing



Considering “root” as mount point :



When querying data from schema mounted models:



<get-config>

  <filter>

    <network-instances>

      <network-instance>

       <name>1</name>

        <root>

          <routing/>



And



<action>

    <network-instances>

      <network-instance>

       <name>1</name>

        <root>

          <get-config>  -- having ietf-netconf ns

            <filter>

             <routing/>



Will these two give the same result ?



With Regards,

Rohit R



Sent from Mail<https://go.microsoft.com/fwlink/?LinkId=550986> for Windows 10



________________________________
From: Martin Bjorklund <mbj@tail-f.com>
Sent: Thursday, April 5, 2018 6:13:49 PM
To: rohitrranade@outlook.com
Cc: netmod@ietf.org
Subject: Re: [netmod] Comments on schema mount draft

Hi,


Rohit Ranade <rohitrranade@outlook.com> wrote:
> Hi Martin,
>
>
>
> Thank you for your responses.
>
> I have gone through the LNE draft and YANG 1.1 and found some more suggestions.
>
>
>
> 1. Section 5
>
>    "If a mounted YANG module defines an RPC operation, clients can invoke
>
>    this operation as if it were defined as an action for the
>
>    corresponding mount point"
>
>    ==> Below is the example from Yang 1.1 Section 7.15
>
>
>
>     <rpc message-id="101"
>
>           xmlns="urn:ietf:params:xml:ns:netconf:base:1.0">
>
>        <action xmlns="urn:ietf:params:xml:ns:yang:1">
>
>          <server xmlns="urn:example:server-farm">
>
>            <name>apache-1</name>
>
>            <reset>
>
>              <reset-at>2014-07-29T13:42:00Z</reset-at>
>
>            </reset>
>
>          </server>
>
>        </action>
>
>      </rpc>
>
>
>
>      <rpc-reply message-id="101"
>
>                 xmlns="urn:ietf:params:xml:ns:netconf:base:1.0">
>
>        <reset-finished-at xmlns="urn:example:server-farm">
>
>          2014-07-29T13:42:12Z
>
>        </reset-finished-at>
>
>      </rpc-reply>
>
>               ==> Here rpc-reply only has the namespace and action name defined in the mount-instance's module.
>
>               The client needs to store information of the mount-instance for which the RPC request was sent and only then it can validate the rpc-reply against the data-model.
>
>               To avoid this work of client, whether we can think of adding meta-data to rpc-reply to provide this information to client.

If the client invokes an action, it is expected that it knows how to
interpret the result.  This does not change with the introduction of
schema mount.  The client obviously knows the name and input
parameters of the action, so it seems resonable to expect that it
knows the output parameters as well, w/o any additional meta data.

> 2. Section 5
>
>    I would prefer the approach taken by Yang 1.1 where statements followed by XML examples   to help in clarity.
>
>    Especially for the RPC and notification section, it is better to add clear examples
>
>    in a "Usage Example" sub-section for this section.

The examples are given in the appendix, and there is a forward
reference to the appendix from section 5.


> 3. Yang RPC and ACTION statements:
>
>   If we need to view the RPC defined in a module as an ACTION after schema mount, then
>
>   Whenever there is update to RPC in say YANG 1.2, then the corresponding changes must be present in ACTION also, introducing a coupling between RPC and ACTION statements.

This module is written using YANG 1.1.  Unless this module is updated,
it doesn't matter what YANG 2.0 or whatever does.

> 4. NETCONF has some "rpc" which work on multiple mount-instances.
>
>    ==> For example <edit-config> , <get-config> or <lock>. Whether we need to give a
>
>    guideline for how to handle such "rpc", so that other protocols which implement schema mount   also adapt accordingly ?
>
>    Eg: Something like, for transaction management, better to operate on one mount-instance.

This would not be correct.  I think you are assuming one use case;
where schema mount is used in a (primitive) orchestrator that actually
talks to multiple devices (w/o transaction control).

Note that this document just defines how the *schema* is built; not
how instance data is stored or accessed.



/martin

>
>
>
>
>
>
>
> With Regards,
>
> Rohit R
>
>
>
> ________________________________
> From: Martin Bjorklund <mbj@tail-f.com>
> Sent: Thursday, March 29, 2018 12:59:53 PM
> To: rohitrranade@outlook.com
> Cc: netmod@ietf.org
> Subject: Re: [netmod] Comments on schema mount draft
>
> Hi,
>
> Rohit Ranade <rohitrranade@outlook.com> wrote:
> > Hi Martin,
> >
> > W.r.t <get-schema> on the main device, it will mean that for
> > successful <get-schema> for all the schema of mounted devices, the
> > main device must be upgraded to higher version first and must contain
> > ALL the schema of all the devices behind the main device.
>
> This is not the intention, and as you note, in many cases this is just
> not possible.
>
> The client can look at the "location" leaf in the mounted YANG library
> (in YLbis; in old YL it was called "schema") and get the module from
> there.
>
> If the mounted schema also mounts "ietf-netconf-monitoring", the
> client can invoke the mounted <get-schema> as an action, and retrieve
> the specific version of the module that is mounted there.
>
> > This point may prove to be tricky as the whole topology upgrade has to
> > be considered always. I feel we can add some text regarding this.
> >
> > Also how to “mount” an instance of a mount-point ? Because once this
> > draft is out, each implementer may define private RPCs for mount and
> > un-mount if this module does not define it. Whether any plan about it
> > ?
>
> Note that schema mount is not about mounting devices; that would be a
> future specialization of this mechanism.
>
> In the LNE and NI drafts, entities are "mounted" by creating entries
> in the corresponding lists.  There is no need for a "mount" rpc in
> these cases.
>
>
> /martin
>
>
>
>
> >
> >
> >
> >
> > With Regards,
> > Rohit R
> >
> > Sent from Mail<https://go.microsoft.com/fwlink/?LinkId=550986> for
> > Windows 10
> >
> > From: Martin Bjorklund<mailto:mbj@tail-f.com>
> > Sent: 26 मार्च 2018 13:41
> > To: rohitrranade@outlook.com<mailto:rohitrranade@outlook.com>
> > Cc: netmod@ietf.org<mailto:netmod@ietf.org>
> > Subject: Re: [netmod] Comments on schema mount draft
> >
> > Hi,
> >
> > Thank you for these comments, replies inline.
> >
> > Rohit Ranade <rohitrranade@outlook.com> wrote:
> > > Hi All,
> > >
> > > Please find some comments for the schema mount draft. If I find any
> > > other will send in another mail.
> > >
> > > Editorial:
> > > ============
> > > 1. Section 3.1
> > >    "The "mount-point" statement MUST NOT be used in a YANG version 1
> > >    module."
> > >    ==> It is unclear why such a restriction is placed.
> >
> > The reason is that YANG 1 doesn't support inline actions and
> > notification, which means that top-level rpcs and notifs in the
> > mounted module cannot be invoked using the mechanism described in
> > section 5.  I will try to clarify this.
> >
> > > 2. Section 3.2
> > >    "state data in the "yangmnt:schema-mounts""
> > >    ==> Here the yang tree diagram is not yet introduced. I feel better to
> > >    introduce
> > >    this diagram as it makes it easier to understand the data-nodes
> >
> > Ok.  I moved section 8 to a new section 3.2.
> >
> > > 3. Section 3.2
> > >    "Data in this container is intended to be as stable as data in the
> > >    top-level YANG library"
> > >    ==> What is the meaning of "as stable" as ? As a developer , I am
> > >    unclear what needs
> > >    to be done here. Please clarify.
> >
> > Kent also had a comment around this, and the text about stable is now
> > removed.
> >
> > > 4. Section 3.2
> > >    "i.e., instances of that mount point MUST NOT contain any data above
> > >    those that are defined in the parent schema."
> > >    ==> Here "any data above", means "above" in the hieararchy ?
> >
> > No, this was just wrong; it should be "except".
> >
> > >    Not
> > >    clear, this is similar
> > >    to having a USB slot, but no device mounted on it as yet in UNIX
> > >    terms. Right ?
> > >    The query output on parent-schema should give empty data.
> > >
> > > 5. Section 3.2
> > >    "If multiple mount points with the same name are defined in the same
> > >    module - either directly or because the mount point is defined in a
> > >    grouping and the grouping is used multiple times - then the
> > >    corresponding "mount-point" entry applies equally to all such mount
> > >    points."
> > >   ==> As per tree diagram, "mount-point" has two keys. So each module
> > >   can have multiple
> > >   mount points. So how to apply it "equally" ? Not clear.
> >
> > Note that the sentence starts with "If multiple mount points with the
> > same name are defined in the same module" -- so this clearly doesn't
> > apply to mount points with different names, right?
> >
> > For example, you can have:
> >
> >   container foo {
> >     yangmnt:mount-point my-mnt-point;
> >   }
> >   container bar {
> >     yangmnt:mount-point my-mnt-point;
> >   }
> >
> > There is just one entry in the "mount-point" list, so that entry
> > applies to both these mount points.  Both are either "inline" or
> > "shared-schema".
> >
> >
> > > 6. Section 3.2
> > >    Instead of "inline" and "shared-schema", I suggest to use
> > >    "variable-schema" and
> > >    "same-schema"
> > >    Reason: The key difference between the two is that in one case, the
> > >    schema MAY be different
> > >    while in the other the schema is same. The name can be similar to the
> > >    reason.
> >
> > At this point, we have to live with these terms.  This was part of the
> > compromise leading to this solution; there are other documents in the
> > RFC editor's queue that depend on these terms.
> >
> > > Logical Point:
> > > 1. Consider the topology where 1 main device is present with N logical
> > > devices behind it.
> > >    When the mounting is done, it is quite possible that some of N devices
> > >    are having different
> > >    versions of modules.
> > >    This can lead to each instance of mount point, having different
> > >    schema.
> > >    How can the client understand the schema of each mount-point instance
> > >    ? Preferably get-schema of these devices and then know the model ?
> >
> > This draft says that each instance will have its own YANG library
> > instance.  So there the client can detect which versions of the
> > different modules each instance supports.  Then <get-schema> can be
> > invoked to get the modules, if it is supported.
> >
> >
> > /martin
> >