Re: Gen-ART Last Call review of draft-ietf-rserpool-asap-19.txt

Michael Tüxen <Michael.Tuexen@lurchi.franken.de> Fri, 30 May 2008 00:00 UTC

Return-Path: <ietf-bounces@ietf.org>
X-Original-To: ietf-archive@megatron.ietf.org
Delivered-To: ietfarch-ietf-archive@core3.amsl.com
Received: from [127.0.0.1] (localhost [127.0.0.1]) by core3.amsl.com (Postfix) with ESMTP id 0A47828C148; Thu, 29 May 2008 17:00:16 -0700 (PDT)
X-Original-To: ietf@core3.amsl.com
Delivered-To: ietf@core3.amsl.com
Received: from localhost (localhost [127.0.0.1]) by core3.amsl.com (Postfix) with ESMTP id 5F55928C148; Thu, 29 May 2008 17:00:14 -0700 (PDT)
X-Virus-Scanned: amavisd-new at amsl.com
X-Spam-Flag: NO
X-Spam-Score: 2.038
X-Spam-Level: **
X-Spam-Status: No, score=2.038 tagged_above=-999 required=5 tests=[BAYES_00=-2.599, HOST_EQ_DIP_TDIAL=2.144, HOST_MISMATCH_NET=0.311, MIME_8BIT_HEADER=0.3, RCVD_IN_PBL=0.905, RCVD_IN_SORBS_DUL=0.877, RDNS_DYNAMIC=0.1]
Received: from mail.ietf.org ([64.170.98.32]) by localhost (core3.amsl.com [127.0.0.1]) (amavisd-new, port 10024) with ESMTP id TuaO2U9bEYgZ; Thu, 29 May 2008 17:00:13 -0700 (PDT)
Received: from mail-n.franken.de (drew.ipv6.franken.de [IPv6:2001:638:a02:a001:20e:cff:fe4a:feaa]) by core3.amsl.com (Postfix) with ESMTP id 993033A6BB8; Thu, 29 May 2008 16:59:53 -0700 (PDT)
Received: from [192.168.1.199] (p508FF6F1.dip.t-dialin.net [80.143.246.241]) by mail-n.franken.de (Postfix) with ESMTP id 9FE171C0C0BDB; Fri, 30 May 2008 01:59:50 +0200 (CEST)
From: Michael Tüxen <Michael.Tuexen@lurchi.franken.de>
To: Spencer Dawkins <spencer@wonderhamster.org>
In-Reply-To: <04a201c8a014$64519f40$ad600240@china.huawei.com>
Subject: Re: Gen-ART Last Call review of draft-ietf-rserpool-asap-19.txt
X-Priority: 3
References: <04a201c8a014$64519f40$ad600240@china.huawei.com>
Message-Id: <97079B52-8033-45F4-90EA-7BE602334B29@lurchi.franken.de>
Mime-Version: 1.0 (Apple Message framework v924)
Date: Fri, 30 May 2008 01:59:50 +0200
X-Mailer: Apple Mail (2.924)
Cc: rserpool-chairs@tools.ietf.org, ietf@ietf.org, General Area Review Team <gen-art@ietf.org>, Randall Stewart <rrs@lakerest.net>, Maureen.Stillman@nokia.com, Qiaobing Xie <qiaobing.xie@gmail.com>
X-BeenThere: ietf@ietf.org
X-Mailman-Version: 2.1.9
Precedence: list
List-Id: IETF Discussion <ietf.ietf.org>
List-Unsubscribe: <https://www.ietf.org/mailman/listinfo/ietf>, <mailto:ietf-request@ietf.org?subject=unsubscribe>
List-Archive: <http://www.ietf.org/pipermail/ietf>
List-Post: <mailto:ietf@ietf.org>
List-Help: <mailto:ietf-request@ietf.org?subject=help>
List-Subscribe: <https://www.ietf.org/mailman/listinfo/ietf>, <mailto:ietf-request@ietf.org?subject=subscribe>
Content-Type: text/plain; charset="us-ascii"
Content-Transfer-Encoding: 7bit
Sender: ietf-bounces@ietf.org
Errors-To: ietf-bounces@ietf.org

Hi Spencer,

see my comments in-line.

Best regards
Michael

On Apr 17, 2008, at 12:51 AM, Spencer Dawkins wrote:

> I have been selected as the General Area Review Team (Gen-ART)
> reviewer for this draft (for background on Gen-ART, please see
> http://www.alvestrand.no/ietf/gen/art/gen-art-FAQ.html).
>
> Please resolve these comments along with any other Last Call comments
> you may receive.
>
> Document: draft-ietf-rserpool-asap-19
> Reviewer: Spencer Dawkins
> Review Date: 2008-04-16
> IETF LC End Date: 2008-04-14 (sorry!)
> IESG Telechat date:
>
> Summary: This document is close to ready for publication as an  
> Experimental RFC. I have some specific comments below, but nothing  
> that's a show-stopper.
>
> If this document were to advance onto the standards track, I'd  
> recommend a very tight editing pass on 2119 language, especially  
> looking for anything that seems to be capitalized for emphasis, and  
> I'd recommend clearer statements for why some of the SHOULDs aren't  
> MUSTs. I don't see any reason to hold up for this when publishing as  
> Experimental.
>
> Comments:
>
> 1.1.  Definitions
>
>  Home ENRP server:  The ENRP server to which a PE or PU currently
>     sends all namespace service requests.  A PE MUST only have one
>
> Spencer (clarity): I'm not wild about 2119 language in terminology  
> sections, but at the very least, this section comes before you  
> describe the 2119 conventions in Section 1.4...
>
>     home ENRP server at any given time and both the PE and its home
>     ENRP server MUST know and keep track of this relationship.  A PU
>     SHOULD select one of the available ENRP servers as its Home ENRP
>     server but the collective ENRP servers may change this by the
>     sending or a ASAP_ENDPOINT_KEEP_ALIVE message.
Agreed. I changed it from SHOULD or MUST to should or must.
>
>
> 1.2.  Organization of this document
>
>  Section 2 details the ASAP message formats.  In Section 3 we provide
>  detailed ASAP procedures for for the ASAP implementer.  In Section 6
>
> Spencer (clarity): interesting jump from Sec 3 to Sec 6... ;-)
>
>  we give details of the ASAP interface, focusing on the communication
>  primitives between ASAP the applications above ASAP and ASAP itself,
>  and the communications primitives between ASAP and SCTP (or other
>  transport layers).  Also included in this discussion are relevant
>  timers and configurable parameters as appropriate.  Section 7
>  provides threshold and protocol variables.
I added appropriate text for section 4 and 5 (which were added lately)
and also cleaned up the text for section 7.
>
>
> 2.2.  ASAP Messages
>
>  0x0d       - ASAP_BUSINESS_CARD
>
> Spencer (clarity): it would be nice to see "business card" called  
> out in the terminology section, at a minimum.
I added a description to the terminology section.
>
>
> 3.5.  Unreachable endpoints
>
>  Optionally, an ENRP server may also periodically send point-to-point
>  ASAP_ENDPOINT_KEEP_ALIVE (with 'H' flag set to '0') messages to each
>  of the PEs owned by the ENRP server in order to check their
>  reachability status.  If the send of ASAP_ENDPOINT_KEEP_ALIVE to a PE
>  fails, the ENRP server MUST consider the PE as unreachable and MUST
>  remove the PE from its handlespace .  Note, if an ENRP server owns a
>  large number of PEs, the implementation should pay attention not to
>  flood the network with bursts of ASAP_ENDPOINT_KEEP_ALIVE messages.
>  Instead, the implementation MUST distribute the
>  ASAP_ENDPOINT_KEEP_ALIVE message traffic over a time period.
>
> Spencer (comment): Is this a requirement for application-level  
> behavior beyond what TCP or SCTP would do at the transport level? If  
> so ... I'd expect more guidance here (if everyone knew how to "pay  
> attention not to flood the network with bursts of messages", we'd  
> all be using UDP).
SCTP or TCP do congestion control per association or connection. Here  
the messages
are sent on multiple associations.
I've added a note that the time between ASAP_ENDPOINT_KEEP_ALIVE  
messages should
randomly varied by plus/minus 50 percent. This should work (At least  
this is
the way we handle the same situation in SCTP).
>
>
> 3.7.1.  SCTP Send Failure
>
>  In such a case, the ASAP endpoint should not re-send the
>  undeliverable message.  Instead, it should discard the message and
>  start the ENRP server hunt procedure as described in Section 3.6 .
>
> Spencer (comment): I'm not sure why these "should"s are non- 
> normative, and I'm not sure why the first "should" is not MUST.
Changed to MUST and SHOULD.
>
>
>  After finding a new Home ENRP server, the ASAP endpoint should
>  reconstruct and retransmit the request.
>
>  Note that an ASAP endpoint MAY also choose to NOT discard the
>  message, but to queue it for retransmission after a new Home ENRP
>  server is found.  If an ASAP endpoint does choose to discard the
>  message, after a new Home ENRP server is found, the ASAP endpoint
>  MUST be capable of reconstructing the original request.
>
> Spencer (comment): this seems way deep into implementation, not into  
> protocol interoperation (whether I discard a message and reconstruct  
> it, or queue it for retransmission, would be up to the implementer,  
> or do I misunderstand?).
Correct.

I have replaced it by

In such a case, the ASAP endpoint MUST not re-send the undeliverable
message. Instead, it SHOULD discard the message and start the
ENRP server hunt procedure as described in <xref  
target="servhuntproc" /> .
After finding a new Home ENRP server, the ASAP endpoint should
re-send the request.

>
>
> 3.8.  Cookie handling procedures
>
>  Note: a control channel is a communication channel between a PU and
>  PE that does not end in data passed to the user.  This is
>
> Spencer (clarity): s/does not end in/does not carry/ ?
Done.
>
>
>  accomplished with SCTP by using a PPID to separate the ASAP messages
>  (Cookie and Business Card) from normal data messages.
>
> 6.5.2.1.  Round Robin Policy
>
>  When an ASAP endpoint sends messages by Pool Handle and Round-Robin
>  is the current policy of that Pool, the ASAP endpoint of the sender
>  will select the receiver for each outbound message by round-Robining
>  through all the registered PEs in that Pool, in an attempt to achieve
>  an even distribution of outbound messages.  Note that in a large
>  server pool, the ENRP server MAY not send back all PEs to the ASAP
>
> Spencer (comment): is this supposed to be a 2119 MAY? Or is it more  
> like "might not"?
Changed to might not
>
>
>  client.  In this case the client or PU will be performing a round
>  robin policy on a subset of the entire Pool.
>
> 6.5.5.  Message Delivery Options
>
>     Note that this is a best-effort service.  Applications should be
>     aware that messages can be lost during the failover process, even
>     if the underlying transport supports retrieval of unacknowledged
>     data (e.g.  SCTP) (Example: messages acknowledged by the SCTP
>     layer at a PE, but not yet read by the PE when a PE failure
>     occurs.)  In the case where the underlying transport does not
>     support such retrieval (e.g.  TCP), any data already submitted by
>     ASAP to the transport layer MAY be lost upon failover.
>
> Spencer: ... I'm positive this isn't a 2119 MAY ;-)
Correct.

Thank you very much for your comments!

I've submitted a new version of the ID addressing all your comments
as described above.
>
>
>

_______________________________________________
IETF mailing list
IETF@ietf.org
https://www.ietf.org/mailman/listinfo/ietf