Re: [lmap] AD evaluation: draft-ietf-lmap-yang-10
Juergen Schoenwaelder <j.schoenwaelder@jacobs-university.de> Thu, 26 January 2017 10:17 UTC
Return-Path: <j.schoenwaelder@jacobs-university.de>
X-Original-To: lmap@ietfa.amsl.com
Delivered-To: lmap@ietfa.amsl.com
Received: from localhost (localhost [127.0.0.1])
by ietfa.amsl.com (Postfix) with ESMTP id BDD93129512
for <lmap@ietfa.amsl.com>; Thu, 26 Jan 2017 02:17:08 -0800 (PST)
X-Virus-Scanned: amavisd-new at amsl.com
X-Spam-Flag: NO
X-Spam-Score: -7.398
X-Spam-Level:
X-Spam-Status: No, score=-7.398 tagged_above=-999 required=5
tests=[BAYES_00=-1.9, RCVD_IN_DNSWL_MED=-2.3, RP_MATCHES_RCVD=-3.199,
URIBL_BLOCKED=0.001] autolearn=ham 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 OhO_vJgYMkio for <lmap@ietfa.amsl.com>;
Thu, 26 Jan 2017 02:17:07 -0800 (PST)
Received: from atlas3.jacobs-university.de (atlas3.jacobs-university.de
[212.201.44.18])
(using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits))
(No client certificate requested)
by ietfa.amsl.com (Postfix) with ESMTPS id 27F4A129448
for <lmap@ietf.org>; Thu, 26 Jan 2017 02:17:07 -0800 (PST)
Received: from localhost (demetrius5.irc-it.jacobs-university.de [10.70.0.222])
by atlas3.jacobs-university.de (Postfix) with ESMTP id DAB447BD;
Thu, 26 Jan 2017 11:17:05 +0100 (CET)
X-Virus-Scanned: amavisd-new at jacobs-university.de
Received: from atlas3.jacobs-university.de ([10.70.0.205])
by localhost (demetrius5.jacobs-university.de [10.70.0.222]) (amavisd-new,
port 10030)
with ESMTP id LWjg2lDP_vtr; Thu, 26 Jan 2017 11:17:02 +0100 (CET)
Received: from hermes.jacobs-university.de (hermes.jacobs-university.de
[212.201.44.23])
(using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits))
(Client CN "hermes.jacobs-university.de",
Issuer "Jacobs University CA - G01" (verified OK))
by atlas3.jacobs-university.de (Postfix) with ESMTPS;
Thu, 26 Jan 2017 11:17:05 +0100 (CET)
Received: from localhost (demetrius4.jacobs-university.de [212.201.44.49])
by hermes.jacobs-university.de (Postfix) with ESMTP id 0F40B200AC;
Thu, 26 Jan 2017 11:17:05 +0100 (CET)
X-Virus-Scanned: amavisd-new at jacobs-university.de
Received: from hermes.jacobs-university.de ([212.201.44.23])
by localhost (demetrius4.jacobs-university.de [212.201.44.32]) (amavisd-new,
port 10024)
with ESMTP id J9Z2aUrM8p34; Thu, 26 Jan 2017 11:17:03 +0100 (CET)
Received: from elstar.local (elstar.jacobs.jacobs-university.de
[10.50.231.133])
by hermes.jacobs-university.de (Postfix) with ESMTP id 3EAAE200AB;
Thu, 26 Jan 2017 11:17:03 +0100 (CET)
Received: by elstar.local (Postfix, from userid 501)
id C72823E4CDFF; Thu, 26 Jan 2017 11:17:06 +0100 (CET)
Date: Thu, 26 Jan 2017 11:17:06 +0100
From: Juergen Schoenwaelder <j.schoenwaelder@jacobs-university.de>
To: Alissa Cooper <alissa@cooperw.in>
Message-ID: <20170126101706.GD43055@elstar.local>
Mail-Followup-To: Alissa Cooper <alissa@cooperw.in>, lmap@ietf.org
References: <49AB42C1-3DE5-4289-9B32-173B69C191DC@cooperw.in>
<20170124202305.GA38068@elstar.local>
<E2346FCD-B119-4385-BBF8-B97207DFB693@cooperw.in>
MIME-Version: 1.0
Content-Type: text/plain; charset=utf-8
Content-Disposition: inline
X-Clacks-Overhead: GNU Terry Pratchett
Content-Transfer-Encoding: 8bit
In-Reply-To: <E2346FCD-B119-4385-BBF8-B97207DFB693@cooperw.in>
User-Agent: Mutt/1.6.0 (2016-04-01)
Archived-At: <https://mailarchive.ietf.org/arch/msg/lmap/0UBxQGRlcBS7ZLpzqPPzsV-rMJk>
Cc: lmap@ietf.org
Subject: Re: [lmap] AD evaluation: draft-ietf-lmap-yang-10
X-BeenThere: lmap@ietf.org
X-Mailman-Version: 2.1.17
Precedence: list
Reply-To: Juergen Schoenwaelder <j.schoenwaelder@jacobs-university.de>
List-Id: Large Scale Measurement of Access network Performance <lmap.ietf.org>
List-Unsubscribe: <https://www.ietf.org/mailman/options/lmap>,
<mailto:lmap-request@ietf.org?subject=unsubscribe>
List-Archive: <https://mailarchive.ietf.org/arch/browse/lmap/>
List-Post: <mailto:lmap@ietf.org>
List-Help: <mailto:lmap-request@ietf.org?subject=help>
List-Subscribe: <https://www.ietf.org/mailman/listinfo/lmap>,
<mailto:lmap-request@ietf.org?subject=subscribe>
X-List-Received-Date: Thu, 26 Jan 2017 10:17:09 -0000
Trimming things down...
On Wed, Jan 25, 2017 at 01:25:26PM -0500, Alissa Cooper wrote:
> >
> >> (4) "A queue is internally used to pass
> >> results to another schedule."
> >>
> >> I thought it was up to the implementation to decide how to implement this?
> >
> > OK. I meanwhile understand that the word 'queue' has too many
> > connotations. Is 'buffer' a less problematic term? The key here is
> > that the data producer and the data consumer are in general not
> > running at the time and hence data needs to be stored temporarily
> > somewhere.
>
> Isn’t this implied though? Even with “buffer” it still seems like specifying an implementation detail. I’d prefer to see something like your last sentence above instead.
So I will replace 'buffer' with 'somewhere'. Oh boy. Here is the
new text:
A set of schedules receiving the output produced
by this action. The output is stored temporarily
somewhere since the destination schedules will in
general not be running when output is passed to
them. The behaviour of an action passing data to
its own schedule is implementation specific.
> > I will replace queue with buffer for now.
> >
> >> (5) I don't understand why the 'program' elements are included in the task configurations and capabilities. It doesn't seem wise to allow the controller to tell the MA which program it needs to use to complete a task, and I don't understand why the MA would need to communicate that information to the controller either. I thought the recent list discussion indicated that if an MA was not capable of performing an action, that action would simply fail, which seems like all that is needed.
> >
> > There are multiple things:
> >
> > (a) How do I tell which task I want to have executed? The information
> > model assumes that this can be done with the help of a registry.
> > The YANG data model, in addition, allows to use a simple 'program
> > name'. Note that this is a choice, i.e., you either use a registry
> > or a program name, but not both.
> >
> > The registry at the end is just some level of indirection - but
> > this indirection also requires to have tasks registered in a
> > registry. Right now, the implementation I know of only supports
> > program names.
> >
> > (b) The task list in the capabilities branch serves as an inventory,
> > i.e., it tells the controller which tasks are supported by a given
> > implementation. The other task list defined options that are used
> > when a certain task is invoked (the Task Configuration in the
> > information model). If a controller configures a task that the
> > agent does support (i.e., it is not listed in the capability
> > tasks), it will not be executed.
> >
> > Note that a capability task name 'traceroute' exposed by the LMAP
> > agent does not necessarily mean that there is a program called
> > traceroute at the operating system level. In fact, an implementation
> > could choose to run traceroute internally without an explicit system
> > level process (like RIPE Atlas did everything in a big event loop, not
> > sure whether this is still the case).
>
> Ok, I can understand that under circumstances where there is no registry, there needs to be some identifier to indicate which task to run, and which tasks the MA is capable of running. But the examples seem to imply that ‘program’ is the path and file name of the actual executable on the MA, which is what seems dangerous and unnecessary to me.
I can take out the path if that helps.
Why would the controller necessarily even know where such executables reside on the file system? And I know there are a lot of things that could go wrong if a Controller gets compromised, but it just seems like making it so trivial for an MA implementation to literally just run the executable name specified by the Controller creates unnecessary risk.
Perhaps we need to add more explicit text to /tasks/task saying that a
configured LMAP task MUST resolve to a task listed in the capabilities.
This is in my view what matters most.
> If the task name on its own is not sufficient for the MA to be able to figure out which program is suitable to run, why not have the additional field defined as ‘program-name’ with some guidance about how to populate it, so that, e.g., what you end up with in that field is “mtr” or “fping” instead of "/usr/bin/mtr” or "/usr/bin/fping”?
I do not really see the logic here. An implementation that blindly
executes a program called 'mtr' by search a search PATH may actually
be worse than an implementation that executes /some/path/mtr.
> >> Nits and minor comments:
> >
> >> (2) "Implementers MUST taken care that
> >> option names and values are passed literally to programs. In
> >> particular, it MUST be avoided that any shell expansions are
> >> performed that may alter the option names and values."
> >>
> >> This text strikes me as a bit odd. Surely there are a whole selection of good programming practices that are necessary to ensure that things don't go haywire when implementing LMAP -- why call out these two with normative recommendations? Why does this guidance only apply to options? I would recommend having this text be non-normative, but if you do keep it I would suggest the following:
> >>
> >> Implementers MUST take care that
> >> option names and values are passed literally to programs. In
> >> particular, shell expansions that may alter the option names and values MUST NOT be performed.
> >
> > I have no strong opinion on MUST vs must here and I usually happily
> > follow the advice of IESG members on RFC 2119 keywords. ;-)
>
> Ok, my suggestion is to use non-normative “ought to” rather than 2119 MUST.
Seriously? I have left the 'must' in (there are other occurances of
must) and I leave it to the discretion of the IESG to discuss this if
needed - and then I do whatever comes out of it.
/js
--
Juergen Schoenwaelder Jacobs University Bremen gGmbH
Phone: +49 421 200 3587 Campus Ring 1 | 28759 Bremen | Germany
Fax: +49 421 200 3103 <http://www.jacobs-university.de/>
- [lmap] AD evaluation: draft-ietf-lmap-yang-10 Alissa Cooper
- Re: [lmap] AD evaluation: draft-ietf-lmap-yang-10 Juergen Schoenwaelder
- Re: [lmap] AD evaluation: draft-ietf-lmap-yang-10 Alissa Cooper
- Re: [lmap] AD evaluation: draft-ietf-lmap-yang-10 Juergen Schoenwaelder
- Re: [lmap] AD evaluation: draft-ietf-lmap-yang-10 Alissa Cooper
- Re: [lmap] AD evaluation: draft-ietf-lmap-yang-10 Juergen Schoenwaelder
- Re: [lmap] AD evaluation: draft-ietf-lmap-yang-10 MORTON, ALFRED C (AL)
- Re: [lmap] AD evaluation: draft-ietf-lmap-yang-10 Juergen Schoenwaelder
- Re: [lmap] AD evaluation: draft-ietf-lmap-yang-10 Alissa Cooper