Re: [Lsr] A review of draft-ietf-lsr-isis-ttz

Huaimo Chen <huaimo.chen@futurewei.com> Wed, 24 February 2021 02:01 UTC

Return-Path: <huaimo.chen@futurewei.com>
X-Original-To: lsr@ietfa.amsl.com
Delivered-To: lsr@ietfa.amsl.com
Received: from localhost (localhost [127.0.0.1]) by ietfa.amsl.com (Postfix) with ESMTP id 5E03C3A136A; Tue, 23 Feb 2021 18:01:48 -0800 (PST)
X-Virus-Scanned: amavisd-new at amsl.com
X-Spam-Flag: NO
X-Spam-Score: -2.089
X-Spam-Level:
X-Spam-Status: No, score=-2.089 tagged_above=-999 required=5 tests=[BAYES_00=-1.9, DKIM_SIGNED=0.1, DKIM_VALID=-0.1, DKIM_VALID_AU=-0.1, DKIM_VALID_EF=-0.1, HTML_MESSAGE=0.001, RCVD_IN_MSPIKE_H2=-0.001, T_SPF_PERMERROR=0.01, URIBL_BLOCKED=0.001] autolearn=ham autolearn_force=no
Authentication-Results: ietfa.amsl.com (amavisd-new); dkim=pass (1024-bit key) header.d=futurewei.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 x5V3N467ENKE; Tue, 23 Feb 2021 18:01:44 -0800 (PST)
Received: from NAM12-DM6-obe.outbound.protection.outlook.com (mail-dm6nam12on2109.outbound.protection.outlook.com [40.107.243.109]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by ietfa.amsl.com (Postfix) with ESMTPS id C45353A1368; Tue, 23 Feb 2021 18:01:43 -0800 (PST)
ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=MMcZuirqyx028tM9MO6CQl1G6IVSpEbTnMQkkholYOpkGPLfY9h4wLJHmL/LoWCLYoVJPYAS2yeKm1iT9ZQLeQVNaa7tm32oU1e0jjFZYvtKZ0uWbcmufp24+zAVtEraYCGiXYmy5pnvD9EcUcPd+7KVIjy4VXXhCEoJ3n+hIntl3vqOr+5LUU6zse6Qb4hw4IROsRYsIQ6G67JTzCNMuafbG6cnVJghoPd5UM8vc1dyGrg6RRXN0wYuz5yqrgoNesBFhITLoqUBj4m1ZmH/E6EQ77brDdcFFXIJEkDL1tqDB3nZWLkxbMoYI3jMGN16ExPPuS8t3KgyO+s8gNvk6g==
ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector9901; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=tv8EaGEaP52wZIxbMjpOFGiMxp8fVW7hvt9QhsMePtU=; b=LERlyGQb7slWDfinhUvPfJQGYuAYGWaH637mxBcCaR+/WfXs9L25023LwMEKNQOBWaWmSsHPCj9H2H7iGvuqSFsuH4biprD/vrVS3D+1LdJptcVdU5zClrp91AMQpgxXgXPmGZv3IhcK/5vhmdaoUu6aEmmtS1pbwpNVuA2HFuYqHVzi7vV8nB09pVGtPpcyJ7Xt5YgopIQhDlc0iPzNFFTrzq1/aDocx4BH7bG/qWhSHBqd/pcaLAa7YH88IEhLjFKHS75FrzXH0mLk/Mtsjbztihm5yR9vlHVvh1Z0m5n/fgmGUGxNXIozEPywZg5+lp0V7Jf3X0zVs6VyGwNCHg==
ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=futurewei.com; dmarc=pass action=none header.from=futurewei.com; dkim=pass header.d=futurewei.com; arc=none
DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=Futurewei.com; s=selector2; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=tv8EaGEaP52wZIxbMjpOFGiMxp8fVW7hvt9QhsMePtU=; b=QTeSwo1t8VJqMFin8mbM4i8omAmPaLiY0TtI4SvpbndZ0sl/YGVk7ZELNuyiw0jnhpPomDCU3KAsfCH2LTheDCnSFk7VnyrTv1V3I6xIX1HC8KSwGG3InQGvPUTfPIhuTKnrhqZExk+MpgL39auVePm49tCO0MOHGCM9fHC5YZA=
Received: from MN2PR13MB4087.namprd13.prod.outlook.com (2603:10b6:208:263::16) by MN2PR13MB2830.namprd13.prod.outlook.com (2603:10b6:208:f5::28) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.3868.15; Wed, 24 Feb 2021 02:01:41 +0000
Received: from MN2PR13MB4087.namprd13.prod.outlook.com ([fe80::14ed:3768:8b86:be32]) by MN2PR13MB4087.namprd13.prod.outlook.com ([fe80::14ed:3768:8b86:be32%9]) with mapi id 15.20.3890.018; Wed, 24 Feb 2021 02:01:41 +0000
From: Huaimo Chen <huaimo.chen@futurewei.com>
To: 'lsr' <lsr@ietf.org>, "adrian@olddog.co.uk" <adrian@olddog.co.uk>
CC: "draft-ietf-lsr-isis-ttz@ietf.org" <draft-ietf-lsr-isis-ttz@ietf.org>
Thread-Topic: A review of draft-ietf-lsr-isis-ttz
Thread-Index: AdcCR2vhMlJEbN5ZTliY5aujPCJY/gIByp9a
Date: Wed, 24 Feb 2021 02:01:41 +0000
Message-ID: <MN2PR13MB4087803D035EAF537BDE5477F29F9@MN2PR13MB4087.namprd13.prod.outlook.com>
References: <034801d70247$a3d0e970$eb72bc50$@olddog.co.uk>
In-Reply-To: <034801d70247$a3d0e970$eb72bc50$@olddog.co.uk>
Accept-Language: en-US
Content-Language: en-US
X-MS-Has-Attach:
X-MS-TNEF-Correlator:
authentication-results: ietf.org; dkim=none (message not signed) header.d=none;ietf.org; dmarc=none action=none header.from=futurewei.com;
x-originating-ip: [2601:199:4300:8e5a:3c13:77b8:bc98:7088]
x-ms-publictraffictype: Email
x-ms-office365-filtering-correlation-id: 41f17bf0-e9b6-4563-6a2c-08d8d86820f3
x-ms-traffictypediagnostic: MN2PR13MB2830:
x-microsoft-antispam-prvs: <MN2PR13MB2830A486B7B32E4FD32FC544F29F9@MN2PR13MB2830.namprd13.prod.outlook.com>
x-ms-oob-tlc-oobclassifiers: OLM:5236;
x-ms-exchange-senderadcheck: 1
x-microsoft-antispam: BCL:0;
x-microsoft-antispam-message-info: B2C/j8MC6rGz6N4lMjRKCvSHsQmVt7/5pRAhsbmTkIuEhteWqT07/7ObPvySisuv0sNAekiH5dD4Jt45wGUA5jZtuHezjH/R4DYOkqSYWxk4vNLNqPN5MmVPy5dNQ0pq4y6mMpz+VY5dmLXp92qGh4yIrb1cKts/Z6b0lIw0u+86L4w/chxGl8LZlvPxx8NqEJopBNjQ1yDmwupuPkkQSAT/166qJeZVOQkk13/wLFOQFpEvfkNE+mk/ByyRITLrOFgn7wRAf9yNMSw+zW7m+kBWrugluQH3LVYz2KHysiFb/duFSJ1tgcWJiV7FC1t1cdCysyIbfOaCMMbJMkQrpPqUJpc4mxSQnNZsZ3kl5wpqSO5fVZHSObO+dOwg7ISpyAut2ucWgoUDd9qE6QCOkmg3iysFgGxGAwPZs3CKkd+aXukcr61o5JIq3A5LfC7KzDJxP8AwR5xQiIktSYkpwYICRp6N1bFiewO8876amkRfCr1PoZ/rSWZe9rgZuAvu1/0+WVhYhGxo4CZnVf/fCg==
x-forefront-antispam-report: CIP:255.255.255.255; CTRY:; LANG:en; SCL:1; SRV:; IPV:NLI; SFV:NSPM; H:MN2PR13MB4087.namprd13.prod.outlook.com; PTR:; CAT:NONE; SFS:(4636009)(376002)(39850400004)(396003)(366004)(346002)(136003)(86362001)(8936002)(316002)(5660300002)(110136005)(186003)(7696005)(478600001)(55016002)(19627405001)(76116006)(9686003)(66476007)(64756008)(53546011)(66446008)(83380400001)(6506007)(44832011)(2906002)(71200400001)(52536014)(66574015)(66556008)(30864003)(33656002)(4326008)(66946007)(8676002); DIR:OUT; SFP:1102;
x-ms-exchange-antispam-messagedata: e8ZdrgVkYYL7lGL8ZlRkDKgyF3RbzKJ/BSrrd83Iuuvp3ylrBqttUrWpxw9KRjw1SfqKVXLpZ3OUudbnfFQOaUVzJZ5qHOC0+3fimebfBcW5+n4ksfaDvFxjz5FZjO4Qh+Y1KVhDTXdJFww6QjN4mHChFa5HE69r8xkI5KLJc78FTJPSN2+6T9mXfQVYzMVd4pxc0k9Hh4wpA0AijL37fAz+fPzXrOIDvt2VLK9okuRK0o1hNXHRoxeLqH3p77yp7OzY5Rc8kdTL9hnLHwJ5L714GbsOv1s2sAGH+0YKcoNLB/Fs+O0gUSg/dLqruL0C34rUad9EXPDx85NmPHIQoNXx7dM+epLaIG6LcwHRyVCEvEeL23UFLfhZrvWInAw8jrZxaqk4TgV6sy1pHu8WDsAu4R+xzrORo81bAbpsZx+bpFvKP+pZKUvvTgYW8qDjQ0SBlCQ2QesfTlxOMq5T0cv4Ky5ZK086P7L3X502Zf40DxOmH23bKNrCcxYUONcpv5QTM5QytIFxcL7MK+ZzJI+NhnTAnONMmnrD1EDLx9/kOqoIdPakVAeM+GbJapOrPfiD97GGqKsSNPhgKilAvZWXQcxLegnIXuxhEJNu1wpz8Jz1htx5hC8cML6YO+jiq4vizx2zOTu/4TJ5yE8eILX7JEl3G11ajOFqZjg2oFVuQfPOlUHXmdprfI0XgBFVdSDq5f983drqInwabVs7ZLvJdgsGawpL/aNY4vo3jDAYPUFt0GPTUtY+el3Ef4/VD1Q6CGHahQs2BTIeyhYaIH15tnSdCvSW+gkFr5VokvYWbBktq8IAW5v+dH6Fiq4QD2Ci9zWdERj/gZU/e1NjmbGLShTtfEPZK5yyikItoB5dQXqbDP7LimFcpYkXzq//XqwbBowaR7P+vSKa0dpJ+lV3xbtWbTaOmGHf+ct3MAWqXmtc6YRx0N0feZyiHAFfC4mk25KFrnQG0eR5jK9oPgMYmhYOlFLrs/KOwLZWAOVLOtGsDormZDscJnPvMRVujcgAPZBkWE4d3/hWOwbUIUWHviEn+pu4CE9WMCXBf+Z7rbugKhcZVWL98o5cw5CA+NSUniVu3yeYRbjzCcxl4W45yU3fWKqHIiDpzMPOe/qChX84vRNTsEfTEN1nN7J63se+kmS77gwtrNJMNQgPeAQaNkM+t9fvYkmpASlBmb3v4IKlj3cLjilTWChgt5EHxxanggK8VIIVzGgxV71oa9/Ttbm/SqnMm/A0/7Ocl2oqsXO09fXR9nd7A78jRGc0dpjcL1FMU7LJhW3rXnP5zM6hVONAX+3e9SfnOaj0Png+cuT65QRHV6AFHMTDgaHr6Ainh/O/MuxVcyw68xh1hN6sTWg6MVAKiL2ewP4N395UwWg1k00DHzLciZzOdTQ7
x-ms-exchange-transport-forked: True
Content-Type: multipart/alternative; boundary="_000_MN2PR13MB4087803D035EAF537BDE5477F29F9MN2PR13MB4087namp_"
MIME-Version: 1.0
X-OriginatorOrg: Futurewei.com
X-MS-Exchange-CrossTenant-AuthAs: Internal
X-MS-Exchange-CrossTenant-AuthSource: MN2PR13MB4087.namprd13.prod.outlook.com
X-MS-Exchange-CrossTenant-Network-Message-Id: 41f17bf0-e9b6-4563-6a2c-08d8d86820f3
X-MS-Exchange-CrossTenant-originalarrivaltime: 24 Feb 2021 02:01:41.3299 (UTC)
X-MS-Exchange-CrossTenant-fromentityheader: Hosted
X-MS-Exchange-CrossTenant-id: 0fee8ff2-a3b2-4018-9c75-3a1d5591fedc
X-MS-Exchange-CrossTenant-mailboxtype: HOSTED
X-MS-Exchange-CrossTenant-userprincipalname: xO4EdgGhYOVjYzMj6anTTt2fPVFb3UK68RNCHvQdmPRXpraAWFzJWcS0decNxjtJ8JDYhXSx2kxb1fgVR9z+2w==
X-MS-Exchange-Transport-CrossTenantHeadersStamped: MN2PR13MB2830
Archived-At: <https://mailarchive.ietf.org/arch/msg/lsr/mBPlBhHShtKHtbTtDFxSJinAp_0>
Subject: Re: [Lsr] A review of draft-ietf-lsr-isis-ttz
X-BeenThere: lsr@ietf.org
X-Mailman-Version: 2.1.29
Precedence: list
List-Id: Link State Routing Working Group <lsr.ietf.org>
List-Unsubscribe: <https://www.ietf.org/mailman/options/lsr>, <mailto:lsr-request@ietf.org?subject=unsubscribe>
List-Archive: <https://mailarchive.ietf.org/arch/browse/lsr/>
List-Post: <mailto:lsr@ietf.org>
List-Help: <mailto:lsr-request@ietf.org?subject=help>
List-Subscribe: <https://www.ietf.org/mailman/listinfo/lsr>, <mailto:lsr-request@ietf.org?subject=subscribe>
X-List-Received-Date: Wed, 24 Feb 2021 02:01:48 -0000

Hi Adrian,

    Thank you very much for your valuable comments.
    My answers/explanations are inline below with prefix [HC].

Best Regards,
Huaimo on behalf of authors


From: Adrian Farrel <adrian@olddog.co.uk>
Sent: Saturday, February 13, 2021 3:34 PM
To: 'lsr' <lsr@ietf.org>
Cc: draft-ietf-lsr-isis-ttz@ietf.org <draft-ietf-lsr-isis-ttz@ietf.org>
Subject: A review of draft-ietf-lsr-isis-ttz

Hi all,

Acee leant on me to do a review of this work (so blame him :-)

It's good to see this document adopted and progressing. Particularly
good to see the realistic compromise of making this Experimental.

I have a few comments, below.

Best,
Adrian

===

I have a largish issue with the fact that the document offers a choice
of how to aggregate the zone: virtual node or full mesh. Firstly, it is
not helpful to offer options without guidance about which option to pick
if you're an implementer or a deployer. You also need to specify whether
the choice MUST be a configuration option, and how to handle when some
nodes in the zone think one option and the others think the other
option.
[HC]: Added the advantages and disadvantages of two choices into the
document, which may help an implementer or a deployer.

Possibly you can make this part of the experiment (see below for notes
on the experiment).

I have some pretty strong opinions on the idea of a single node
abstraction. The main challenge comes when there is a partial failure in
the zone such that the zone is partitioned (or the path between two
zone neighbors across the zone is severely degraded). It is not possible
to represent this in the node model since your only options are:
- drop the connection to a neighbor
- move to represent the zone as two nodes
[HC]: To resolve the partition of a zone is challenging. One possible
solution is that when a zone is partitioned, it is abstracted as two
virtual nodes. One (the first) part of the zone is abstracted as one
(the first) virtual node, the other (second) part (which is disconnected
from the first part through zone links) is abstracted as another (second)
virtual node.

In fact, both models (node and mesh) are subject to disruption when
there is a connectivity failure within the zone, but if we think about
the mesh model, it doesn't actually need to be advertised as a full
mesh: partial mesh is easily handled. Nevertheless, the use of a single
zone leader to perform the aggregation has problems if the zone is
partitioned in some way - perhaps this is addressed by the partitioned
zone simply electing two distinct leaders and declaring itself as two
zones.
[HC]: When a partial mesh is used, some of routes may not be optimal
after a zone is abstracted as a partial mesh among the zone edges.
When a zone is abstracted as a full mesh of zone edges, the routes
keep unchanged. The routes that are optimal before the abstraction
are still optimal after the abstraction.
For node model, a zone is abstracted as a single virtual node.
When there is a connectivity failure within the zone, the failure
is not seen from any node outside of the zone. The routes computed
in any node outside of the zone will not change.
For mesh model, a zone is abstracted as a full mesh of zone edges.
Some of the routes will change. The route changes are consistent.

This discussion of faults within the zone seems (to me) to be pretty
important.

I am also struggling with metrics and route computation when the zone is
viewed from outside the zone.  4.1.5 tells us about route computation,
but it is not until 4.3.1 that we discover:
   The
   metric to the neighbor is the metric of the shortest path to the edge
   node within the zone.
This text applies to the full mesh case, and we don't have anything
about the node model, so we might assume that the metrics on the edge
circuits are unchanged.
[HC]: Added forward pointers accordingly.
For the node model, every node outside of the zone has no change
on the metrics; every node inside the zone sees the metric of a link
outside of the zone is one order of magnitude larger than the metric
of a link inside the zone.

Obviously, this is important, and it feels that something is broken for
the virtual node case. Consider Figure 1.

Without the zone (and assuming link metrics of 1), the cost of the path
R15-R61-R71-R67-R31 is 4, and this route might not be preferred if some
other route R15-x-y-R31 exists with cost 3. However, once we have
introduced the zone using the virtual node approach, there is an
available route R15-Rz-R31 that appears to have a preferable metric of
2. I would say that the route R15-x-y-R31 should still be preferred.
[HC]: Added some text about this.
After a zone is abstracted as a single virtual node, some routes
will be changed since the block of an area (zone) becomes a single
node. Some of the routes may not be optimal after the abstraction.

This point certainly needs to be called out in the text, and maybe this
gives some input to the choice between models. Perhaps the metrics in
the ISN and ESN TLVs are related to this point, but section 4.2.1 gives
no hint about how to set these values. Actually, I suspect that what is
going on here is that all of the metrics advertised to outside the zone
are controlled by the zone leader and advertised in the ISN/ESN - but I
don't find that actually stated anywhere.
[HC]: Added some text about this.
Node model has a higher abstraction rate than mesh model.
The mesh model does not scale when the number of edge nodes of a zone
is large.
The mesh model keeps the routes unchanged. After a zone is abstracted
as the full mesh of the edges of the zone, every route is still
optimal. The TLVs are not used to advertise anything inside a zone
to outside of the zone. They are used to indicate the zone links
of a zone edge node and are used by the zone nodes.
For the node model, nothing inside a zone is advertised outside
except for some prefixes inside the zone.


All this said, I find it notable that this document focusses almost
completely (sections 4 and 5 - section 4.3 is a very small section) on
the virtual node model. It would be good to provide an example like
Figure 2, but for the mesh model.
[HC]: Added an example with a figure accordingly.

Perhaps rather than deferring this to be an outcome of the experiment,
this document should spend some time comparing the two models *or* it
might even be time to abandon one of the models.
[HC]: Added the text comparing the two models.

---

Obviously, at some point before this goes forward for publication,
you'll need to reduce to no more than five front-page authors.
[HC]: Will reduce to five.

---

I think the Abstract might usefully mention IS-IS. Probably the first
sentence could read:

   This document specifies a topology-transparent zone in an IS-IS area.
[HC]: Updated the document according to your suggestion.
---

The document really needs a section to scope the Experiment.
[HC]: Added a section for this.

- How is the experiment kept separate and safe from the Internet or
  indeed from any non-participating routers?
[HC]: A new TLV (called Zone ID TLV) is defined for TTZ.
      Any router that does not support TTZ (or non-participating router)
      and is outside of a TTZ zone will ignore this TLV.

- What happens if the boundary of the experiment are breached?
  (To expand on this, what happens if there is a misconfiguration so
   that a Zone Internal Node thinks its neighbor is also in the Zone
   when it is actually unaware of these extensions and should be
   treated as a Zone External Node? This misconfiguration has a node
   that should be a Zone Edge/Border Node acting as a Zone Internal
   Node.)
[HC]: When there is a misconfiguration on a zone (a block of an area
      not using TTZ), a zone should not be transformed to a virtual
      node. A misconfiguration of a Zone Edge/Border Node to a
      Zone Internal node can be detected automatically.
      Every adjacent node of a Zone Internal node is a Zone node
      and has the same zone ID. When the Zone Internal node
      detects that one of its adjacent nodes is not a zone node,
      it should alarm the misconfiguration.

- How is the success (or failure!) of the experiment assessed?
[HC]: Backward compatible is verified and abstraction works as expected.
      Some critical misconfigurations should be detected and alarmed.

- Are there plans to bring this back for consideration on the standards
  track if certain criteria are satisfied?
[HC]: We have a plan for using IS-IS TTZ, which may help.

- Is evaluation of the relative merits of node and mesh abstraction part
  of the experiment?
[HC]: The evaluation will focus on node model.

---

Section 1

The WG may have established a different practice, but it used to be
normal to reference RFC 1195 alongside ISO 10589.  (You do have 1195
listed in the references section, but you don't actually reference it).
[HC]: Added reference to RFC 1195.

---

Section 1

   There are scalability issues in using areas as the number
   of routers in a network becomes larger and larger.

Maybe what you're trying to say in this section (and it is important
because it gives the whole motivation for this work) is that there are
scalability issues with a single IS-IS area as the number of routers in
the area grows. (You might explain what those issues are.)
[HC]: Added some details.
When an IS-IS area becomes larger, its convergence on a network event
such as a link down will take a longer time. During the period of network
converging, more traffic that is transported through the network area
will get lost.

Then you can go on to say how splitting into multiple levels and having
multiple L1 areas mitigates the scaling issues. And then you can
continue with your text about why splitting an IS-IS system as it grows
can be hard.
[HC]: Added some details.
It needs a careful planning and many configurations on the network.

---

Section 2

   A Topology-Transparent Zone (TTZ) may be deployed to resolve some
   critical issues such as scalability in existing networks and future
   networks.

This sounds like you have a number of critical issues in mind, but you
only mention scalability. Are there others you can list, or should you
reduce this text to just...

   A Topology-Transparent Zone (TTZ) may be deployed to resolve the
   critical issue of scalability in existing network and future
   networks.
[HC]: Updated the text as you suggested.
---

Section 2

   o  Abstracting a zone as a TTZ virtual entity, which is a single
      virtual node or zone edges' mesh, SHOULD be smooth with minimum
      service interruption.

I *think* you are talking about the transition from not using TTZ to
using TTZ, but it could be a lot clearer.

A forward pointer to 4.1.4 might be useful. And 4.1.4 really should
describe some of the processing governed by the OPS bits in 4.2.1.
[HC]: Updated the text accordingly.

---

Section 2

   o  De-abstracting (or say rolling back) a TTZ virtual entity to a
      zone SHOULD be smooth with minimum service interruption.

This is similarly unclear, and it sounds like you might be talking
about turning off a zone (i.e., moving all of the Zone Nodes into the
surrounding area and removing the zone), or you could be talking about
moving a single node from inside to outside the zone.
[HC]: Updated the text accordingly.
      Transforming (or say rolling back) a TTZ virtual entity using TTZ
      back to its zone (i.e., its original block of network area
      not using TTZ) (refer to Section 5.2)
      SHOULD be smooth with minimum service interruption.

---

Section 2

   o  Users SHOULD be able to easily set up an end-to-end service
      crossing TTZs.

I am not clear what a "service" is in this context. Assuming we're not
talking about TE extensions, isn't the service simply that the user
sends packets and they are routed by the network?
[HC]: Removed it.

---

Section 4

I think the start of this section needs to add a little about the limits
of a TTZ. In particular:
- Is a TTZ restricted to reside within a single level?
[HC]: All the nodes in a zone must be L1 nodes except for some
zone edge nodes are L1/L2 nodes;
All the nodes in a zone must be L2 nodes except for some
zone edge nodes are L1/L2 nodes; or
All the nodes in a zone must be L1/L2 nodes.

- Is a TTZ restricted to lie within a single area?
[HC]: Yes.

- What happens if one of the zone nodes is an L1/L2 router?
[HC]: In this case, if the other zone nodes are L1 routers,
all the zone nodes are abstracted to be an L1 virtual node;
if the other zone nodes are L2 routers,
all the zone nodes are abstracted to be an L2 virtual node.

  - Presumably, depending on the answer to the first question, this
    could only happen if the node in question is a zone edge/border node
    But, even then it is complicated: does the abstracted node become an
    L1/L2 router?
[HC]: If all the zone nodes are L1/L2 routers, the abstracted
node becomes an L1/L2 router.

---

4.1
OLD
  Each of these links connects a zone neighbor.
NEW
  Each of these links connects to a zone neighbor.
END
[HC]: Changed the text as you suggested.

---

4.1
   The virtual node ID may be derived from the zone ID.

Maybe say how else it could be specified and how the implementer or
deployer makes this choice.
[HC]: Added more details.

---

A useful modification to Figures 1 and 2 would be to add a circuit from
R15 to R65 in Figure 1 and show how this becomes a second 'parallel'
circuit from R15 to Rz in Figure 2.
[HC]: Added the circuit from R15 to R65 as you suggested.

---

4.1.1

   A TTZ MUST hide the information inside the TTZ from the outside.  It
   MUST NOT directly distribute any internal information about the TTZ
   to a router outside of the TTZ.

   For instance, the TTZ in the figure above MUST NOT send the
   information about TTZ internal router R71 to any router outside of
   the TTZ in the routing domain; it MUST NOT send the information about
   the circuit between TTZ router R61 and R65 to any router outside of
   the TTZ.

These "for instance" examples are good in that they are true. But they
imply some things by omission, and I don't think you mean to make those
implications.

That is, the first paragraph is much clearer and definitive. But your
second paragraph, by calling out some special cases of "internal
information" makes it ambiguous whether, for example, the router R61 is
advertised outside the TTZ. (Of course, it isn't.)

It may be better to delete the second paragraph, and go straight to the
following paragraph that describes what is seen outside the TTZ by
directly describing what *is* advertised rather than providing a partial
list of what is not advertised.
[HC]: Removed the second paragraph accordingly.

---

I think that the subsections of 4.1 cover all of the necessary
information. My list of things to cover is:
- zone edge/border nodes form adjacencies with zone neighbor nodes using
  the identity of the aggregate zone node and not their own identities
[HC]: In Section 4.1.4.  Adjacency Establishment

- zone nodes continue to operate IS-IS as normal to advertise zone nodes
  and zone links within the zone
[HC]: In Section 4.4.1.  Advertisement of LSPs within Zone

- zone edge/border nodes do not advertise or readvertise LSPs that
  originated within the zone to neighbors outside the zone
[HC]: In Section 4.1.4.  Adjacency Establishment
      In Section 4.4.1.  Advertisement of LSPs within Zone

- zone nodes continue to operate IS-IS as normal to re-advertise LSP
  that originated outside the zone
[HC]: In Section 4.1.4.  Adjacency Establishment
      In Section 4.4.2.  Advertisement of LSPs through Zone

- the zone leader is responsible for deriving the aggregate node
  information that represents the node and for originating LSPs for this
  aggregate node
[HC]: In Section 4.1.3.  LS Generation for Zone as a Single Node

- zone nodes re-advertise LSPs originated by the zone leader on behalf
  of the aggregate zone node on all circuits including those that
  connect to zone neighbor nodes
[HC]: In Section 4.1.3.  LS Generation for Zone as a Single Node

- when a zone edge/border node readvertises the LSPs for the aggregate
  zone node, it does so as it had originated the LSP
[HC]: In Section 4.1.4.  Adjacency Establishment

- when any zone edge/border node receives an LSP that reports itself as
  originating from the aggregate zone node, the edge/border node
  suppresses the LSP
[HC]: In Section 4.1.4.  Adjacency Establishment
      In Section 5.1.  Transfer Zone to a Single Node

- zone nodes do not install routing state resulting from advertisements
  of LSPs describing the aggregate zone node
[HC]: In Section 4.1.5.  Computation of Routes

As I say, I think you have all this in the subsections of 4.1, but I had
to hunt around to find all of this. It might be helpful to give a clear
summary of the behaviors.
[HC]: Added a summary of these behaviors with forward pointers.

---

4.1.2

   The leader election mechanism described in
   [I-D.ietf-lsr-dynamic-flooding] may be used to elect the leader for
   the zone.

"may be used" or "are used"?
[HC]: Changed it accordingly.

---

4.1.2

   Somewhere you need to cover what happens if the zone leader fails
   but the zone remains otherwise fully connected. Does the new leader
   start from scratch, or does it try to retain the zone ID etc.?
[HC]: Added the text below:
    When the existing zone leader fails, a new zone leader is elected.
    The new leader originates the LSPs for the virtual node based
    on the LSPs received from the failed leader. It retains the
    System ID of each LSP ID and the live adjacencies between
    the virtual node and the zone neighbors.

---

4.1.4 attempts to do two things:
- describe the migration from not-a-zone to the use of a zone
- describe the steady state zone behavior
I think it would be helpful to split these out into separate sections.
In particular, the migration from not-a-zone to zone is only needed in
operational networks.
[HC]: Split these into two separate sections.

---

4.2

   The following TLV is defined in IS-IS.

I think...

   This document defines a new TLV for use in IS-IS as follows.
[HC]: Used the text as you suggested.

---

4.2.1

   The format of IS-IS Zone ID TLV is illustrated below.  It may be
   added into an LSP for a zone node.

s/may/MUST/
[HC]: Changed "may" to "MUST".

---

4.2.1

   If every link of a zone edge node is a zone link

Doesn't that mean that the zone edge node is not a zone edge node?
[HC]: Removed the related text.

---

4.2.1

To be honest, I found the description of the processing governed by
the OPS bits to be pretty complicated.

I would recommend adding a new section (related to 4.1.4) that talks
through the process in clear steps. Then this txt can just list the
meanings of the bits and point back to the process description.

Maybe this is what sections 5, 6.2, and 6.3 are for, in which case cut
down the explanation here and provide forward pointers.
[HC]: Cut down the text here and added forward pointers.

---

Figures 4 and 5. I think you have defined the types for these two
sub-TLVs (1 and 2).
[HC]: Changed them accordingly.

---

4.2.1

I wonder how many neighbors a zone might have. It could be a fairly big
number, I suspect, although obviously it depends on how the operator
decides to chop up the area into zones (for which I don't find any
guidance).

The size of the ISN and ESN would appear to be a function of the number
of neighbors times (IDlength+3). Is there a practical constraint on the
size of the TLVs which places a limit on the number of neighbors that a
zone can have? This would be an important design consideration for the
operator. Maybe it is another feature for experimentation.
[HC]: The number of zone neighbors may be big. When a zone is abstracted
as a single virtual node, all these zone neighbors are put into one or
more extended IS reachability TLVs in the LSPs for the virtual node,
which are originated by the leader of the zone.
One TLV can store 20+ neighbors. Ten TLVs in two LSPs can contain 200+
neighbors.

---

4.2.1

The same neighbour may have two links to the zone and not necessarily
through the same edge/border node (see my previous point). In this case,
might the different links have different metrics? I think so, but I
don't see how that is encoded in the sub-TLVs.
[HC]: This may follow a normal implementation. In default, one link with
lower metric is included in the LSPs originated for the virtual node.

---

6.1

There is probably something to be said about what happens if the
configuration of the zone ID is not consistent across the zone. Is it
as simple as you ending up with two zones?
[HC]: When the configuration of the zone ID is not consistent across
      the zone, some unexpected results will be generated.
      For example, when two different zone IDs are configured
      for the zone, two virtual nodes for two zones may be seen
      in the network. These are not expected. Once the unexpected
      results are seen, the inconsistent configurations MUST be fixed.

What is the scope of uniqueness of the zone ID? I think it only has to be
unique in the zone and with the neighbors. Obviously there are ways to
make this safe (such as area or global uniqueness). What are the
constraints?
[HC]: Added some constraints.
A zone ID MUST be unique in an AS. It MUST not be any IP address
in the AS from which a system ID is transformed to and used.

---

6.2

   When receiving
   the command, the node distributes it to every zone node.

Is this in the management plane or in IS-IS? I can see how it could be
in IS-IS if the configured node is the zone leader and it just starts
sending the zone TLV and all of the edge nodes are identified in
sub-TLVs such that a receiving node is either an edge or an internal
node. But I don't see how it works if the configured node is just some
internal or edge node and the leader has to be elected.

Similarly...
   If automatic transferring zone to node is enabled, the user does not
   need to issue the command.  A zone node, such as the zone leader,
   will distribute the "command" to every zone node after determining
   that the configuration of the zone has been finished.
...what is the command and how is it distributed?

Same sort of issues in 6.3
[HC]: Updated the related text and referred to Section 5.1.

---

Section 7 is a bit suspect! What would happen if a zone TLV was sent by
a compromised router or added to an LSP by a mid-wire attacker? I would
be sympathetic to you saying that if an attacker can do either of these
things then there are many far worse things they can do, but I think you
should call out:
- what sort of attacks are possible
- what damage they might do
- how these attacks might be detected
- what protections are available (references would be enough)
[HC]: Added text for this.

---

Section 8

   Under the registry name "IS-IS TLV Codepoints", IANA is requested to
   assign a new registry type for Zone ID as follows:

I think...

   IANA is requested to make a new allocation in the "IS-IS TLV
   Codepoint Registry" under the registry name "IS-IS TLV Codepoints"
   as follows:
[HC]: Updated the text as you suggested.

---

Section 8

I recommend you tell IANA whether you want the new TLV type to be less
than or greater than 255.
[HC]: Added some text for this.

---

Section 8

   IANA is requested to create a new sub-registry "Adjacent Node ID Sub-
   TLVs" on the IANA IS-IS TLV Codepoints web page as follows:

I recommend you call the new sub-registry "Sub-TLVs for TLV type TBD1
(Zone ID TLV)"
[HC]: Updated the text accordingly.