Thankz, Duzongpeng,

inline:

On Wed, Jun 07, 2017 at 06:33:58AM +0000, Duzongpeng wrote:
> Hi, Toerless
> 
>       Thanks for the review and suggestions.
> 
>       Some personal opinions to share. Please correct me if any 
> misunderstanding.
> 
>       1. The description about the relationship between DHCP PD and ANIMA 
> prefix-management mechanism is ambiguous. 
>       
>       I agree with Brian's suggestion about deleting the PD issue from this 
> document. 
>
>       It is a realization problem and deleting it will not cause too much 
> misunderstanding. 

Instead of deletion it might be more helpful to write text that explains as i 
did in
my review how RFC3633 is meant for interdomain (administative boundary) 
operation and
that the GRASP/ANI based approach is intra-domain and therefore could even be a 
great
complement to DHCPv6 - and not replace it.

>       IMO, to talk too much about the details is not the document's purpose, 
> i.e., validation of the designation of autonomic networking infrastructure.

Not sure what specific change proposal that refers to.

>       2. A node model containing "requested_prefix_length" and 
> "assigned_prefix_length" is propsoed, while in current document we only have 
> a prefix_length for the node.
> 
>       I think the problem is shortage of description of the whole structure, 
> or a clear example. It causes the reader hard to image the mechanism.
>       We need make it clear about the main mechanism, for example, adding 
> some topology pictures and TLA descriptions as suggested. 

Thanks.

>       3. It is suggested to add more abbreviation explanations and a picture 
> about 6.1 (the IPRAN example section)
> 
>       Agree.
> 
>       4. It is suggested that we should not go through all that detail work 
> because that is easier done by first building prototypes. Also, you have 
> proposed a paragraph of introduction:
> 
>         This document is not a functional specification of the proposed 
> autonomic function
>   "prefix management" or all detail all the aspects of GRASP objective 
> parameters and ASA procedures
>   necessary to achieve all the different options of building a complete 
> system. Instead it
>   describes the ***architectural framework*** utilizing the components of the 
> ANI and outlines the
>   different deployment options and aspects and defines simple type of 
> objectives in GRASP to
>   start building the system as well as some basic parameter examples.
> 
>       Agree. But as suggested by Brian, ***architectural framework*** perhaps 
> is not very proper here. 
>       I suggest some other word here, such as "initial realization" or 
> "prototype system". Is it OK?

Well, Brian is a native english speaker so i'd happily defer to his selection 
of words.

To me "architectural framework is always the best lame excuse for providing an 
overview and 
then NOT go into details. Just enough to feel safe that it can be built and 
will deliver
the claimed benefits. "initiaial realization" or "prototype" sounds to me as if 
a lot more details would have to be worked out.

>       5. You suggest that add some texts about the abstract deployment 
> pictures / solution overview
>       Including:
> 
>       5.1. Address & Prefix management with DHCP
>       5.2 Prefix management with ANI/GRASP
> 
>       I agree that we need to add some mechanism descriptions to make the 
> reader more easily catch the main point about the mechanism.
>       However, although it may be helpful, I do not suggest describing too 
> much about the DHCP mechanism in this document.
> 
>       I suggest focusing on the main mechanism about ANIMA prefix-management 
> and adding more details about it.
>       If it can solve the problem of ambiguity, we do not need to add too 
> much contents about other detailed descriptions in this document.
> 
>       On the other side, I agree with the proposed solution architecture, and 
> I think it should be able to work. 
>       If it is agreed that to add all the texts is necessary, i.e., it is 
> worthwhile to explain the multiple solutions in the document, I am ok with it.

So, the DHCP text i proposed has two purposes:

a) It is meant to justify paragraph 2 of section 3 (problem statement).
b) It is meant to show how the proposed picture/solution with PD could fill in 
exactly
   the not well defined/working pieces of one of the DHCP pictures.

Aka: Mayve lets wait with the DHCP texts for when Brian has time (after getting 
through GRASP),
so that we can understand his best insight and then finalize that part of the 
discussion.

Cheers
    Toerless

> 
> Best Regards
> Zongpeng Du
> 
> -----Original Message-----
> From: Toerless Eckert [mailto:[email protected]] 
> Sent: Wednesday, June 07, 2017 8:11 AM
> To: [email protected]; [email protected]
> Subject: [draft-ietf-anima-prefix-management-03] review
> 
> [darn, second mail header typo on my side. sorry.]
> 
> Dear authors
> 
> Some feedback for the PD draft:
> 
> 1. Relationship to DHCPv6 PD:
> 
> The note in 4.3 makes it sound as if there is a concern by the authors that 
> this proposal could potentially be seen as being in conflict with DHCPv6.
> 
> I am not sure about a practical case where this case would ever be a concern. 
> If the authors can think of such a case, then it would be good to add 
> sentences explaining that case. Otherwise maybe revisit this concern. IMHO 
> ANIMA-PD could nicely integrate/expand DHCP-PD:
> 
> RFC3633 (DHCPv6 PD) abstract says: "..delegating a long- lived prefix from a 
> delegating router to a requesting router, across an administrative boundary.."
>                                          ^^^^^^^^^^^^^^^^^^^^^^^ To validate 
> the ANI, IMHO we just need to show how to use GRASP within a domain, eg: not 
> across an administrative boundary. == no overlap with the declared intended 
> use of DHCPv6 PD. Instead i could rather see ANI/GRASP used inside the domain 
> and then DHCP/DHCPv6-PD be used on the edge of the domain to client (non-ANI 
> devices).
> 
> 2. Prefix Management Parameters
> 
> I do not understand from the text what prefix length is described in 6.1. 
> Maybe i am misunderstanding how the proposed PD mechanism should work, but in 
> my understanding, a device has at least TWO type of prefixes:
> 
>        GRASP/(+DHCP-PD)   +---------+
>          requested        | router  |  ------    Interfaces with assigned 
> prefixes
>       <-----------------> |  with   |  ...       "Assigned prefix-length 
> 'APL'"
>          prefix-length    | PM-ASA  |  ------    or
>            'RPL'          +---------+            GRASP/DHCP-PD requests via 
> downstream PM-ASA
> 
> If RPL == APL, then there is no prefix aggregation. This may be acceptable 
> (==scale well enough) at GRASP/DHCP-PD signaling level. If thats what the 
> authors have in mind then that should be written explicitly.
> 
> Note that if RPL == APL, then this will result in more prefixes at the 
> routing level because all APLs can be from different prefixes and may not be 
> aggregateable. IMHO, achieving aggregation and managing that via PM-ASA would 
> be a big benefit of PM-ASA.
> 
> Aka: If the document intends to support RPL < APL, then that should be better 
> described. For example, section 6.1 could for each role have simply those two 
> parameters (requested_prefix_length,
> assigned_prefix_length):
> 
> [
>       [["role", "RSG"],["requested_prefix_length", 34], 
> ["assigned_prefix_length", 56] ],
>       [["role", "ASG"],["requested_prefix_length", 44], 
> ["assigned_prefix_length", 64] ],
>       [["role", "CSG"],["requested_prefix_length", 56], 
> ["assigned_prefix_length", 64] ] ]
> 
> Thre assigned_prefix_length is of course most important if the downstream is 
> an interface where the router with PM-ASA needs to configure the prefix and 
> the addresses are assigned by SLAAC or DHCP from the router itself. If the 
> downstream is not a local interface but requests from PM-ASA, then the prefix 
> can be determined by the  downstream PM-ASA. 
> 
> 3. Mobile network roles
> 
> section 6.1: Please expand (in parenthesis) the abbreviations you use on 
> first use, eg:
> IPRAN, RNC in section 6.1. Please check any other unexplained TLAs in the 
> document.
> 
> A good picture with RSG, ASG, CSG would be great and help. Especially if you 
> want to take the prior suggestion into account of what prefix length would be 
> required in which role device.
> 
> 4. If you read the point 5 below, i think there are a lot of options how PDs 
> with ASAs can be done.
> All of these options would require further details such as more GRASP 
> objective parameters, more description of the ASA state machinery, the 
> individual GRASP negotiation steps etc.
> I do not think we want to go through all that detail work because that is 
> IMHO easier done by first building prototypes, and instead having the 
> document rather be a "framework" or "architecture document instead of an ASA 
> functional specification. To that end, it would IMHO be  prudent to say so, 
> for example before the last two paragraphs of the introduction:
> 
> proposed text, as 3rd last paragraph of introduction:
> 
>   This document is not a functional specification of the proposed autonomic 
> function
>   "prefix management" or all detail all the aspects of GRASP objective 
> parameters and ASA procedures
>   necessary to achieve all the different options of building a complete 
> system. Instead it
>   describes the architectural framework utilizing the components of the ANI 
> and outlines the
>   different deployment options and aspects and defines simple type of 
> objectives in GRASP to
>   start building the system as well as some basic parameter examples.
> 
> 5. Abstract deployment pictures / solution overview:
> 
> I think it would help in understanding the document if it would include a 
> logical deployment model pictures with explanations of the target deployment 
> models. Ideally comparing to how this is done with DHCP.
> 
> For example: In the introduction, there are some high level, very suggestive 
> statements about limitations of DHCP (non-autonomicity). Its really hard to 
> detail why/how the PD solution improves over this without a more explicit 
> comparison of some DHCP deployment model example and a PD deployment model 
> example.
> 
> So, i have appended two proposed texts: 5.1 for what i understand to be the 
> two most common DHCP deployment models, and 5.2 for what i understand to be 
> the proposed PD deployment model.
> 
> I would strongly suggest to consider using 5.2 in the document - or something 
> equivalent.
> Otherwise its IMHO hard to follow / understand how PD is meant to work.
> 
> Brian Carpenter already proved the feedback that a section like 5.1 might be 
> contentuous and also incomplete because centralized address management has a 
> wide range of options not only limited to DHCP but also involving Radius and 
> other protocols - and there is even a whole working group in the making (CASM 
> - coordinated address space management).
> 
> So maybe my proposed 5.1 would better go into an appended with sufficient 
> preface stating exactly that these are just examples, and that there are many 
> more deployment models, and that there are no current IETF recommendations or 
> documents laying out such complete deployment pictures. (which IMHO is 
> exactly one of the may problems). If folks feel that any more explicit 
> description of even exemplary DHCP deployment models is inappropriate because 
> it would get too contentuous, then its almost impossible to make statements 
> about the limitations about DHCP in the introduction. But without trying to 
> give an example and getting backpressure from reviewers, its IMHO a dead 
> end:wq
> 
> 
> 5.1. Address & Prefix management with DHCP
> 
>                                                               edge
>                     dynamic, "netconf/YANG"                 interfaces
>                      <----------------->   +-------------+
>    +-------------+      <- telemetry       | edge router/|+   ------  
> +--------+
>    |config server|    ..... Domain ....    | DHCP server ||   ...     | CPE   
>  |-+   LANs
>    +-------------+                         +-------------+|   ------  
> +--------+ | (----| )
>                                             +-------------+   DHCP/    
> +---------+
>                                                             DHCPv6 / PD
> 
> Edge DHCP server deployment requires every edge router connecting to CPE to 
> be a DHCP server assigning IPv4/IPv6 addresses to CPE - and optionally IPv6 
> prefixes via DHCPv6-PD (RF3633) for IPv6 capable CPE that are router and have 
> LANs behind them.
> 
> This requires various coordination functions via some backend system depicted 
> as "config server": The address prefixes on the edge interfaces should be 
> slightly larger than required for the number of CPE connected so that the 
> overall address space is best used.
> The config server needs to provision edge interface address prefixes and DHCP 
> parameters for every edge router.  If too fine grained prefixes are used, 
> this will result in large routing tables across the "Domain". If too coase 
> grained prefixes are used, address space is wasted.
> 
> There is no standard describing algorithms for how config servers would best 
> perform this ongoing dynamic provisioning to optimize routing table size and 
> address space utilization.
> There are currently no complete YANG models that a config server could use to 
> perform these actions (including telemetry of assigned adddresses from such 
> distributed DHCP servers).
> For example, a YANG model for controlling DHCP server operations is still in 
> draft (draft-liu-dhc-dhcp-yang-model-06).
> 
> Due to these and other problems of the above model, the more common DHCP 
> deployment model is as
> follows:
> 
>                                                               edge
>    +-------------+     initial, "CLI"                       interfaces
>    |config server|   ----------------->    +-------------+
>    +-------------+                         | edge router/|-+   ------  
> +--------+
>          |            ..... Domain ....    | DHCP relay  | |   ...     | CPE  
>   |-+    LANs
>    +-------------+                         +-------------+ |   ------  
> +--------+ | (----|  )
>    |DHCP server  |                          +--------------+   DHCP/    
> +---------+
>    +-------------+                                            DHCPv6 / PD
> 
> 
> Dynamic provisioning changes to edge routers are avoided by using a central 
> DHCP server and reducing the edge router from DHCP server to DHCP relay. The 
> "configuration" on the edge routers is static, the DHCP relay function 
> inserts "edge interface" and/or subscriber identifying options into DHCP 
> requests from CPE (eg: rfc3046, rfc6221), the DHCP server has complete 
> policies for address assignments and prefixes useable on every 
> edge-router/interface/subscriber-group. When the DHCP relay sees the DHCP 
> reply, it inserts static routes for the assigned address/address-prefix into 
> the routing table of the edge router which are then to be distributed by the 
> IGP (or BGP) inside the domain to make the CPE and LANs reachable across the 
> Domain (the same.
> 
> There is no comprehensive standardization of these solutions. RFC3633 section 
> 14. for example simply refers to "a [non-defined] protocol or other 
> out-of-band communication to add routing information for delegated prefixes 
> into the provider edge router".
> 
> 5.2 Prefix management with ANI/GRASP
> 
> With the proposed use of ANI and Prefix-management ASAs using GRASP, the 
> deployment model is intended to look as follows: 
> 
>   |<................... ANI Domain / ACP...................>| (...) 
> ............->
> 
>                                               Roles
>                                                 |
>                                                 v   "Edge routers"
>      GRASP parameter                      +----------------+
>      Network wide parameters/policy       | PM-ASA         |  downstream 
> interfaces
>          |                                |(DHCP-functions)|  ------
>          v  "central device"              +----------------+
>    +-------+                                    ^                      
> +--------+
>    |PM-ASA |      <................... GRASP ....             ....     | CPE  
>   |-+  ( LANs )
>    +-------+              .                     v                      
> |(PM-ASA)| |    ----|  
>         .               +........+        +----------------+           
> +--------+ | 
>    +...........+        . PM-ASA .        |     PM-ASA     |  ------    
> +---------+
>    .DHCP server.        +........+        |(DHCP-functions)|  SLAAC /
>    +...........+     "intermediate router"+----------------+  DHCP / DHCP-pd
> 
> 
> The network runs an ANI domain with ACP between some central device (eg: 
> router or ANI enabled management device) and the edge routers. ANI/ACP 
> provides a secure, zero-touch communication channel between the devices and 
> enables the use of GRASP not only for p2p communication, but also for 
> distribution/flooding.
> 
> The central devices and edge-routers run software to support this documents 
> autonomic
> IPv6 edge prefix management (PM). In the autonomic networking terminology, 
> such software are called "Autonomic Service Agents" (ASA). The ASA for Prefix 
> Management are called PM-ASA in this document and form together the Autonomic 
> Prefix Management Function.
> 
> Edge-routers can have different roles based on the type and number of CPE 
> attaching to them.
> Consider edge routers could be RSG, ASG CSG in mobile aggregation networks 
> (see Section 6.1).
> Mechanisms outside the scope of this document make routers aware of their 
> role.
> 
> 1. In a minimum Prefix Managmeent solution, the central device uses the 
> "PrefixManager.Params"
> GRASP Objective introduced in this document to disseminate network wide, 
> per-role parameters to edge routers. The PM-ASA use the parameters applying 
> to its role to locallly "configuring"
> pre-existing addressing functions. Because PM-ASA do not manage the dynamic 
> assignment of actual
> IPv6 address prefixes in this case, the following options can be considered:
> 
> 1.a The edge router connects via downstream interfaces to (host) CPE that 
> each require an address.
> The PM-ASA sets up for each such interface a DHCP requesting router 
> (according to RFC3633) to request an IPv6 prefix for the interface. The 
> routers address on the downstream interface can be another parameter from the 
> GRASP Objective. The CPEs assign addresses in the prefix via RAs from the 
> router or the PM-ASA manages a local DHCPv6 server to assign addresses to the 
> CPEs. A central DHCP server acting as the DHCP delegating router (according 
> to RFC3633) is required. Its address can be another parameter from the GRASP 
> Objective.
> 
> 1.b The edge router also connects via downstream interfaces to (customer 
> managed) CPEs that are routers and act as DHCPv6 requesting routers. The need 
> to support this could be derived from role and/or GRASP parameters and the 
> PM-ASA sets up a DHCP relay function to pass on requests to the central DHCP 
> server as in 1.a.
> 
> 2. In a solution without a central DHCP server, the PM-ASA on the edge 
> routers do not only learn parameters from "PrefixManager.Params" but also 
> utilize GRASP to request/negotiate actual IPv6 prefix delegation via the 
> GRASP "PrefixManager" objective described in more detail below.
> In the most simple case, these prefixes are delegated via this GRASP 
> objective from the PM-ASA in the central device.  These addresses are then 
> used by the PM-ASA on the edge routers to edge routers to configure prefixes 
> on their downstream interfaces to assign addresses via RA/SLAAC to host CPEs. 
> The PM-ASA may also start local DHCP servers (as in 1.a) to assign addresses 
> via DHCP to CPE from the prefixes it received. This includes both host CPEs 
> requesting
> IPv6 addresses as well as router CPEs that request IPv6 prefixes. The PM-ASA 
> needs to manage the address pool(s) it has requested via GRASP and allocate 
> sub-address pools to interfaces and the local DHCP servers it starts. It need 
> to monitor the address utilization and accordingly request more address 
> prefixes if its existing prefixes are exhausted, or return address prefixes 
> when they are unneeded.
> 
> This solution is quite similar to the initial described IPv6 DHCP deployment 
> model without central DHCP server, and ANI/ACP/GRASP and the PM-ASA do 
> provides the automation to make this approach work more easily than it is 
> possible today.
> 
> 3. The address pool(s) from which prefixes are allocated do not need to be 
> taken all from one central location. Edge router PM-ASA that received a big 
> (short) prefix from a central PM-ASA could offer smaller sub-prefixes to 
> neighboring edge-router PM-ASA. GRASP could be used in such a way that the 
> PM-ASA would find and select the objective from the closest neighboring 
> PM-ASA, therefore allowing to maximize aggregation: A PM-ASA would only 
> request further
> (smaller/shorter) prefixes when it exhausts its own poll (from the central 
> location) and can not get further large prefixes from that central location 
> anymore. Because the overflow prefixes taken from a topological nearby 
> PM-ASA, the number of longer prefixes that have to be injected into the 
> routing tables is limited and the topological proximity increases the chances 
> that aggregation of prefixes in the IGP can most likely limit the geography 
> in which the longer prefixes need to be routed. 
> 
> 4. Instead of peer-to-peer optimization of prefix delegation, a hierarchy of 
> PM-ASA can be built (indicated in he picture via a dotted intermediate 
> router). This would require additional parameters to the "PrefixManager" 
> objective to allow creating a hierarchy of PM-ASA across which the prefixes 
> can be delegated. This is not detailed further below.
> 
> 5.  In cases where CPEs are also part of the ANI Domain (eg: "Managed CPE"), 
> then GRASP will extend into the actual customer sites and can equally run a 
> PM-ASA. All the options described in points
> 1..4 above would then apply to the CPE as the edge router with the mayor 
> changes being that
> a) a CPE router will most likley not need to run DHCPv6 PD itself, but only 
> DHCP address assignment,
> b) The edge routers to which the CPE connect would most likely become ideal 
> places to run a hierarchical instance of PD-ASAs on as outlined in point 1.

-- 
---
[email protected]

_______________________________________________
Anima mailing list
[email protected]
https://www.ietf.org/mailman/listinfo/anima

Reply via email to