Re: [Netconf] Confirmed commit

Jonathan Hansford <Jonathan@hansfords.net> Fri, 20 September 2013 10:29 UTC

Return-Path: <jonathan@hansfords.net>
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 8CCC921F90FD for <netconf@ietfa.amsl.com>; Fri, 20 Sep 2013 03:29:41 -0700 (PDT)
X-Virus-Scanned: amavisd-new at amsl.com
X-Spam-Flag: NO
X-Spam-Score: -2.948
X-Spam-Level:
X-Spam-Status: No, score=-2.948 tagged_above=-999 required=5 tests=[AWL=0.650, BAYES_00=-2.599, HTML_MESSAGE=0.001, RCVD_IN_DNSWL_LOW=-1]
Received: from mail.ietf.org ([12.22.58.30]) by localhost (ietfa.amsl.com [127.0.0.1]) (amavisd-new, port 10024) with ESMTP id aAkYsws5e41S for <netconf@ietfa.amsl.com>; Fri, 20 Sep 2013 03:29:35 -0700 (PDT)
Received: from avasout04.plus.net (avasout04.plus.net [212.159.14.19]) by ietfa.amsl.com (Postfix) with ESMTP id AC82D21F9193 for <netconf@ietf.org>; Fri, 20 Sep 2013 03:29:33 -0700 (PDT)
Received: from webmail.plus.net ([84.93.237.98]) by avasout04 with smtp id TNVX1m004283uBY01NVYD4; Fri, 20 Sep 2013 11:29:32 +0100
X-CM-Score: 0.00
X-CNFS-Analysis: v=2.1 cv=MqNrtQqe c=1 sm=1 tr=0 a=BJaFPv9AyABFDM2hXLRoEA==:117 a=MEK23cO9Z3nTrtfM1ievvA==:17 a=0Bzu9jTXAAAA:8 a=lxldWUwtbAkA:10 a=dYCPD3cKDi0A:10 a=0B8HqoTn75oA:10 a=6bkCdLdQAAAA:8 a=f0uUZFObAAAA:8 a=urOY2GcFnqMA:10 a=SUE4xeBjAAAA:8 a=xskcdSivAAAA:8 a=48vgC7mUAAAA:8 a=rPp2i0zUz4JSECK8f_wA:9 a=QEXdDO2ut3YA:10 a=jFPUFpGHtmAA:10 a=ChEcuLpljosA:10 a=1rgnPY4EEFsA:10 a=lZB815dzVvQA:10 a=F_-xGfPuGH-TOJ81glQA:9 a=9kjqu_gVvwLbRaF8:21 a=_W_S_7VecoQA:10
X-AUTH: hansfords+us:2500
Received: from host-212-159-134-100.static.as13285.net ([212.159.134.100]) by webmail.plus.net with HTTP (HTTP/1.1 POST); Fri, 20 Sep 2013 11:29:31 +0100
MIME-Version: 1.0
Content-Type: multipart/alternative; boundary="=_24c5105c5f1ce0acd1a8e40ec92f820f"
Date: Fri, 20 Sep 2013 11:29:31 +0100
From: Jonathan Hansford <Jonathan@hansfords.net>
To: "Bert Wijnen (IETF)" <bertietf@bwijnen.net>
Message-ID: <c0df6f9383b5810f604aec2a2f381bae@imap.plus.net>
X-Sender: Jonathan@hansfords.net
User-Agent: Roundcube Webmail/0.7.4
X-Originating-IP: [212.159.134.100]
Cc: Netconf <netconf@ietf.org>
Subject: Re: [Netconf] Confirmed commit
X-BeenThere: netconf@ietf.org
X-Mailman-Version: 2.1.12
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: <http://www.ietf.org/mail-archive/web/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: Fri, 20 Sep 2013 10:29:41 -0000

 

I propose the following changes to address Andy's issue relating to
consecutive confirmed commits and my issue relating to the confusing
terminology: 

8.4.1. Description (paras 2-6)
A <commit> operation with
the <confirmed> parameter (an unconfirmed <commit>) MUST be reverted if
a confirming commit is not issued within the timeout period (by default
600 seconds = 10 minutes). The confirming commit is a <commit> operation
without the <confirmed> parameter and, if successful, cannot be
reverted. The timeout period can be adjusted with the <confirm-timeout>
parameter. If a follow-up unconfirmed <commit> operation is issued
before the timer expires, the timer is reset to the new value (600
seconds by default). Both the confirming commit and a follow-up
unconfirmed <commit> operation MAY introduce additional changes to the
configuration.
If the <persist> element is not given in the unconfirmed
commit operation, any follow-up commit and the confirming commit MUST be
issued on the same session that issued the unconfirmed commit. If the
<persist> element is given in the unconfirmed <commit> operation, a
follow-up commit and the confirming commit can be given on any session,
and they MUST include a <persist-id> element with a value equal to the
given value of the <persist> element.
If the server also advertises the
:startup capability, a <copy-config> from running to startup is also
necessary to save the changes to startup. If the session issuing a
sequence of one or more unconfirmed commits is terminated for any reason
before the confirm timeout expires, the server MUST restore the
configuration to its state before the sequence of unconfirmed commits
was issued, unless the last unconfirmed commit also included a <persist>
element.
If the device reboots for any reason before the confirm timeout
expires, the server MUST restore the configuration to its state before
the sequence of unconfirmed commits was issued.
If a confirming commit
is not issued, the device will revert its configuration to the state
prior to the issuance of the first in the current sequence of
unconfirmed commits. To cancel the current sequence of unconfirmed
commits and revert changes without waiting for the confirm timeout to
expire, the client can explicitly restore the configuration to its state
before the sequence of unconfirmed commits was issued, by using the
<cancel-commit> operation.
:
8.4.4.1.
<cancel-commit>
Description:
Cancels an ongoing sequence of unconfirmed
commits. If the <persist-id> parameter is not given, the <cancel-commit>
operation MUST be issued on the same session that issued the sequence of
unconfirmed commits.
Parameters:
persist-id:
Cancels a persistent
sequence of unconfirmed commits. The value MUST be equal to the value
given in the <persist> parameter to the <commit> operation. If the value
does not match, the operation fails with an "invalid-value"
error.
:
8.4.5.1. <commit>
The :confirmed-commit:1.1 capability allows 4
additional parameters to the <commit>
operation.
Parameters:
confirmed:
Perform an unconfirmed <commit>
operation.
confirm-timeout:
Timeout period for confirmed commit, in
seconds. If unspecified, the confirm timeout defaults to 600
seconds.
persist:
Make the unconfirmed commit survive a session
termination, and set a token on the ongoing sequence of unconfirmed
commits.
persist-id:
Used to issue a follow-up unconfirmed commit or a
confirming commit from any session, with the token from the previous
<commit> operation.

On 2013-09-20 11:08, Bert Wijnen (IETF) wrote: 

>
THat is one (and probably good) approach.
> 
> So can the
authors/experts suggest some text that makes
> sense as a fix (or better
clarification) to a possible
> erratum?
> 
> Bert
> 
> On 9/20/13 10:00
AM, Jonathan Hansford wrote:
> 
>> Would it be worth agreeing text
online then raising an erratum? Sent from my BlackBerry -----Original
Message----- From: "Bert Wijnen (IETF)" <bertietf@bwijnen.net [1]> Date:
Fri, 20 Sep 2013 08:41:42 To: Andy Bierman<andy@yumaworks.com [2]>;
Jonathan Hansford<Jonathan@hansfords.net [3]>; Netconf<netconf@ietf.org
[4]> Subject: Re: [Netconf] Confirmed commit See at bottom On 9/20/13
7:13 AM, Juergen Schoenwaelder wrote: 
>> 
>>> On Thu, Sep 19, 2013 at
01:39:28PM -0700, Andy Bierman wrote: 
>>> 
>>>> Hi, I always found
section 8.4.1, para 2 confusing. T0: /int8.1 does not exist 
>>>> 
>>>>>
merge /int8.1 value=20 commit confirmed confirm-timeout=60
>>>> T1:
/int8.1 = 20 merge /int8.1 value=30 commit confirmed confirm-timeout=60
T2: /int8.1 = 30 T3: timeout occurs: para 6 says: If a confirming commit
is not issued, the device will revert its configuration to the state
prior to the issuance of the confirmed commit. The problem is that there
are 2 confirmed commit operations. At time T3 does the server go back to
state T1 or T0? (Our server goes back to T0). The 2nd commit contains a
confirmed parameter, and para 2 sentence 2 clearly says this is not a
confirming commit. The text does not actually define a "confirmed
commit", but I assume it is a commit with a confirmed parameter.
Therefore, paragraphs 5 - 7 are wrong where they refer to "the confirmed
commit", because there are 2 of them.
>>> Yes, this corner case where
multiple confirmed commits are issued is not described well. Your
interpretation that subsequent confirmed commits effectively extend the
first one makes sense to me.
>> Can wee keep this somewhere so we
clarify it if we ever have to open up and update the document? Bert 
>>

>>> /js
 

Links:
------
[1] mailto:bertietf@bwijnen.net
[2]
mailto:andy@yumaworks.com
[3] mailto:Jonathan@hansfords.net
[4]
mailto:netconf@ietf.org