Kals -

From: tech_kals Kals [mailto:[email protected]]
Sent: Tuesday, March 21, 2017 9:32 PM
To: Les Ginsberg (ginsberg)
Cc: [email protected]; Peter Psenak (ppsenak); Stefano Previdi (sprevidi)
Subject: Re: [Mapping Server] Conflict Resolution

Hi Les,

 Thanks for your clarification. It was really helpful.

 I have few more questions.

 1) How would you handle identical entries has been populated by more than one 
Mapping Server at the same time ?
     For example, assume the below mapping entry is populated by Say, 
Mapping-Server-1 and Mapping-Server-2

     MS-1 entry:   10.1.1.0/24<http://10.1.1.0/24>, 200, 2
     MS-2 entry:   10.1.1.0/24<http://10.1.1.0/24>, 200, 2

[Les:] There is no conflict – entries are identical – it does not matter which 
entry is used.
This is actually what I would expect to see. If one has multiple SRMSs in a 
network they are expected to advertise the same information.
Primary purpose of multiple SRMSs is to provide redundancy.

     I don't think, the draft talks about this case.

2) If there is sub-set of identical entries populated by two different mapping 
servers.

     MS-1 entry:   10.1.3.0/24<http://10.1.3.0/24>, 200, 2
     MS-2 entry:   10.1.1.0/24<http://10.1.1.0/24>, 198, 5

[Les:] Again, there is no conflict. Both entries can be used.
The definition of a prefix conflict is explicitly defined at the end of  
Section 3.2.1 of the draft. Apply the logic to your example.

     In this case, 10.1.3.0, 200; 10.1.4.0, 201 are identical entries. How to 
handle this scenario ?

3) Is preference values are configurable per mapping server or per-mapping 
entry ?

[Les:] Preference is per mapping server- NOT per mapping entry. This is stated 
in Section 3.1 of the draft:

“If a node acts as an SRMS, it MAY advertise a preference to be
   associated with all SRMS SID advertisements sent by that node.”

I mean, once preference value is configured per mapping server then it would be 
applicable for all mapping entries which are triggered from the mapping server 
? Isn't it ?

I see, All SIDs advertised in prefix reachability advertisements implicitly 
have a preference value of 192. It means, preference configured for the node 
will not applicable for "prefix reachability advertisements" ? Isn't it ?

[Les:] Correct.

So, the main purpose of preference is to give preference for a specific mapping 
server ?

[Les:] Yes. SRMS preference provides a way to provision a new mapping server, 
have its advertisements validated but not actually used. This provides a 
non-disruptive way to bring a new server online.

4) One very basic question...

In case of LDP-SR inter-working, mapping entries are stitched by intersect node.

Where as in SR-LDP inter-working, stitching can't be done. Why do we need to 
use mapping server ? Why cant we use stitching?


[Les:] I am not sure what you mean by “stitching”.
Nodes which do not support SR clearly will not advertise SIDs for the prefixes 
they originate. SRMS can be configured to advertise SIDs on behalf of the 
non-SR-capable nodes – thus allowing SR labels to be used in the SR enabled 
portion of the network even for destinations on nodes which are NOT SR-capable.

It is also possible to use SRMS as a central provisioning tool – eliminating 
the need to configure SIDs locally on each SR capable router.

   Les

Thanks in adv Les,


Regards,
_tech.kals_




On Sun, Mar 19, 2017 at 8:52 PM, Les Ginsberg (ginsberg) 
<[email protected]<mailto:[email protected]>> wrote:
Kals –

Inline…look for “Les2”

From: tech_kals Kals [mailto:[email protected]<mailto:[email protected]>]
Sent: Saturday, March 18, 2017 11:40 PM
To: Les Ginsberg (ginsberg)
Cc: [email protected]<mailto:[email protected]>; Peter Psenak (ppsenak); Stefano 
Previdi (sprevidi); 
[email protected]<mailto:[email protected]>
Subject: Re: [Mapping Server] Conflict Resolution

Hi Les,

Thank you so much for your clarification.

I have one more question here...

1) the newly incoming entry would do conflict resolution validation with all 
existing entries and will be programmed only if it doesn't have any conflict 
with any entries or if it wins in conflict resolution with all of them?

In this case, the entry will be programmed only if it wins over all entries, 
even if it fails with any one of the entry, it would not be added. But, the 
entry which fails to win with the new entry also would exists in the database. 
It would have not got removed.

Is my understanding right ?

2) Or when new entry X do conflict resolution validation with each entry and 
assume, all entries are having a conflict resolution with this new entry and 
the new entry wins over all entries. So, in this case, all of them gets 
removed; only new entry would be added.

[Les2:] When an entry arrives has no bearing on the application of the 
preference rule. Conceptually (I am not talking about actual implementation 
details) when the database changes (new entry added, existing entry modified or 
deleted) the algorithm must be re-executed on the complete contents of the 
database – not just on the changed entries..

3) In cisco routers, I observed the below behavior.

[Les2:] There currently is no standard. Individual vendors have implemented 
whatever seemed best to them at the time. When there is WG agreement on a 
standard behavior then it should be expected that implementations will be 
modified to conform to the standard.

    Whenever there is any conflict (prefix/SID) with entries, the entry which 
wins if it has lower system-id ( system-id is in the context of ISIS protocol) 
though it has higher prefix/SID values. i.e. it seems, "system-ID" is treated 
as "preference value".
Why system-ID is being treated as preference value ?  Can you please clarify ?


Coming back to our discussion, I thinks, there is a conflict with all 3 entries 
in all 3 scenarios.

Please see my reply inline with <KALS>

Regards,
_tech.kals_


On Sat, Mar 18, 2017 at 11:19 AM, Les Ginsberg (ginsberg) 
<[email protected]<mailto:[email protected]>> wrote:
Kals –

Please look closely at how to determine if there is a conflict.
From Section 3:

     Prf - Preference Value (See Section 3.1)
       Pi - Initial prefix
       Pe - End prefix
       L  - Prefix length
       Lx - Maximum prefix length (32 for IPv4, 128 for IPv6)
       Si - Initial SID value
       Se - End SID value
       R  - Range value (See Note 1)
       T  - Topology
       A  - Algorithm

       A Mapping Entry is then the tuple: (Prf, Src, Pi/L, Si, R, T, A)
       Pe = (Pi + ((R-1) << (Lx-L))
       Se = Si + (R-1)

And Section 3.2.1

  Given two mapping entries:

   (Prf, P1/L1, S1, R1, T1, A1) and
   (Prf, P2/L2, S2, R2, T2, A2)

   where P1 <= P2

   a prefix conflict exists if all of the following are true:

   1)(T1 == T2) && (A1 == A2)
   2)P1 <= P2
   3)The prefixes are in the same address family.
   2)L1 == L2
   3)(P1e >= P2) && ((S1 + (P2 - P1)) != S2)

The preference rule as defined in the latest version of the draft (02):

1.  Higher preference value wins
   2.  Smaller range wins
   3.  IPv6 entry wins over IPv4 entry
   4.  Longer prefix length wins
   5.  Smaller algorithm wins
   6.  Smaller starting address (considered as an unsigned integer
       value) wins
   7.  Smaller starting SID wins
   8.  If topology IDs are NOT identical both entries MUST be ignored

Comments inline

From: tech_kals Kals [mailto:[email protected]<mailto:[email protected]>]
Sent: Friday, March 17, 2017 1:09 AM
To: Les Ginsberg (ginsberg)
Cc: [email protected]<mailto:[email protected]>; Peter Psenak (ppsenak); Stefano 
Previdi (sprevidi); 
[email protected]<mailto:[email protected]>
Subject: Re: [Mapping Server] Conflict Resolution

Hi Les,

 Sorry, I have not included my mapping entries in the previous mail. Please see 
the example here below.

 I am working with the RFC which doesn't support Preference Value, so please 
ignore it. And, my mapping entries would looks like.
Topology will be a single topology, not a Multi-topology and algorithm would be 
SPF not CSPF.

 Please read my entry the below order:  <Prefix-start/ prefix-len,  starting 
SID,  range>
 E1 and E2 already configured Active entries. X is the newly incoming entry.


Scenario 1:   (Entries are conflicting with prefix)
                         Entry E1:      <10.1.10.0/24<http://10.1.10.0/24>, 
300, 22>
                         Entry E2:      <10.1.1.0/24<http://10.1.1.0/24>,   
150, 5>

[Les:] E1 expands to (10.1.10.0/24<http://10.1.10.0/24> through 
10.1.31.0/24<http://10.1.31.0/24>) using SIDs 300-321
E2 expands to (10.1.1.0/24<http://10.1.1.0/24> through 
10.1.5.0/24<http://10.1.5.0/24>) using SIDs 150 -154

There is no conflict – both entries are used.

                         incoming entry is X:
                         Entry X:        <10.1.2.0/24<http://10.1.2.0/24>,  
200, 20>

[Les:] X expands to (10.1.2.0/24<http://10.1.2.0/24> – 
10.1.21.0/24<http://10.1.21.0/24>) using SIDs 200-219.
There is a prefix conflict with E1.
Preference rule #2 (smaller range) is applied – but the answer one gets depends 
on the order in which the entries are processed – a point which I discussed in 
my presentation at IETF 96. See Slides 17-20 in
https://www.ietf.org/proceedings/97/slides/slides-97-spring-1_ietf97_draft-ietf-spring-conflict-resolution-02-00.pptx

So, if we examine entries in range order (smallest to highest) we find:
E2 has no conflict w X nor with E1.

<KALS>

There is a conflict between X and E2 also.

[Les2:] You are correct – my error.
So, processing entries in range order (smallest to highest)

E2 has a conflict with X. X is ignored.
E2 has no conflict with E1.
E1 and E2 are used – X is ignored.

Apologies for the confusion.


E2 expands to (10.1.1.0/24<http://10.1.1.0/24> through 
10.1.5.0/24<http://10.1.5.0/24>) using SIDs 150 -154
X expands to (10.1.2.0/24<http://10.1.2.0/24> – 
10.1.21.0/24<http://10.1.21.0/24>) using SIDs 200-219.

Prefix 10.1.2.0 to 10.1.5.0 are conflicting between entry-X and entry-E2.
Will E2 win as they have lower range ?

So, only E2 will exist in this case.
E1 will be removed due to conflict with X and X would be removed due to 
conflict with E2.

Assume, if I have some more entries in the table say E3 to E100, they will not 
be participating in the conflict resolution validation as X is lost to E2 
itself. Isn't it ?

Is there any criteria that all entries such as E1, E2 and so on should be in 
sorted order ? Otherwise, performing validation with all mapping entries will 
be difficult if they have not been sorted. Isnt it ?

Could you please let me know whether am I right ?


X has a conflict with E1 – E1 is ignored.
E2 and X are used.

           Step1: Conflict would be validated between E1 and X.

           Step2: Conflict would be validated between E2 and X.

          # what are the entries would be active and what will become 
inactive/excluded entry ?



Scenario 2:   (Entries are conflicting with SID)
                         Entry E1:      <10.1.10.0/24<http://10.1.10.0/24>, 
300, 22>
                         Entry E2:      <7.1.1.0/24<http://7.1.1.0/24>,     
280, 10>

[Les:] Again, there is no conflict, both entries are used.

                         incoming entry is X:
                         Entry X:        <3.1.1.0/24<http://3.1.1.0/24>,   285, 
20>

[Les:] There is no prefix conflict but there is a SID conflict.
E1 300 – 321
E2 280 – 289
X 285 – 304

Again applying Preference Rule #2 (smallest range wins)
E2 wins over X – X is ignored
E2 has no conflict with E1 – both entries are used.
So E1 and E2 are used and X is ignored.


<KALS>

So, X will be added only if it is not having any conflict with all existing 
entries.

X will not be validated with other entries once it loses to someone ? Am i rght 
?

What will happen if,

  - the new entry wins with some entries and
  - losing to some ?

[Les2:] We apply the comparison based on the order of the preference rules. 
Once an entry loses it is no longer a candidate for comparison using any of the 
lower priority preference rule.

   Les


           Step1: Conflict would be validated between E1 and X.

           Step2: Conflict would be validated between E2 and X.

          # what are the entries would be active and what will become 
inactive/excluded entry ?


Scenario 3:    (Entries are conflicting with prefix and SID)

                         Entry E1:      <10.1.10.0/24<http://10.1.10.0/24>, 
300, 22>
                         Entry E2:      <5.1.1.0/24<http://5.1.1.0/24>,     
190, 15>

[Les:] Again, no conflict – both entries are used.

                         incoming entry is X:
                         Entry X:        <10.1.1.0/24<http://10.1.1.0/24>,  
200, 20>

[Les:] X has a prefix conflict with E1 – because it has smaller range X is the 
winner and E1 is ignored.
X has a SID conflict with E2. E2 has smaller range so X is ignored.
Only E2 is used.
Note that we evaluate  prefix conflicts before sid conflicts. Different results 
might ensue if we did sid conflicts before prefix conflicts (though not in this 
example)

The subtleties of ordering in achieving interoperability have not yet been 
incorporated into the draft – in part because there is still discussion about 
what policy should be used (Ignore, Quarantine, Ignore Overlap Only). If the WG 
were to select Ignore as the policy then ordering would not matter.

HTH

   Les

           Step1: Conflict would be validated between E1 and X.

           Step2: Conflict would be validated between E2 and X.

          # what are the entries would be active and what will become 
inactive/excluded entry ?


Regards,
__tech.kals__


On Fri, Mar 17, 2017 at 12:41 PM, Les Ginsberg (ginsberg) 
<[email protected]<mailto:[email protected]>> wrote:
It is not possible to answer your query because the way you have presented your 
entries (X, E1, E2, E3) does not tell us what conflicts you have.
Do you have two SIDs assigned to the same prefix? (Prefix conflict)
Do you have the same SID assigned to two different prefixes? (SID conflict)

This matters – see Section 3.3.6 of the draft for an example as to why.

Please present your example in the form defined in Section 3:

       Prf - Preference Value (See Section 3.1)
       Pi - Initial prefix
       Pe - End prefix
       L  - Prefix length
       Lx - Maximum prefix length (32 for IPv4, 128 for IPv6)
       Si - Initial SID value
       Se - End SID value
       R  - Range value (See Note 1)
       T  - Topology
       A  - Algorithm

       A Mapping Entry is then the tuple: (Prf, Src, Pi/L, Si, R, T, A)

Thanx.

   Les


From: tech_kals Kals [mailto:[email protected]<mailto:[email protected]>]
Sent: Thursday, March 16, 2017 7:22 PM
To: [email protected]<mailto:[email protected]>; Les Ginsberg (ginsberg); Peter 
Psenak (ppsenak); Stefano Previdi (sprevidi); 
[email protected]<mailto:[email protected]>
Subject: [Mapping Server] Conflict Resolution

Hi Experts,

  Could you please explain me what would be the expected behavior in the 
following scenario in Quarantine approach.

  Mapping entries E1, E2, E3 are Active entries.

  In case, if incoming new entry say X which has conflict with E1, E2 and E3.

  Assume, X is better than E1 but not better than E2.  ( E1 < X < E2)

  1] X is better than E1 so E1 will become excluded entry and X will become an 
active entry

  2] Now, X is compared with E2. E2 is better than X. So, X will become 
excluded entry and E2 is an active entry as it was.

So, X and E1 will become "excluded entry".

I couldn't find any info as shown above in the RFC. Can you please clarify ?


My doubts:
1) Will the entry become active only if it wins with all entries which are 
conflicted with this ?
2) When doing conflict resolution with other entries, it can win with some 
entries and can lose to some? What could be the behavior ?
     - This is the case which I explained above.
     - In this case, X can become active by winning to E1 and lose E2 which 
leads X and E1 to become inactive/excluded entry.


can you please clarify ?


Regards,
__tech.kals__



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

Reply via email to