Re: [Netconf] YANG Doctor question: empty mandatory choice?

Henk Birkholz <henk.birkholz@sit.fraunhofer.de> Thu, 02 August 2018 16:22 UTC

Return-Path: <henk.birkholz@sit.fraunhofer.de>
X-Original-To: netconf@ietfa.amsl.com
Delivered-To: netconf@ietfa.amsl.com
Received: from localhost (localhost [127.0.0.1]) by ietfa.amsl.com (Postfix) with ESMTP id 31F39130E2B for <netconf@ietfa.amsl.com>; Thu, 2 Aug 2018 09:22:03 -0700 (PDT)
X-Virus-Scanned: amavisd-new at amsl.com
X-Spam-Flag: NO
X-Spam-Score: -6.901
X-Spam-Level:
X-Spam-Status: No, score=-6.901 tagged_above=-999 required=5 tests=[BAYES_00=-1.9, RCVD_IN_DNSWL_HI=-5, SPF_PASS=-0.001] autolearn=unavailable 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 0U71MCVm_O6Q for <netconf@ietfa.amsl.com>; Thu, 2 Aug 2018 09:22:01 -0700 (PDT)
Received: from mailext.sit.fraunhofer.de (mailext.sit.fraunhofer.de [141.12.72.89]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by ietfa.amsl.com (Postfix) with ESMTPS id DF809130E21 for <netconf@ietf.org>; Thu, 2 Aug 2018 09:22:00 -0700 (PDT)
Received: from mail.sit.fraunhofer.de (mail.sit.fraunhofer.de [141.12.84.171]) by mailext.sit.fraunhofer.de (8.14.4/8.14.4/Debian-4.1ubuntu1) with ESMTP id w72GLbjn011187 (version=TLSv1/SSLv3 cipher=DHE-RSA-AES256-GCM-SHA384 bits=256 verify=NOT); Thu, 2 Aug 2018 18:21:39 +0200
Received: from [192.168.16.50] (134.102.43.163) by mail.sit.fraunhofer.de (141.12.84.171) with Microsoft SMTP Server (TLS) id 14.3.399.0; Thu, 2 Aug 2018 18:21:32 +0200
To: Kent Watsen <kwatsen@juniper.net>, Alexander Clemm <alexander.clemm@huawei.com>, Martin Bjorklund <mbj@tail-f.com>
CC: "evoit=40cisco.com@dmarc.ietf.org" <evoit=40cisco.com@dmarc.ietf.org>, "netconf@ietf.org" <netconf@ietf.org>
References: <44B0A74E-CCF0-4E9B-846A-1F46E90AEB5E@juniper.net> <20180731.165103.950825344221422538.mbj@tail-f.com> <644DA50AFA8C314EA9BDDAC83BD38A2E0EB406AA@sjceml521-mbx.china.huawei.com> <024DE375-E3F0-4255-AC53-2D17C77D6E06@juniper.net>
From: Henk Birkholz <henk.birkholz@sit.fraunhofer.de>
Message-ID: <2b135729-7a5c-ede1-a15b-3cb6b453256e@sit.fraunhofer.de>
Date: Thu, 02 Aug 2018 18:21:31 +0200
User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101 Thunderbird/52.9.1
MIME-Version: 1.0
In-Reply-To: <024DE375-E3F0-4255-AC53-2D17C77D6E06@juniper.net>
Content-Type: text/plain; charset="utf-8"; format="flowed"
Content-Language: en-US
Content-Transfer-Encoding: 8bit
X-Originating-IP: [134.102.43.163]
Archived-At: <https://mailarchive.ietf.org/arch/msg/netconf/aBI0YrQuzDdv9NXRmml2sgjL_mw>
Subject: Re: [Netconf] YANG Doctor question: empty mandatory choice?
X-BeenThere: netconf@ietf.org
X-Mailman-Version: 2.1.27
Precedence: list
List-Id: Network Configuration WG mailing list <netconf.ietf.org>
List-Unsubscribe: <https://www.ietf.org/mailman/options/netconf>, <mailto:netconf-request@ietf.org?subject=unsubscribe>
List-Archive: <https://mailarchive.ietf.org/arch/browse/netconf/>
List-Post: <mailto:netconf@ietf.org>
List-Help: <mailto:netconf-request@ietf.org?subject=help>
List-Subscribe: <https://www.ietf.org/mailman/listinfo/netconf>, <mailto:netconf-request@ietf.org?subject=subscribe>
X-List-Received-Date: Thu, 02 Aug 2018 16:22:03 -0000

Hello all,

this discussion seems to be about dynamic subscriptions as "each 
application will selfishly create its own subscription". Configured 
subscriptions would benefit from a list of multiple receivers at the 
time of unboxing, I think. And that would be about resilient 
subscriptions or HA features in redundancy groups of receivers.

That said, wrt dynamic subscriptions, constrained-node environment YANG 
servers/datastores would benefit from minimizing the number of 
subscription state to be maintained. Also, the amount of potential 
useful sets of subscription characteristic is smaller with smaller 
things. Looking these up would be a valid alternative, I'd assume?

Viele Grüße,

Henk

On 08/02/2018 05:11 PM, Kent Watsen wrote:
> 
> I am sympathetic to Eric's and Einar's observation that a given subscription, having multiple receivers, is likely to have all the receivers using the same transport and encoding.
> 
> The thought behind this is that, assuming there are multiple distinct applications, each application will selfishly create its own subscription; it will not try to see if there is another existing subscription that matches its needs.
> 
> Thus, in effect, the *only* purpose for there being a *list* of receivers is for enabling high availability, which I think is okay.  I wish the text was clearer about this objective.
> 
> What I object to is the way that this restriction is currently implemented using identities, which requires the "notif" models to do something right.  Better would be a "must" expression that says the count of the descendants is exactly one.  Can you do that?
> 
> Kent // contributor
> 
> 
> ===== original message =====
> 
> I am wondering why we are reopening the issue of multiple encodings/transports per receiver vs per subscription?
> 
> Having single transport / encoding per subscription is a simpler design (feedback from implementors; simplifies dealing with any error conditions due to encoding that would affect one receiver but not others in the same subscription; Einar has explained this in the past) and, while I am in general a fan of general design, there does not seem to be business requirements and scenarios that demand this - and even if there were, this would constitute merely an optimization (since if you have different receivers who want different encodings/tranport, you can always simply create another subscription).
> 
> If in the future there is really desire to add this as an additional feature, we can put this into a -bis version.  (Adding stuff will be easier than taking things away.)  Let's just be done.
> 
> --- Alex
> 
>> -----Original Message-----
>> From: Netconf [mailto:netconf-bounces@ietf.org] On Behalf Of Martin
>> Bjorklund
>> Sent: Tuesday, July 31, 2018 7:51 AM
>> To: kwatsen@juniper.net
>> Cc: evoit=40cisco.com@dmarc.ietf.org; netconf@ietf.org
>> Subject: Re: [Netconf] YANG Doctor question: empty mandatory choice?
>>
>> Kent Watsen <kwatsen@juniper.net> wrote:
>>> [removing yang-doctors list, and updating subject line accordingly]
>>>
>>>
>>>>>> Why do all receivers of a subscription have to use the same
>> transport?
>>>>>
>>>>> This was something that Martin and Eric worked out before we did
>>>>> the first Last Call.  Eric doesn't seem to know the particular
>>>>> reason, other than Martin seems to think it’s easier.
>>>>
>>>> No; I personally also prefer a design where each receiver has its
>>>> own transport + encoding.
>>>
>>> +1
>>>
>>>
>>>> The original model had a common "encoding" for all receivers, and
>>>> then a receiver-specific transport - I think this is even worse,
>>>
>>> Agreed.
>>>
>>>
>>>> and suggested to have transport + encoding defined together
>>>> preferrably receiver-specifc or else common for all receivers.
>>>>
>>>> If the WG now believes that the transport + encoding should be done
>>>> per receiver, this should be fairly easy to change.
>>>
>>> I also prefer per receiver, and I think that doing so will simplify
>>> the model, as neither the mandatory "transport" nor the [not
>>> mandatory?] "encoding" leaves have to be specified.
>>>
>>> In particular, my thoughts are that the "notif" model should provide
>>> for the encoding selection, if needed (it's not needed for NETCONF, or
>>> COAP I imagine).
>>
>> I agree.  I think this would be a cleaner design.
>>
>>
>> /martin
>>
>>
>>>
>>> In the case of RESTCONF, we could update the ietf-restconf-client and
>>> ietf-restconf-server models to include an "encodings" leaf-list, to
>>> configure the RESTCONF server which encodings it should support.  We
>>> likely need to do something similar to configure which HTTP versions
>>> should be supported.  Now, in a general RC server, the server could
>>> support both but, if the restconf-notif draft has its own list of
>>> restconf-servers (i.e., it uses the "restconf-server-grouping" itself,
>>> see my July 19 email for a YANG example), then a constraint could be
>>> added limiting the number "supported" to just one.  Thus, when the RC
>>> server reboots, and connects to the receiver and *automatically* (no
>>> client RPC) starts pushing notifications, it can know what encoding to
>>> use.
>>>
>>> I'm still unsure if its legal for an RC server to automatically push
>>> notifications without a client-initiated RPC of any sort, and I'm also
>>> uncertain if supporting *configured* subscriptions for NC or RC is
>>> needed (see my message July 20 email).  So, some of this may work
>>> itself out as we progress.
>>>
>>> I know that we're not defining the *configured* notif drafts in this
>>> first effort, the we are publishing the SN draft with a configuration
>>> model, my only concern now is configuration model presented in the SN
>>> draft.
>>>
>>>
>>> Kent // contributor
>>>
>>>
>> _______________________________________________
>> Netconf mailing list
>> Netconf@ietf.org
>> https://urldefense.proofpoint.com/v2/url?u=https-3A__www.ietf.org_mailman_listinfo_netconf&d=DwIGaQ&c=HAkYuh63rsuhr6Scbfh0UjBXeMK-ndb3voDTXcWzoCI&r=9zkP0xnJUvZGJ9EPoOH7Yhqn2gsBYaGTvjISlaJdcZo&m=Mh0UuTFvh9TpmFzzMMON07C4WQIwjRJLM-OT62OJZe4&s=PPy3uCUVVJa-GwAfmUexA9cX31IWHhlMHlAGMcPdnyY&e=
> 
> 
> _______________________________________________
> Netconf mailing list
> Netconf@ietf.org
> https://www.ietf.org/mailman/listinfo/netconf
>