Discussion:
[alto] Comments on the Path-Vector draft during IETF 102
Qiao Xiang
2018-08-07 20:48:41 UTC
Permalink
Dear authors of the PV draft and the ALTO WG members,

Before and during IETF 102, I raised a couple of issues about the path
vector draft: (1) why we use a vector of abstract network element (ANE)?
and (2) update the current PV design to support multicast/multicast. It was
suggested during IETF 102 that we move this discussion to the mailing list.
Hence the following are my opinions in detail:

*1. The design choice of using "array/sequence/list of abstract network
elements (ANEs)".*

We all know that the concept "path vector" in this draft was highly
motivated by BGP, a path-vector interdomain routing protocol. In BGP, a
path vector encodes an AS path, which provides the semantics that to reach
a destination IP prefix, which ASes will be traversed in what "order". The
AS-path vector has semantics: (1) the first one in the vector is the
neighbor AS providing this route, (2) the last one is the destination AS
providing the destination IP prefix, (3) The ASes in between help provide
information about inter-AS connectivity. In contrast, a path vector in ALTO
is an ANE-path. What semantics does it have? In order words, why does the
order of ANEs matter? One may argue that it may help provide information
like "a flow will pass through a firewall middlebox before entering a DPI
middlebox", but why would a network operator want to provide such detailed
private information to the application? Is there a strong, reasonable use
case?

In Danny's multi-domain broker draft tries to use the PV extension to
provide the AS-path information for different NFs. This may be a strong
case to use the array of ANEs, instead of a set of ANEs, in the PV draft.
However, such information is already provided by BGP and will be the source
of an ALTO server getting such information, why is ALTO better than BGP at
providing such information?

I see 3 ways that we can proceed:

(1) we keep the current design, and provide strong use cases in the draft
to justify "array of ANEs" is necessary, and explicitly state that the
application MUST recognize that the returned array of ANEs MAY be
unordered;
(2) we keep the current design, do not provide strong use cases to justify
this design, but explicitly state that the server MAY return the array of
ANEs unordered;
(3) we change the design from "array of ANEs" to "set of ANEs" (i.e., cost
mode changed from "array" to "set"). Given that all specifications in ALTO
are specified using JSON format, which does not have a concept called
"set", this design choice may seem a bit strange. However, I believe that
we should not let the specification language used by the WG affect the
semantics of the design.

*2. Handling multipath (and potentially multicast).*

The current PV design does not handle multipath routing or multicast. Per
suggestion from Richard, I took a look at how BGP handles multipath, given
that PV was highly motivated by BGP. I found RFC7911 ("Advertisement of
Multiple Paths in BGP") provides the solution. And the basic idea is very
simple: in BGP announcement, assigning an ID (path identifier) to the
route. This motivates me to propose the following design to let the PV
extension support multipath.

Consider a source-destination pair (a flow), its route (no matter
single-path route or multipath route) is essentially a set of route
segments. When the ALTO client submits a PV query about this flow to the
ALTO server. Instead of returning an array of ANEs, the ALO server returns
a set of arrays of ANEs, where each array represents a route segment in the
route of this flow and is assigned a unique ID. These IDs are also sent to
the ALTO client. In addition to the property map of all ANEs used in these
route segments, the ALTO server also sends another property map of all
route segments, where the property is "traffic load percentage".

I intended to talk about this design during the IETF 102 meeting, however,
given my unstable internet connection, I had to omit this part. Slide 4-6
in the attached presentation illustrates this design with an example. I
believe this design perfectly provides accurate, compact information of
resource sharing in multipath routing. It can also handle the resource
sharing defined by TE policies, and can potentially provide such
information in multicast, provided that the query format supports a query
on multicast flow.

What do you think about these two issues? It would be great to hear the
opinion from not only the authors, but also other WG members. If they are
reasonable to most of you, may I suggest integrating them into the next
version of the PV draft? Thank you very much.


Best wishes
Qiao Xiang
--
Qiao Xiang
Postdoctoral Fellow,
Department of Computer Science,
Yale University
Dawn Chen
2018-08-15 12:28:50 UTC
Permalink
Hi Qiao,

I have some points for the two issues.

1. The design choice of using "array/sequence/list of abstract network elements (ANEs)".

BGP is one of the motivations for "path-vector". But the path vector document has mentioned another motivation that is the bottlenecks between different flows. Actually, I do not think the order of the ANEs matters. Array is only a data type to encode such information in JSON. So I would prefer the first solution: To justify "array of ANEs" is necessary, and explicitly state that the application MUST recognize that the returned array of ANEs MAY be unordered.

2. Handling multipath (and potentially multicast).

The design mentioned in the slides might introduce a more complex dependency relationships. It will be considered in the following design.

Thanks
Dawn

________________________________________
From: alto <alto-***@ietf.org> on behalf of Qiao Xiang <***@gmail.com>
Sent: Wednesday, August 8, 2018 4:48 AM
To: IETF ALTO
Subject: [alto] Comments on the Path-Vector draft during IETF 102

Dear authors of the PV draft and the ALTO WG members,

Before and during IETF 102, I raised a couple of issues about the path vector draft: (1) why we use a vector of abstract network element (ANE)? and (2) update the current PV design to support multicast/multicast. It was suggested during IETF 102 that we move this discussion to the mailing list. Hence the following are my opinions in detail:

1. The design choice of using "array/sequence/list of abstract network elements (ANEs)".

We all know that the concept "path vector" in this draft was highly motivated by BGP, a path-vector interdomain routing protocol. In BGP, a path vector encodes an AS path, which provides the semantics that to reach a destination IP prefix, which ASes will be traversed in what "order". The AS-path vector has semantics: (1) the first one in the vector is the neighbor AS providing this route, (2) the last one is the destination AS providing the destination IP prefix, (3) The ASes in between help provide information about inter-AS connectivity. In contrast, a path vector in ALTO is an ANE-path. What semantics does it have? In order words, why does the order of ANEs matter? One may argue that it may help provide information like "a flow will pass through a firewall middlebox before entering a DPI middlebox", but why would a network operator want to provide such detailed private information to the application? Is there a strong, reasonable use case?

In Danny's multi-domain broker draft tries to use the PV extension to provide the AS-path information for different NFs. This may be a strong case to use the array of ANEs, instead of a set of ANEs, in the PV draft. However, such information is already provided by BGP and will be the source of an ALTO server getting such information, why is ALTO better than BGP at providing such information?

I see 3 ways that we can proceed:

(1) we keep the current design, and provide strong use cases in the draft to justify "array of ANEs" is necessary, and explicitly state that the application MUST recognize that the returned array of ANEs MAY be unordered;
(2) we keep the current design, do not provide strong use cases to justify this design, but explicitly state that the server MAY return the array of ANEs unordered;
(3) we change the design from "array of ANEs" to "set of ANEs" (i.e., cost mode changed from "array" to "set"). Given that all specifications in ALTO are specified using JSON format, which does not have a concept called "set", this design choice may seem a bit strange. However, I believe that we should not let the specification language used by the WG affect the semantics of the design.

2. Handling multipath (and potentially multicast).

The current PV design does not handle multipath routing or multicast. Per suggestion from Richard, I took a look at how BGP handles multipath, given that PV was highly motivated by BGP. I found RFC7911 ("Advertisement of Multiple Paths in BGP") provides the solution. And the basic idea is very simple: in BGP announcement, assigning an ID (path identifier) to the route. This motivates me to propose the following design to let the PV extension support multipath.

Consider a source-destination pair (a flow), its route (no matter single-path route or multipath route) is essentially a set of route segments. When the ALTO client submits a PV query about this flow to the ALTO server. Instead of returning an array of ANEs, the ALO server returns a set of arrays of ANEs, where each array represents a route segment in the route of this flow and is assigned a unique ID. These IDs are also sent to the ALTO client. In addition to the property map of all ANEs used in these route segments, the ALTO server also sends another property map of all route segments, where the property is "traffic load percentage".

I intended to talk about this design during the IETF 102 meeting, however, given my unstable internet connection, I had to omit this part. Slide 4-6 in the attached presentation illustrates this design with an example. I believe this design perfectly provides accurate, compact information of resource sharing in multipath routing. It can also handle the resource sharing defined by TE policies, and can potentially provide such information in multicast, provided that the query format supports a query on multicast flow.

What do you think about these two issues? It would be great to hear the opinion from not only the authors, but also other WG members. If they are reasonable to most of you, may I suggest integrating them into the next version of the PV draft? Thank you very much.


Best wishes
Qiao Xiang
--
Qiao Xiang
Postdoctoral Fellow,
Department of Computer Science,
Yale University
Dawn Chen
2018-08-20 02:05:15 UTC
Permalink
Hi Qiao,

For the second issue Handling multipath, I would think it is a general problem not specific to path vector. Actually, base ALTO protocol also has such problem. Current base ALTO protocol only has one cost value between a source-destination pair. Similar to base ALTO protocol, multi-cost, cost calendar also adopt such setting. So, instead of considering multipath in path vector, I suggest that the multipath consideration can be a general consideration that will include base ALTO protocol, multi-cost… if possible.

Thanks,
Dawn

________________________________________
From: alto <alto-***@ietf.org> on behalf of Qiao Xiang <***@gmail.com>
Sent: Wednesday, August 8, 2018 4:48 AM
To: IETF ALTO
Subject: [alto] Comments on the Path-Vector draft during IETF 102

Dear authors of the PV draft and the ALTO WG members,

Before and during IETF 102, I raised a couple of issues about the path vector draft: (1) why we use a vector of abstract network element (ANE)? and (2) update the current PV design to support multicast/multicast. It was suggested during IETF 102 that we move this discussion to the mailing list. Hence the following are my opinions in detail:

1. The design choice of using "array/sequence/list of abstract network elements (ANEs)".

We all know that the concept "path vector" in this draft was highly motivated by BGP, a path-vector interdomain routing protocol. In BGP, a path vector encodes an AS path, which provides the semantics that to reach a destination IP prefix, which ASes will be traversed in what "order". The AS-path vector has semantics: (1) the first one in the vector is the neighbor AS providing this route, (2) the last one is the destination AS providing the destination IP prefix, (3) The ASes in between help provide information about inter-AS connectivity. In contrast, a path vector in ALTO is an ANE-path. What semantics does it have? In order words, why does the order of ANEs matter? One may argue that it may help provide information like "a flow will pass through a firewall middlebox before entering a DPI middlebox", but why would a network operator want to provide such detailed private information to the application? Is there a strong, reasonable use case?

In Danny's multi-domain broker draft tries to use the PV extension to provide the AS-path information for different NFs. This may be a strong case to use the array of ANEs, instead of a set of ANEs, in the PV draft. However, such information is already provided by BGP and will be the source of an ALTO server getting such information, why is ALTO better than BGP at providing such information?

I see 3 ways that we can proceed:

(1) we keep the current design, and provide strong use cases in the draft to justify "array of ANEs" is necessary, and explicitly state that the application MUST recognize that the returned array of ANEs MAY be unordered;
(2) we keep the current design, do not provide strong use cases to justify this design, but explicitly state that the server MAY return the array of ANEs unordered;
(3) we change the design from "array of ANEs" to "set of ANEs" (i.e., cost mode changed from "array" to "set"). Given that all specifications in ALTO are specified using JSON format, which does not have a concept called "set", this design choice may seem a bit strange. However, I believe that we should not let the specification language used by the WG affect the semantics of the design.

2. Handling multipath (and potentially multicast).

The current PV design does not handle multipath routing or multicast. Per suggestion from Richard, I took a look at how BGP handles multipath, given that PV was highly motivated by BGP. I found RFC7911 ("Advertisement of Multiple Paths in BGP") provides the solution. And the basic idea is very simple: in BGP announcement, assigning an ID (path identifier) to the route. This motivates me to propose the following design to let the PV extension support multipath.

Consider a source-destination pair (a flow), its route (no matter single-path route or multipath route) is essentially a set of route segments. When the ALTO client submits a PV query about this flow to the ALTO server. Instead of returning an array of ANEs, the ALO server returns a set of arrays of ANEs, where each array represents a route segment in the route of this flow and is assigned a unique ID. These IDs are also sent to the ALTO client. In addition to the property map of all ANEs used in these route segments, the ALTO server also sends another property map of all route segments, where the property is "traffic load percentage".

I intended to talk about this design during the IETF 102 meeting, however, given my unstable internet connection, I had to omit this part. Slide 4-6 in the attached presentation illustrates this design with an example. I believe this design perfectly provides accurate, compact information of resource sharing in multipath routing. It can also handle the resource sharing defined by TE policies, and can potentially provide such information in multicast, provided that the query format supports a query on multicast flow.

What do you think about these two issues? It would be great to hear the opinion from not only the authors, but also other WG members. If they are reasonable to most of you, may I suggest integrating them into the next version of the PV draft? Thank you very much.


Best wishes
Qiao Xiang
--
Qiao Xiang
Postdoctoral Fellow,
Department of Computer Science,
Yale University
Qiao Xiang
2018-08-20 07:02:43 UTC
Permalink
Hi Dawn,

Thanks for clarifying it. It seems that you are referring to multicast,
where one source has multiple destinations?

In multipath routing, the traffic is still from one source to one
destination, only with different portions of the whole traffic are
forwarded along different paths. So the cost is still "one value" (where
this value is a path vector). With the one-source-one-destination paradigm,
the ALTO base protocol can still support it with ECS/Cost map, and other
extensions, right?

In my proposal, regardless of multipath/multicast, the cost is still "one
value", where this value is a set/vector of route segments (same as path
vectors). So the problem you just described does not exist, right? To
support multicast, the query specifications of ECS/Cost map need to be
changed to allow the one-source-multiple-destination query, but I think
it's also doable.

Do I understand your concern correctly? Or you are referring to other
issues? Thanks.



Best
Qiao
Post by Dawn Chen
Hi Qiao,
For the second issue Handling multipath, I would think it is a general
problem not specific to path vector. Actually, base ALTO protocol also has
such problem. Current base ALTO protocol only has one cost value between a
source-destination pair. Similar to base ALTO protocol, multi-cost, cost
calendar also adopt such setting. So, instead of considering multipath in
path vector, I suggest that the multipath consideration can be a general
consideration that will include base ALTO protocol, multi-cost
 if possible.
Thanks,
Dawn
________________________________________
Sent: Wednesday, August 8, 2018 4:48 AM
To: IETF ALTO
Subject: [alto] Comments on the Path-Vector draft during IETF 102
Dear authors of the PV draft and the ALTO WG members,
Before and during IETF 102, I raised a couple of issues about the path
vector draft: (1) why we use a vector of abstract network element (ANE)?
and (2) update the current PV design to support multicast/multicast. It was
suggested during IETF 102 that we move this discussion to the mailing list.
1. The design choice of using "array/sequence/list of abstract network elements (ANEs)".
We all know that the concept "path vector" in this draft was highly
motivated by BGP, a path-vector interdomain routing protocol. In BGP, a
path vector encodes an AS path, which provides the semantics that to reach
a destination IP prefix, which ASes will be traversed in what "order". The
AS-path vector has semantics: (1) the first one in the vector is the
neighbor AS providing this route, (2) the last one is the destination AS
providing the destination IP prefix, (3) The ASes in between help provide
information about inter-AS connectivity. In contrast, a path vector in ALTO
is an ANE-path. What semantics does it have? In order words, why does the
order of ANEs matter? One may argue that it may help provide information
like "a flow will pass through a firewall middlebox before entering a DPI
middlebox", but why would a network operator want to provide such detailed
private information to the application? Is there a strong, reasonable use
case?
In Danny's multi-domain broker draft tries to use the PV extension to
provide the AS-path information for different NFs. This may be a strong
case to use the array of ANEs, instead of a set of ANEs, in the PV draft.
However, such information is already provided by BGP and will be the source
of an ALTO server getting such information, why is ALTO better than BGP at
providing such information?
(1) we keep the current design, and provide strong use cases in the draft
to justify "array of ANEs" is necessary, and explicitly state that the
application MUST recognize that the returned array of ANEs MAY be unordered;
(2) we keep the current design, do not provide strong use cases to justify
this design, but explicitly state that the server MAY return the array of
ANEs unordered;
(3) we change the design from "array of ANEs" to "set of ANEs" (i.e., cost
mode changed from "array" to "set"). Given that all specifications in ALTO
are specified using JSON format, which does not have a concept called
"set", this design choice may seem a bit strange. However, I believe that
we should not let the specification language used by the WG affect the
semantics of the design.
2. Handling multipath (and potentially multicast).
The current PV design does not handle multipath routing or multicast. Per
suggestion from Richard, I took a look at how BGP handles multipath, given
that PV was highly motivated by BGP. I found RFC7911 ("Advertisement of
Multiple Paths in BGP") provides the solution. And the basic idea is very
simple: in BGP announcement, assigning an ID (path identifier) to the
route. This motivates me to propose the following design to let the PV
extension support multipath.
Consider a source-destination pair (a flow), its route (no matter
single-path route or multipath route) is essentially a set of route
segments. When the ALTO client submits a PV query about this flow to the
ALTO server. Instead of returning an array of ANEs, the ALO server returns
a set of arrays of ANEs, where each array represents a route segment in the
route of this flow and is assigned a unique ID. These IDs are also sent to
the ALTO client. In addition to the property map of all ANEs used in these
route segments, the ALTO server also sends another property map of all
route segments, where the property is "traffic load percentage".
I intended to talk about this design during the IETF 102 meeting, however,
given my unstable internet connection, I had to omit this part. Slide 4-6
in the attached presentation illustrates this design with an example. I
believe this design perfectly provides accurate, compact information of
resource sharing in multipath routing. It can also handle the resource
sharing defined by TE policies, and can potentially provide such
information in multicast, provided that the query format supports a query
on multicast flow.
What do you think about these two issues? It would be great to hear the
opinion from not only the authors, but also other WG members. If they are
reasonable to most of you, may I suggest integrating them into the next
version of the PV draft? Thank you very much.
Best wishes
Qiao Xiang
--
Qiao Xiang
Postdoctoral Fellow,
Department of Computer Science,
Yale University
--
Qiao Xiang
Postdoctoral Fellow,
Department of Computer Science,
Yale University
Danny Alex Lachos Perez
2018-08-21 20:38:31 UTC
Permalink
Hello Qiao,

See inline a quick comment about the AS-level path information at the
Broker-assisted architecture

In Danny's multi-domain broker draft tries to use the PV extension to
Post by Qiao Xiang
provide the AS-path information for different NFs. This may be a strong
case to use the array of ANEs, instead of a set of ANEs, in the PV draft.
However, such information is already provided by BGP and will be the source
of an ALTO server getting such information, why is ALTO better than BGP at
providing such information?
In multi-domain SFC/NFV scenarios, besides the AS-level topology (provided
by BGP, for instance) information, the provision of a complete E2E network
service needs resource (storage, storage, memory), network (bandwidth,
delay) and services (Virtual/physical Network Functions) information. The
current SG object proposed on the Broker-assisted draft is focused purely
on AS-level connectivity information between entities (e.g., SAP->NF,
NF->NF, etc.), following an ordered flow. However, the SG object is
conceived to support (extension or potential new ALTO service) additional
information (e.g., resource, network, service). This means the connectivity
information will be computed considering also such additional parameters.

Best regards,

Danny Lachos
Post by Qiao Xiang
Dear authors of the PV draft and the ALTO WG members,
Before and during IETF 102, I raised a couple of issues about the path
vector draft: (1) why we use a vector of abstract network element (ANE)?
and (2) update the current PV design to support multicast/multicast. It was
suggested during IETF 102 that we move this discussion to the mailing list.
*1. The design choice of using "array/sequence/list of abstract network
elements (ANEs)".*
We all know that the concept "path vector" in this draft was highly
motivated by BGP, a path-vector interdomain routing protocol. In BGP, a
path vector encodes an AS path, which provides the semantics that to reach
a destination IP prefix, which ASes will be traversed in what "order". The
AS-path vector has semantics: (1) the first one in the vector is the
neighbor AS providing this route, (2) the last one is the destination AS
providing the destination IP prefix, (3) The ASes in between help provide
information about inter-AS connectivity. In contrast, a path vector in ALTO
is an ANE-path. What semantics does it have? In order words, why does the
order of ANEs matter? One may argue that it may help provide information
like "a flow will pass through a firewall middlebox before entering a DPI
middlebox", but why would a network operator want to provide such detailed
private information to the application? Is there a strong, reasonable use
case?
In Danny's multi-domain broker draft tries to use the PV extension to
provide the AS-path information for different NFs. This may be a strong
case to use the array of ANEs, instead of a set of ANEs, in the PV draft.
However, such information is already provided by BGP and will be the source
of an ALTO server getting such information, why is ALTO better than BGP at
providing such information?
(1) we keep the current design, and provide strong use cases in the draft
to justify "array of ANEs" is necessary, and explicitly state that the
application MUST recognize that the returned array of ANEs MAY be
unordered;
(2) we keep the current design, do not provide strong use cases to justify
this design, but explicitly state that the server MAY return the array of
ANEs unordered;
(3) we change the design from "array of ANEs" to "set of ANEs" (i.e., cost
mode changed from "array" to "set"). Given that all specifications in ALTO
are specified using JSON format, which does not have a concept called
"set", this design choice may seem a bit strange. However, I believe that
we should not let the specification language used by the WG affect the
semantics of the design.
*2. Handling multipath (and potentially multicast).*
The current PV design does not handle multipath routing or multicast. Per
suggestion from Richard, I took a look at how BGP handles multipath, given
that PV was highly motivated by BGP. I found RFC7911 ("Advertisement of
Multiple Paths in BGP") provides the solution. And the basic idea is very
simple: in BGP announcement, assigning an ID (path identifier) to the
route. This motivates me to propose the following design to let the PV
extension support multipath.
Consider a source-destination pair (a flow), its route (no matter
single-path route or multipath route) is essentially a set of route
segments. When the ALTO client submits a PV query about this flow to the
ALTO server. Instead of returning an array of ANEs, the ALO server returns
a set of arrays of ANEs, where each array represents a route segment in the
route of this flow and is assigned a unique ID. These IDs are also sent to
the ALTO client. In addition to the property map of all ANEs used in these
route segments, the ALTO server also sends another property map of all
route segments, where the property is "traffic load percentage".
I intended to talk about this design during the IETF 102 meeting, however,
given my unstable internet connection, I had to omit this part. Slide 4-6
in the attached presentation illustrates this design with an example. I
believe this design perfectly provides accurate, compact information of
resource sharing in multipath routing. It can also handle the resource
sharing defined by TE policies, and can potentially provide such
information in multicast, provided that the query format supports a query
on multicast flow.
What do you think about these two issues? It would be great to hear the
opinion from not only the authors, but also other WG members. If they are
reasonable to most of you, may I suggest integrating them into the next
version of the PV draft? Thank you very much.
Best wishes
Qiao Xiang
--
Qiao Xiang
Postdoctoral Fellow,
Department of Computer Science,
Yale University
_______________________________________________
alto mailing list
https://www.ietf.org/mailman/listinfo/alto
Jensen Zhang
2018-08-22 10:25:41 UTC
Permalink
Hi all,

I’m glad to see your active discussion. Sorry for my late reply.

For the first issue, instead of pointing “array” MAY be unordered, I will
suggest we split ordered and unordered list into different cost modes. I
believe it will be more convinced. We already have a use case for the
unordered ane-path in Section 3 of the current path-vector document. We may
add another use case to motivate the ordered ane-path is also required.
(Still thinking about this.)

For the second issue, I believe Dawn proposed the multipath issue is a
general issue for all the cost services. Although multipath is still the
one-source-one-destination paradigm, it will have multiple costs for each
<source, destination> pair. So actually we can consider it as a general
proposal, not just for the path-vector extension. Considering the use case
only requiring the simple cost but still sensitive to multipath, the ALTO
server should also provide multipath cost in those cost metric. In this
sense, it is probably better to introduce multipath extension in another
document, rather than put it into the path-vector draft.

And of course, supporting such new cost schema will introduce more complex
ALTO resource dependency issue. But I think this issue comes from the
unified property (see my IETF102 slides for the alto-unified-properties
draft). When an ALTO resource has multiple dependent resources, there will
be some ambiguities for the client to resolve the dependencies. We have
noticed the resource dependency issue and try to solve the issue in the
unified property document.

Best,
Jensen

On Wed, Aug 22, 2018 at 4:38 AM Danny Alex Lachos Perez <
Post by Danny Alex Lachos Perez
Hello Qiao,
See inline a quick comment about the AS-level path information at the
Broker-assisted architecture
In Danny's multi-domain broker draft tries to use the PV extension to
Post by Qiao Xiang
provide the AS-path information for different NFs. This may be a strong
case to use the array of ANEs, instead of a set of ANEs, in the PV draft..
However, such information is already provided by BGP and will be the source
of an ALTO server getting such information, why is ALTO better than BGP at
providing such information?
In multi-domain SFC/NFV scenarios, besides the AS-level topology (provided
by BGP, for instance) information, the provision of a complete E2E network
service needs resource (storage, storage, memory), network (bandwidth,
delay) and services (Virtual/physical Network Functions) information. The
current SG object proposed on the Broker-assisted draft is focused purely
on AS-level connectivity information between entities (e.g., SAP->NF,
NF->NF, etc.), following an ordered flow. However, the SG object is
conceived to support (extension or potential new ALTO service) additional
information (e.g., resource, network, service). This means the connectivity
information will be computed considering also such additional parameters.
Best regards,
Danny Lachos
Post by Qiao Xiang
Dear authors of the PV draft and the ALTO WG members,
Before and during IETF 102, I raised a couple of issues about the path
vector draft: (1) why we use a vector of abstract network element (ANE)?
and (2) update the current PV design to support multicast/multicast. It was
suggested during IETF 102 that we move this discussion to the mailing list.
*1. The design choice of using "array/sequence/list of abstract network
elements (ANEs)".*
We all know that the concept "path vector" in this draft was highly
motivated by BGP, a path-vector interdomain routing protocol. In BGP, a
path vector encodes an AS path, which provides the semantics that to reach
a destination IP prefix, which ASes will be traversed in what "order". The
AS-path vector has semantics: (1) the first one in the vector is the
neighbor AS providing this route, (2) the last one is the destination AS
providing the destination IP prefix, (3) The ASes in between help provide
information about inter-AS connectivity. In contrast, a path vector in ALTO
is an ANE-path. What semantics does it have? In order words, why does the
order of ANEs matter? One may argue that it may help provide information
like "a flow will pass through a firewall middlebox before entering a DPI
middlebox", but why would a network operator want to provide such detailed
private information to the application? Is there a strong, reasonable use
case?
In Danny's multi-domain broker draft tries to use the PV extension to
provide the AS-path information for different NFs. This may be a strong
case to use the array of ANEs, instead of a set of ANEs, in the PV draft..
However, such information is already provided by BGP and will be the source
of an ALTO server getting such information, why is ALTO better than BGP at
providing such information?
(1) we keep the current design, and provide strong use cases in the draft
to justify "array of ANEs" is necessary, and explicitly state that the
application MUST recognize that the returned array of ANEs MAY be
unordered;
(2) we keep the current design, do not provide strong use cases to
justify this design, but explicitly state that the server MAY return the
array of ANEs unordered;
(3) we change the design from "array of ANEs" to "set of ANEs" (i.e.,
cost mode changed from "array" to "set"). Given that all specifications in
ALTO are specified using JSON format, which does not have a concept called
"set", this design choice may seem a bit strange. However, I believe that
we should not let the specification language used by the WG affect the
semantics of the design.
*2. Handling multipath (and potentially multicast).*
The current PV design does not handle multipath routing or multicast. Per
suggestion from Richard, I took a look at how BGP handles multipath, given
that PV was highly motivated by BGP. I found RFC7911 ("Advertisement of
Multiple Paths in BGP") provides the solution. And the basic idea is very
simple: in BGP announcement, assigning an ID (path identifier) to the
route. This motivates me to propose the following design to let the PV
extension support multipath.
Consider a source-destination pair (a flow), its route (no matter
single-path route or multipath route) is essentially a set of route
segments. When the ALTO client submits a PV query about this flow to the
ALTO server. Instead of returning an array of ANEs, the ALO server returns
a set of arrays of ANEs, where each array represents a route segment in the
route of this flow and is assigned a unique ID. These IDs are also sent to
the ALTO client. In addition to the property map of all ANEs used in these
route segments, the ALTO server also sends another property map of all
route segments, where the property is "traffic load percentage".
I intended to talk about this design during the IETF 102 meeting,
however, given my unstable internet connection, I had to omit this part.
Slide 4-6 in the attached presentation illustrates this design with an
example. I believe this design perfectly provides accurate, compact
information of resource sharing in multipath routing. It can also handle
the resource sharing defined by TE policies, and can potentially provide
such information in multicast, provided that the query format supports a
query on multicast flow.
What do you think about these two issues? It would be great to hear the
opinion from not only the authors, but also other WG members. If they are
reasonable to most of you, may I suggest integrating them into the next
version of the PV draft? Thank you very much.
Best wishes
Qiao Xiang
--
Qiao Xiang
Postdoctoral Fellow,
Department of Computer Science,
Yale University
_______________________________________________
alto mailing list
https://www.ietf.org/mailman/listinfo/alto
_______________________________________________
alto mailing list
https://www.ietf.org/mailman/listinfo/alto
Loading...