[alto] Piecewise review of draft-ietf-alto-path-vector-01 - Section 4 Overview

"Randriamasy, Sabine (Nokia - FR/Paris-Saclay)" <sabine.randriamasy@nokia-bell-labs.com> Wed, 13 December 2017 18:21 UTC

Return-Path: <sabine.randriamasy@nokia-bell-labs.com>
X-Original-To: alto@ietfa.amsl.com
Delivered-To: alto@ietfa.amsl.com
Received: from localhost (localhost [127.0.0.1]) by ietfa.amsl.com (Postfix) with ESMTP id 5BB6212704B for <alto@ietfa.amsl.com>; Wed, 13 Dec 2017 10:21:17 -0800 (PST)
X-Virus-Scanned: amavisd-new at amsl.com
X-Spam-Flag: NO
X-Spam-Score: -2.91
X-Spam-Level:
X-Spam-Status: No, score=-2.91 tagged_above=-999 required=5 tests=[BAYES_00=-1.9, DKIM_SIGNED=0.1, DKIM_VALID=-0.1, HTML_MESSAGE=0.001, RCVD_IN_DNSWL_NONE=-0.0001, RCVD_IN_MSPIKE_H5=-1, RCVD_IN_MSPIKE_WL=-0.01, SPF_PASS=-0.001] autolearn=ham autolearn_force=no
Authentication-Results: ietfa.amsl.com (amavisd-new); dkim=pass (1024-bit key) header.d=nokia.onmicrosoft.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 0L2eTQtcuCrT for <alto@ietfa.amsl.com>; Wed, 13 Dec 2017 10:21:13 -0800 (PST)
Received: from EUR03-AM5-obe.outbound.protection.outlook.com (mail-eopbgr30115.outbound.protection.outlook.com [40.107.3.115]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-SHA384 (256/256 bits)) (No client certificate requested) by ietfa.amsl.com (Postfix) with ESMTPS id 5093812714F for <alto@ietf.org>; Wed, 13 Dec 2017 10:21:13 -0800 (PST)
DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=nokia.onmicrosoft.com; s=selector2-nokia-onmicrosoft-com; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version; bh=CgpwSf3w0NHe7DBVnwWgKWNttUxxueRLkWlnpUnDYWM=; b=ayYqqubXPye8Om1jcPsHamCl1mt9eqwOrFnL9ZZOqZvgfRQMb/UiL+SZG/+k+ueznQ3aadNt4BC4FNDiWfR+MhXwXDH1p4cEvFmfbuYo/j56FpK6QSmwIu8v2IcY1A9xNsaTzZN4V98x0R4Q9aQItdKEdB+HO7FEqIecBKHbsTk=
Received: from DB6PR0701MB2454.eurprd07.prod.outlook.com (10.168.75.147) by DB6PR0701MB2456.eurprd07.prod.outlook.com (10.168.75.149) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA384_P256) id 15.20.323.4; Wed, 13 Dec 2017 18:21:10 +0000
Received: from DB6PR0701MB2454.eurprd07.prod.outlook.com ([fe80::5097:2f79:6a5c:dd86]) by DB6PR0701MB2454.eurprd07.prod.outlook.com ([fe80::5097:2f79:6a5c:dd86%17]) with mapi id 15.20.0323.011; Wed, 13 Dec 2017 18:21:11 +0000
From: "Randriamasy, Sabine (Nokia - FR/Paris-Saclay)" <sabine.randriamasy@nokia-bell-labs.com>
To: "alto@ietf.org" <alto@ietf.org>
Thread-Topic: Piecewise review of draft-ietf-alto-path-vector-01 - Section 4 Overview
Thread-Index: AdN0PqbWFCB2t7GRRqG7zMjdUsOMZw==
Date: Wed, 13 Dec 2017 18:21:10 +0000
Message-ID: <DB6PR0701MB2454716B7718F0FE86C2DA2D95350@DB6PR0701MB2454.eurprd07.prod.outlook.com>
Accept-Language: fr-FR, en-US
Content-Language: en-US
X-MS-Has-Attach:
X-MS-TNEF-Correlator:
x-originating-ip: [135.245.212.16]
x-ms-publictraffictype: Email
x-microsoft-exchange-diagnostics: 1; DB6PR0701MB2456; 6:brHTn1vuvYvRJ/XvAzbx/f1StufBTrbNpgoBZhbHIlUw0uIZ0MsWEhGX9pt7F3rJ+Y5z2YCdxA73CJ+EUO/3swYyua35dQwd47DejP5CDNyay9/8umEYvT8VU9snhB+gmDzC5sTNYn/8XozNza6n5jrECaOGyhvQpL9368bulvLxCUjLOCAQl6qe0sDBIDpRr5VPIW4dmfh/X3k0NfXCYHRDSPd3SLptHB6F3G3SQuVHwacMfYcLAuCbjwYHJOaXC6FH4zvZTuBMNT17Us+1ncNWBtqzdUhrNr6fjfsAavaNzj3O7MQZ9PV9HOGJGF87YxsguEyIjWlFL/wq5Cz31pYUdm3t3JfHwVbHeuRc2d8=; 5:cd+qWYNGcRo6Uvi+jbOLSTlA1RLnqFAQj0OPQ9FHb86/vIiBuJVjrgNpPg4XT9xWA30xyQUumX/mo3sA+zUHFqj0xTUEzT6vidGN8ev2ZqWJsTZk67QcPs4N4LMdMP1EXViNN27cahfE+L/O5YtiiVBfYEr8p+No8rMEwwtBnfQ=; 24:ca94EQK9q/MueQFcP7YKlHB+NSECSZHpNeFLLsqK5SMDSzQGpTMF89HibrWs+x2Zgwvuv6GkD+Kw1LVFv671Jw2rfVw+VHd9eXQkwLTUkA8=; 7:3RWXrBjUBBGb0DFH4F1ZeE4FofJnAhTXJgmlyy4fCGQtQCXtWgjIe+XrDul3skumNaWa3N/0DhGBct+1M+GgpDFiXieJfKKOkajQ8NtIr9T8I+x0WbjJEMVx3jWIxBISLPSEdtE2KBjyX+y5GqNf+WDcTlWDy4Ot6bajEMMwTaJ7eaBZwI5aZ6PrW92f8tq8YD4ABRHFiUSqlv+kkKwNiHMokd1/kS0O4pwgn6l/u9i7X4F1Bnm/EI4f8Y3qDdid
x-ms-exchange-antispam-srfa-diagnostics: SSOS;
x-ms-office365-filtering-correlation-id: 15ee9a47-da10-4302-7645-08d54256497f
x-ms-office365-filtering-ht: Tenant
x-microsoft-antispam: UriScan:; BCL:0; PCL:0; RULEID:(5600026)(4604075)(4534020)(4602075)(4627115)(201703031133081)(201702281549075)(48565401081)(2017052603307); SRVR:DB6PR0701MB2456;
x-ms-traffictypediagnostic: DB6PR0701MB2456:
authentication-results: spf=none (sender IP is ) smtp.mailfrom=sabine.randriamasy@nokia-bell-labs.com;
x-microsoft-antispam-prvs: <DB6PR0701MB2456DBD3675FCDBA566A7D3995350@DB6PR0701MB2456.eurprd07.prod.outlook.com>
x-exchange-antispam-report-test: UriScan:(158342451672863)(278428928389397)(131327999870524)(788757137089)(21748063052155);
x-exchange-antispam-report-cfa-test: BCL:0; PCL:0; RULEID:(6040450)(2401047)(8121501046)(5005006)(93006095)(93001095)(3002001)(3231023)(11241501184)(10201501046)(6055026)(6041248)(20161123564025)(20161123560025)(20161123555025)(20161123558100)(201703131423075)(201702281528075)(201703061421075)(201703061406153)(20161123562025)(6072148)(201708071742011); SRVR:DB6PR0701MB2456; BCL:0; PCL:0; RULEID:(100000803101)(100110400095); SRVR:DB6PR0701MB2456;
x-forefront-prvs: 052017CAF1
x-forefront-antispam-report: SFV:NSPM; SFS:(10019020)(376002)(39860400002)(346002)(366004)(189003)(199004)(54896002)(1730700003)(6306002)(59450400001)(478600001)(5640700003)(6436002)(6116002)(81156014)(68736007)(66066001)(33656002)(102836003)(5630700001)(99286004)(3846002)(790700001)(81166006)(6506007)(55016002)(5250100002)(14454004)(8676002)(9686003)(7736002)(74316002)(2900100001)(86362001)(8936002)(316002)(97736004)(2501003)(5660300001)(230783001)(2906002)(25786009)(2351001)(6916009)(105586002)(561944003)(106356001)(7696005)(53936002)(3280700002)(3660700001)(90052001); DIR:OUT; SFP:1102; SCL:1; SRVR:DB6PR0701MB2456; H:DB6PR0701MB2454.eurprd07.prod.outlook.com; FPR:; SPF:None; PTR:InfoNoRecords; MX:1; A:0; LANG:en;
received-spf: None (protection.outlook.com: nokia-bell-labs.com does not designate permitted sender hosts)
spamdiagnosticoutput: 1:99
spamdiagnosticmetadata: NSPM
Content-Type: multipart/alternative; boundary="_000_DB6PR0701MB2454716B7718F0FE86C2DA2D95350DB6PR0701MB2454_"
MIME-Version: 1.0
X-OriginatorOrg: nokia-bell-labs.com
X-MS-Exchange-CrossTenant-Network-Message-Id: 15ee9a47-da10-4302-7645-08d54256497f
X-MS-Exchange-CrossTenant-originalarrivaltime: 13 Dec 2017 18:21:10.7535 (UTC)
X-MS-Exchange-CrossTenant-fromentityheader: Hosted
X-MS-Exchange-CrossTenant-id: 5d471751-9675-428d-917b-70f44f9630b0
X-MS-Exchange-Transport-CrossTenantHeadersStamped: DB6PR0701MB2456
Archived-At: <https://mailarchive.ietf.org/arch/msg/alto/GGroJgfL5XGuH1ydWOLmISCPMKY>
Subject: [alto] Piecewise review of draft-ietf-alto-path-vector-01 - Section 4 Overview
X-BeenThere: alto@ietf.org
X-Mailman-Version: 2.1.22
Precedence: list
List-Id: "Application-Layer Traffic Optimization \(alto\) WG mailing list" <alto.ietf.org>
List-Unsubscribe: <https://www.ietf.org/mailman/options/alto>, <mailto:alto-request@ietf.org?subject=unsubscribe>
List-Archive: <https://mailarchive.ietf.org/arch/browse/alto/>
List-Post: <mailto:alto@ietf.org>
List-Help: <mailto:alto-request@ietf.org?subject=help>
List-Subscribe: <https://www.ietf.org/mailman/listinfo/alto>, <mailto:alto-request@ietf.org?subject=subscribe>
X-List-Received-Date: Wed, 13 Dec 2017 18:21:17 -0000

Hello authors of PV extension and all,

Please find below my review of draft-ietf-alto-path-vector-01, covering section 4.
There is a "digest" part including some points subject to WG discussion on top of this long e-mail, before the detailed comments.

For the caption, in sentences: "... bla bla  ...", text between "++ ++", "-- --" means respectively ++added text++ and --deleted text--

Thanks,
Sabine

========================================================
General comments on the document/digest - section 4
========================================================

- 4.2. Cost Type Extension ( ==> proposed 4.1.3 "Path Vector Cost Type attributes")
Table 1: how should the reader understand this? This table should reflect that "hopcount" and "routingcost" may both in either numerical or ordinal mode where as "ane-path" is only in "array" mode.

- (proposed new section) 4.2 Applicable ALTO Services for Path Vector Costs:
- Cost Map should not be applicable, as a base protocol client will not understand a PV Cost Map obtained via a GET request.

- 4.4 needs a couple of sentences to elaborate on RFC2387 and the consistency with the base protocol
Instead of a last paragraph on backwards compatibility: a subsection is needed on "Impact of backwards compatibility on the PV design" and another subsection on "Requirements for PV on Clients and Servers"

- keywords covered by RFC2119 such as MUST etc. must be used carefully.

References:
- [I-D.ietf-alto-multi-cost] should be replaced by [RFC8189].
- [I-D.roome-alto-unified-props] should be replaced by: [I-D.ietf-alto-unified-props-new]

========================================================
DETAILED COMMENTS - section 4
========================================================

----------------
4. Overview
----------------

Title can be expanded to: "Overview of path-vector extensions".

This section is key and needs substantial expansion and many new notions are introduced there. In particular a sub-section with additonal non-normative text defining:
- the new cost metric "ane-path" and the type of values that are exposed, with format and example.
- the property map optionally associated, with format and example.
Additional sub-sections are suggested here, to be completed/updated as needed.

Sentence 2: It is unlikely that readers are familiar with [draft-ietf-alto-unified-props-new]. So I propose re-phrasing as follows:
"It assumes the readers are familiar with (Filtered) Cost Map and Endpoint Cost Service defined in [RFC7285] and their multi-cost extensions defined in [RFC8189]. ++It also uses features such as++  Filtered Property Map defined in [I-D.ietf-alto-unified-props-new]."
----------------
4.1. Path Vector
----------------

- Title can be expanded to: "The Path Vector Cost Type extensions"

--- Para 1
- Sentence 1: re-phrasing and expansion proposal: "A path vector is an array of so-called ALTO Abstract Network Elements (ANEs) ++and++ represents an abstract network path between entities such as PIDs or endpoints. ++ An ANE represents a selected part of an end to end path that the ALTO Server considers worth exposing. An ANE is a set of one or more network elements such as links, switches or other equipment. it is expected to have properties that may influence the applications e.g. when they select an endpoint or want to estimate their performance.++"

- Sentence 2: "Each abstract network element has two attributes: "name" and "properties" (added quotations)++, where "name" can be for example ... and "properties" can be ... ++."

- Sentence 3: "The abstract network... and the abstract... in ++ separate ++ abstract network element property maps."


----------------
(proposed new section) 4.1.1 New Cost Metric and Values for Path Vector
----------------
To represent an abstracted network path, this document introduces a new cost metric named "ane-path". A cost value in this metric is an array containing the names of the ALTO ANEs that the ALTO Server has specified as describing the network path elements. The ANE names array is organized as a sequence beginning at the source of the path and ending at its destination.

Each ANE name of the "ane-path" array is encoded as a string that identifies the ANE.

----------------
(proposed new section)4.1.3 New Cost Mode for Path Vector
----------------

A cost mode as defined in Section 6.1.2 of [RFC7285], a cost mode is either "numerical" or "ordinal" and none of these can be used to present a list of ANE names. Therefore, this document specifies a new cost mode named "array" for the cost metric "ane-path". The new cost mode "array" means each cost value in the cost maps is a list.

----------------
4.2. Cost Type Extension ==> 4.1.3 "Path Vector Cost Type attributes"
----------------
- skip 2 first paragraphs, already in sections 4.1.1 and 4.1.2

- then:
The attributes of the Path vector cost type are thus as follows:
- Cost metric: "ane-path"
- Cost Mode: "array"
- Semantics: an array of strings representing the sequence of ANEs in a network path, where each string is the name of an ANE.
***** Table 1: how should the reader understand this? This table should reflect that "hopcount" and "routingcost" may both in either numerical or ordinal mode where as "ane-path" is only in "array" mode.

----------------
(proposed new section) 4.2 Applicable ALTO Services for Path Vector Costs
----------------
List here what existing ALTO Services can be used to convey PV costs and related restrictions/conditions that will be detailed in next sections.

***** - Cost Map should not be applicable as a base protocol client will not understand a PV Cost Map obtained via a GET request.
- Filtered Cost Maps
- Endpoint Cost

----------------
4.3. Extended optional property service: ANE Property Map
----------------
- sentence 1: "Given that Cost Map ... there exist bottlenecks ++ shared by ++ different flows."

- sentence 2: ***** not all Clients want to have the ANE properties. Suggestion: "However, ++some++ ALTO clients ++ may want to have++ information on specific ++ANE properties such as++ link capacity ++or delay++."

- sentence 3: "This document adopts the property map resources defined in -- -- [I-D.ietf-alto-unified-props-new] to encode the properties of ++ANEs++."

- sentence 4: Suggestion: "Draft [I-D.ietf-alto-unified-props-new] defines a new entity domain called "ane" and each entity in the "ane" domain has an identifier of an ANE. ANE properties are provided in information resources called "Property Map Resource" and "Filtered Property Map Resource".
- sentence 5: suggestion: An ANE identifier is the ANE name used in the values of the "ane-path" metric defined in the present draft".

- sentence 6: "++In the present draft,++ the property map which supports "ane" domain is ++called++ ANE Property Map."

----------------
4.4. ++RFC 2387++ media-type for path-vector: multipart/related
----------------

Instead of a last paragraph on backwards compatibility: a subsection is needed on "Impact of backwards compatibility on the PV design" and another subsection on "Requirements for PV on Clients and Servers"

--- Para 2:
- sentence 1: replace MUST by "needs to".
- sentence 2:"This ++may cause a++ data synchronization problem"

--- Para 3:
- sentence 1: typo: documents ==> document
- sentence 2: ***** Cost Map ==> ++Filtered++ Cost Map ? Thus, a response can contain both the
path vector as a ++Filtered ? ++ Cost Map (or Endpoint Cost Map) and the ++ associated ++ -- -- ++ANE++ Property Map.
- sentence 3: ***** can you clarify on the consistency with the base protocol.