[alto] ALTO Extension: A document defining multi-metrics filtering?

"Y. Richard Yang" <yry@cs.yale.edu> Fri, 18 October 2013 06:14 UTC

Return-Path: <yang.r.yang@gmail.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 EE01421F9F51 for <alto@ietfa.amsl.com>; Thu, 17 Oct 2013 23:14:24 -0700 (PDT)
X-Virus-Scanned: amavisd-new at amsl.com
X-Spam-Flag: NO
X-Spam-Score: -1.451
X-Spam-Level:
X-Spam-Status: No, score=-1.451 tagged_above=-999 required=5 tests=[AWL=-0.074, BAYES_00=-2.599, FM_FORGED_GMAIL=0.622, HTML_MESSAGE=0.001, J_CHICKENPOX_55=0.6, NO_RELAYS=-0.001]
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 V9xtOY0mqj6c for <alto@ietfa.amsl.com>; Thu, 17 Oct 2013 23:14:23 -0700 (PDT)
Received: from mail-pb0-x232.google.com (mail-pb0-x232.google.com [IPv6:2607:f8b0:400e:c01::232]) by ietfa.amsl.com (Postfix) with ESMTP id C191221F9F2D for <alto@ietf.org>; Thu, 17 Oct 2013 23:14:21 -0700 (PDT)
Received: by mail-pb0-f50.google.com with SMTP id uo15so1978579pbc.9 for <alto@ietf.org>; Thu, 17 Oct 2013 23:14:21 -0700 (PDT)
DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20120113; h=mime-version:sender:in-reply-to:references:date:message-id:subject :from:to:cc:content-type; bh=kf+hYoHU+thoW2+BUAjPEzFepyEAKGQtGKMWIkenW7A=; b=cr/rNZoAvj1P23fL8YUIgvs/mz6zJvDw0AVktudiS9tYMqTkZ6f+ouy/XUYspqAzhR Sb3oReZB1I71NTq3jnZ6y8k490Oo2iDhiob8XZR2AmZULFuZQXq2snp9vLe04DurO11m YYAu1cIznF0n1TCIc0APjWtbVsP0KNJouAzt1QbkoIy/pyRidkolZ/ozEK447wYPTZz1 K1PcyhJWzPSbdRX6HlcZYfHiUNX0wPRzho1xv/T+mAWAxXwc7IDOZVHmD92O5pcf2RPM QOf0TTPuiulPhxQKXASW+R1svzypaIaNIMpud0wfWx0pdBsiRPPk2auNaMbtuc/1mZ6l dPsg==
MIME-Version: 1.0
X-Received: by 10.68.252.68 with SMTP id zq4mr1402205pbc.154.1382076861373; Thu, 17 Oct 2013 23:14:21 -0700 (PDT)
Sender: yang.r.yang@gmail.com
Received: by 10.68.47.195 with HTTP; Thu, 17 Oct 2013 23:14:21 -0700 (PDT)
In-Reply-To: <A7A5844EB93EB94AB22C2068B10AD65A294423FE@FR711WXCHMBA01.zeu.alcatel-lucent.com>
References: <CANUuoLrYSOykB6YyvNSj2Zvrw-ZQiJoFFBoMCXLzkpgW37T1HA@mail.gmail.com> <A7A5844EB93EB94AB22C2068B10AD65A294423FE@FR711WXCHMBA01.zeu.alcatel-lucent.com>
Date: Fri, 18 Oct 2013 02:14:21 -0400
X-Google-Sender-Auth: 7xixJt2e4AxZHlujOm0UGjXFCyM
Message-ID: <CANUuoLpApXcMUdeVOhdqNCUeNCEoU-2SeuKyj6Ayb4FSvQ8ytw@mail.gmail.com>
From: "Y. Richard Yang" <yry@cs.yale.edu>
To: "RANDRIAMASY, SABINE (SABINE)" <sabine.randriamasy@alcatel-lucent.com>
Content-Type: multipart/alternative; boundary="047d7b2e11d75fe30c04e8fdd8bb"
Cc: "ROOME, Wendy D (Wendy)" <w.roome@alcatel-lucent.com>, IETF ALTO <alto@ietf.org>, "choits@etri.re.kr" <choits@etri.re.kr>, Qin Wu <bill.wu@huawei.com>
Subject: [alto] ALTO Extension: A document defining multi-metrics filtering?
X-BeenThere: alto@ietf.org
X-Mailman-Version: 2.1.12
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: <http://www.ietf.org/mail-archive/web/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: Fri, 18 Oct 2013 06:14:25 -0000

Hi Sabine,

Good comments. Please see below.

On Thu, Oct 17, 2013 at 1:40 PM, RANDRIAMASY, SABINE (SABINE) <
sabine.randriamasy@alcatel-lucent.com <javascript:_e({}, 'cvml',
'sabine.randriamasy@alcatel-lucent.com');>> wrote:

>  A few questions and comments inline to make sure I understood. If we are
> to document proposed filtering services, should we put separate sections,
> one on filtering services for the basic protocol and the other one, more
> prospective for protocol extensions on topologies?
>
Following the guideline of modular design, how about using different
documents whenever possible?

Here is some thinking on organization. A main design feature of the
ALTO base protocol is its single-switch abstraction. Hence, how about we
first focus on filtering on this base abstraction, and not beyond?

Specifically, in this base abstraction model, a network map and a cost map
based on the network map defines an abstract, single switch. Each PID in
the network map defines a PoP (i.e., the set of endhosts, which can be
either servers or clients in an application context, attached to this PoP),
and the cost map of each cost metric defines the pair-wise values of the
given cost metric. Let V be the set of n PIDs (nodes), and E the set of n^2
edges. Filtering is to help an application to narrow down its choices when
building an application overlay based on this single-switch model. Hence,
we need to define the following components:

- how to filter the set of nodes?
- how to filter the set of candidate overlay paths (one hop or multiple
hops in extreme e.g., origin -> edge server -> consumer)?

Richard


>  ****
>
> Thanks****
>
> Sabine****
>
> ** **
>
> ** **
>
> *De :* yang.r.yang@gmail.com <javascript:_e({}, 'cvml',
> 'yang.r.yang@gmail.com');> [mailto:yang.r.yang@gmail.com<javascript:_e({}, 'cvml', 'yang.r.yang@gmail.com');>]
> *De la part de* Y. Richard Yang
> *Envoyé :* lundi 14 octobre 2013 04:42
> *À :* IETF ALTO
> *Cc :* RANDRIAMASY, SABINE (SABINE); ROOME, Wendy D (Wendy);
> ietf@nico-schwan.de <javascript:_e({}, 'cvml', 'ietf@nico-schwan.de');>;
> Qin Wu; Young Lee; Greg Bernstein; choits@etri.re.kr <javascript:_e({},
> 'cvml', 'choits@etri.re.kr');>; dhruv.dhody
> *Objet :* Re: ALTO Extension: A document defining multi-metrics filtering?
> ****
>
> ** **
>
> Let me add on: although a filtering service can be a very useful service,
> it can also be quite involved, and hence the WG may need to think through
> the issues when designing this service. For example, there are two types of
> use cases:****
>
> ** **
>
> - end-to-end: given src set {s1, s2, s3, ..., sn} and dst set {d1, d2, d3,
> ..., dm}, return all pairs (si, dj), where si in {s1, ..., sn} and dj in
> {d1, ..., dm} such that (si, dj) satisfies the constraints;****
>
> *[     ] This use case corresponds to the base protocol. The requested
> service is the ALTO Cost Map Filtering Service w.r.t metric values. It
> seems easy to extend this service by extending the set of constraints with
> additional constraints metrics and additional logical operators. *****
>
> ** **
>
> - relay: given src s, dst d, and a relay candidate set {r1, r2, ..., rk},
> return all of the ri such that s -> ri -> d satisfies the constraints. ***
> *
>
> *[     ] This use case relates to a proposed ALTO extension on topologies
> providing cost maps where there may be several paths between an (S,D) pair.
> Is the ALTO Service here the ALTO Cost Map Filtering Service w.r.t metric
> values adapted to a multi-path topology?  The cost map here would need to
> include some index on the cost value w.r.t. the relay ID and the service
> would only return cost values on the indexed (S,D, idx) triples satisfying
> the constraints. If this is correct, then such a use case would well fit
> into filtering services for topology based ALTO  extensions. *****
>
> ** **
>
> Note that with relay, we will then need to worry about the "composition"
> semantics of metrics. For example, delay might be additive, loss rate
> (unless small and independent) may not be.****
>
> *[     ] I think the composition and optimization operators should be
> documented in any case (I think in the “use and application” field of the
> RFC6390 template). Indeed, the OPTIMUM-COMPOSITION attributes may be
> MIN-SUM, MAX-MIN, MIN-PROD etc… *
>
> * *
>
> *In the base protocol an e2e cost value provided by the server is already
> composed and abstracted. But if we have a protocol extension that details
> paths per sections,  then indeed e2e path cost composition may have to be
> done at  the ALTO Client side. *
>
> ** **
>
> The relay could be even fancier (e.g., one-hop server detour such as
> Akamai one-hop detour and hence may involved two relay servers), but it may
> or may not be a good idea to go too complex, depending on if the WG can
> define a clean API (e.g., SQL select/where grammar comes to mind quickly).
> ****
>
> ** **
>
> Thanks!****
>
> ** **
>
> Richard****
>
> On Sun, Oct 13, 2013 at 7:57 PM, Y. Richard Yang <yry@cs.yale.edu<javascript:_e({}, 'cvml', 'yry@cs.yale.edu');>>
> wrote:****
>
> Dear all,****
>
> ** **
>
> The base ALTO protocol (
> http://www.ietf.org/id/draft-ietf-alto-protocol-20.txt) is mostly a
> single-cost-metric centric:****
>
> ** **
>
> - The Cost Map filtering service uses only one cost-type (Sec. 11.3.2.3):*
> ***
>
> ** **
>
>      object {****
>
>      CostType   cost-type;****
>
>      [JSONString constraints<0..*>;]****
>
>      [PIDFilter  pids;]****
>
>    } ReqFilteredCostMap;****
>
> ** **
>
>    object {****
>
>      PIDName srcs<0..*>;****
>
>      PIDName dsts<0..*>;****
>
>    } PIDFilter;****
>
> ** **
>
> ...****
>
>  constraints  Defines a list of additional constraints on which****
>
>       elements of the Cost Map are returned.  This parameter MUST NOT be**
> **
>
>       specified if this resource's capabilities (Section 11.3.2.4)****
>
>       indicate that constraint support is not available.  A constraint****
>
>       contains two entities separated by whitespace: (1) an operator,****
>
>       'gt' for greater than, 'lt' for less than, 'ge' for greater than****
>
>       or equal to, 'le' for less than or equal to, or 'eq' for equal to;**
> **
>
>       (2) a target cost value. ****
>
> ** **
>
> - The Endpoint Cost service allows filtering (Sec. 11.5.1.3) as well, and
> is similar to Cost Map Filtering:****
>
> ** **
>
>    object {****
>
>      CostType          cost-type;****
>
>      [JSONString       constraints<0..*>;]****
>
>      EndpointFilter    endpoints;****
>
>    } ReqEndpointCostMap;****
>
> ** **
>
>    object {****
>
>      [TypedEndpointAddr srcs<0..*>;]****
>
>      [TypedEndpointAddr dsts<0..*>;]****
>
>    } EndpointFilter;****
>
> ** **
>
>    constraints  Defined equivalently to the "constraints" input****
>
>       parameter of a Filtered Cost Map (see Section 11.3.2).****
>
> ** **
>
> In other words, in the base protocol, the filtering condition and the
> output are based on the same Cost Metric. It is natural that the filtering
> and the output are based on different Cost metrics. For example, a Client
> asks for routingcost for only pairs whose latency is below a threshold (see
> use cases in
> http://tools.ietf.org/html/draft-randriamasy-alto-multi-cost-07). ****
>
> ** **
>
> One may argue that the filter-metric-no-equal-to-output-metric function
> can be implemented on top of the filter-and-output-using-one-metric
> function:****
>
> ** **
>
> In particular, suppose the filtering is based on metrics M1 and M2, and
> the output is M3, for a set src to a set dsts. The Client can use the
> following three queries:****
>
> ** **
>
> - Q1: Use single metric <M1, filter on M1, srcs, dsts> and obtains <srcs1,
> dsts1> in return;****
>
> - Q2: Use single metric <M2, filter on M2, srcs1, dsts1> and obtains
> <srcs2, dsts2> in return;****
>
> - Q3: Use single metric <M3, no filter, srcs2, dsts2> to get the final
> result.****
>
> ** **
>
> Although this is not too bad, it is inconvenient. Note that preceding is
> first discussed by Sabine, Wendy, Nico in:
> http://tools.ietf.org/html/draft-randriamasy-alto-multi-cost-07****
>
> ** **
>
> I saw that this is also the issue discussed in  ****
>
> - http://tools.ietf.org/html/draft-wu-alto-json-te-01****
>
> - http://tools.ietf.org/html/draft-lee-alto-app-net-info-exchange-02****
>
> ** **
>
> Hence, I propose that the WG extends the base protocol with this
> capability, as I see that it is quite useful. One issue is that I see three
> designs, and I am wondering if the authors are preparing on discussing
> their designs at the coming IETF, and if there is a possibility for a
> single, unified document, focusing on this issue.****
>
> ** **
>
> Thanks a lot!****
>
> ** **
>
> Richard****
>
> ** **
>