TW DeployingMPLS Text
TW DeployingMPLS Text
TW DeployingMPLS Text
May 2011
By Tim Fiola and Jamie Panagos
The special edition of This Week: Deploying MPLS is provided for easy copying and
pasting of the Junos configurations contained in the book. Xx's are used to blank out
much of the copyrighted material, so use a search in your text editor to locate the
approximate location of the configuration or Junoscript of your choosing.
NOTE: By using this special edition, you agree to use the material in this document at
your own risk. Juniper Networks assumes no responsibility whatsoever for any
inaccuracies in this document or in the configurations or scripts contained within.
2011 by Juniper Networks, Inc. All rights reserved. Juniper Networks, the
Juniper Networks logo, Junos, NetScreen, and ScreenOS are registered
trademarks of Juniper Networks, Inc. in the United States and other countries.
Junose is a trademark of Juniper Networks, Inc. All other trademarks, service
marks, registered trademarks, or registered service marks are the property of
their respective owners.Juniper Networks assumes no responsibility for any
inaccuracies in this document. Juniper Networks reserves the right to change,
modify, transfer, or otherwise revise this publication without notice.
Introduction. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . .6
RSVP LSPs. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . .9
Failover. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . 13
Traffic Engineering . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
.32
LSP Bandwidth Management. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 55
Summary. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
. 66
Once the decision to implement a Multi-Protocol Label Switching (MPLS) core with MPLS services
has been made, it can be a daunting process to understand the concepts, design a
flexxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxXxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxIntroduction
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxXx
xxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxx
xxxxxXxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxx
xxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxXXXxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxXxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
XXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxXXXxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxXXXxxxxxxXxxxxxXxxxXxxxxxxxxxX
XXxxxxxxxxxxxXXXxxXxxxXxxxxxxXxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxx
xxxxxxxxxXxxxxxxxxxXXXxxxxxxxxxxXXXxxXxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxXxxxxxx
xXxxxxxxxxxxxxxxxxxxxxxXxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxx
xxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxXxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxXxxxXxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxx
xxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxXxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxXxxx
Figure 1.1
NOTE A packets label stack refers to the labels that are prepended to the packet. When drawn
graphically, it often appears as a packet with one or more labels stacked on top of it. Later
chapters in this book examine why stacking multiple labels is often necessary.
XxxXxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxx
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxXxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxXxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxx
xxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxXxxxxxXxxxxxxxxxxxxxxxxxxxxx
xxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxXxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xXxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxXxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx ps@glenlivet> show mpls lsp name lagavulin-todalwhinnie detail
Ingress LSP: 0 sessions
Total 0 displayed, Up 0, Down 0
Egress LSP: 2 sessions
Total 0 displayed, Up 0, Down 0
Transit LSP: 1 sessions
10.200.86.5
From: 10.200.86.7, LSPstate: Up, ActiveRoute: 1
LSPname: lagavulin-to-dalwhinnie, LSPpath: Primary
Suggested label received: -, Suggested label sent: Recovery label received: -, Recovery label sent: 3
Resv style: 1 FF, Label in: 300016, Label out: 3
Time left: 126, Since: Tue Feb 15 03:28:02 2011
Tspec: rate 64kbps size 64kbps peak Infbps m 20 M 1500
Port number: sender 1 receiver 30254 protocol 0
PATH rcvfrom: 192.168.86.45 (ge-0/0/3.0) 42150 pkts
Adspec: received MTU 1500 sent MTU 1500
PATH sentto: 192.168.86.6 (ge-0/0/2.0) 42297 pkts
RESV rcvfrom: 192.168.86.6 (ge-0/0/2.0) 42264 pkts
Explct route: 192.168.86.6
Record route: 192.168.86.2 192.168.86.42 192.168.86.45 <self> 192.168.86.6
Total 1 displayed, Up 1, Down 0
XXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxXXXXxxXxxxxxxxxxxxxxxxxxxX
XXxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxXxxXXXxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxNO
TE
UHP may be required in some MPLS networks for class-of-service to work properly or for
vendor interoperability.
XxxxxxxxxxxxxXXXxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxx
xxxxxxxxxxxxxxxxxxx[edit protocols mpls]
ps@dalwhinnie# show
explicit-null;
...
...
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxXxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxps@glenlivet> show mpls lsp name lagavulin-todalwhinnie detail
Ingress LSP: 0 sessions
Total 0 displayed, Up 0, Down 0
Egress LSP: 2 sessions
Total 0 displayed, Up 0, Down 0
Transit LSP: 1 sessions
10.200.86.5
From: 10.200.86.7, LSPstate: Up, ActiveRoute: 1
NOTE
Figure 1.2
RSVP LSPs
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxXxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxXXXXxxxxxXXXxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
Figure 1.3
XXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXX
XxxxxxxxxxxxxxxxxXXXXxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxXXXxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxXXXxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxx
xxxxxxxTo Configure a Basic RSVP LSP on a Junos Device
XxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxx1. Configure the interfaces that will be running RSVP
with family mpls (these are typically all of the core-facing interfaces):
[edit interfaces]
ps@dalwhinnie# show
...
<snip>
...
ge-0/0/2 {
unit 0 {
description "Connection to glenlivet ge-0/0/2.0";
family inet {
address 192.168.86.6/30;
}
family mpls;
}
}
ge-0/0/3 {
unit 0 {
description "Connection to lagavulin ge-0/0/3.0";
family inet {
address 192.168.86.30/30;
}
family mpls;
}
}
xxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxx xxxxxxxxxxxxxxxxxxxxxxxx
xxxxxx [edit protocols rsvp]
ps@dalwhinnie# show
interface ge-0/0/2.0
interface ge-0/0/3.0
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxXXXXxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxx
xxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx xxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxIts a great question and heres why its done.
Specifying interfaces under
[edit
protocols mpls]
allows those interfaces to run the MPLS protocol and appear in the
Traffic Engineering Database (TED) as possible resources for use by RSVP LSPs.
Configuring
family mpls
on the logical interface, on the other hand, allows that
interface to send and receive labeled packets without this ability, the interface does
not know what to do with a labeled packet and simply drops it. It is a common
mistake to configure one and not the other and then spend time troubleshooting why
the configured RSVP LSPs all show
CSPF Failed:
no route toward <destination>
, as
shown here:
[edit protocols mpls]
ps@dalwhinnie# show label-switched-path dalwhinnie-to-lagavulin
to 10.200.86.7;
[edit protocols mpls]
ps@dalwhinnie# run show mpls lsp name dalwhinnie-to-lagavulin detail
Ingress LSP: 3 sessions
10.200.86.7
From: 0.0.0.0, State: Dn, ActiveRoute: 0, LSPname: dalwhinnie-to-lagavulin
ActivePath: (none)
LoadBalance: Random
Encoding type: Packet, Switching type: Packet, GPID: IPv4
Primary
State: Dn
Priorities: 7 0
SmartOptimizeTimer: 180
Will be enqueued for recomputation in 19 second(s).
84 Oct 2 00:51:48.731 CSPF failed: no route toward 10.200.86.7[9 times]
XxxxxxxxxxxxxxxxXXXXxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxNOTE
LDP does not
require configuring interfaces under [edit protocols mpls]. Only RSVP LSPs require that configuration.
Both protocols, however, require that family mpls be configured on the actual logical interfaces.
NOTE Its a bit counterintuitive, but RSVP-signaled LSPs are configured under the
hierarchy.
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxXXXxxxxxxxxxxxXxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxXXXxxxxxxxxxxXxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxXxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXxx
xxxxxxxxxxxxxxxxxxXXXXxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx ps@dalwhinnie> show rsvp session lsp name dalwhinnie-tooban detail
Ingress RSVP: 1 sessions
10.200.86.3
From: 10.200.86.5, LSPstate: Up, ActiveRoute: 0
LSPname: dalwhinnie-to-oban, LSPpath: Primary
Suggested label received: -, Suggested label sent: Recovery label received: -, Recovery label sent: 300432
Resv style: 1 FF, Label in: -, Label out: 300432
Time left: -, Since: Wed Jul 21 03:36:04 2010
Tspec: rate 0bps size 0bps peak Infbps m 20 M 1500
Port number: sender 1 receiver 1773 protocol 0
PATH rcvfrom: localclient
Adspec: sent MTU 1500
Path MTU: received 1500
PATH sentto: 192.168.86.5 (ge-0/0/2.0) 126 pkts
RESV rcvfrom: 192.168.86.5 (ge-0/0/2.0) 124 pkts
Explct route: 192.168.86.5 192.168.86.9 192.168.86.25
Record route: <self> 192.168.86.5 192.168.86.9 192.168.86.25
XxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXX
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxXXXxxxxxxxxxXxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx LDP LSPs
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxx
xxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxXxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxx
xxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxXXXXxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxXxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxXXXXxxxxxxxxxxxxTo Establish an LDP Core
1. Configure family mpls on core-facing interfaces on each router:
ps@tormore> show configuration interfaces
...
<snip>
...
ge-0/0/2 {
unit 0 {
description "Connection to talisker fe-2/0/1.0";
family inet {
address 192.168.86.33/30;
}
family mpls;
}
}
ge-0/0/3 {
unit 0 {
description "Connection to oban ge-0/0/3.0";
family inet {
address 192.168.86.37/30;
}
family mpls;
}
}
stanza
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx Failov
er
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxXxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxXXXXxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxX
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxLink Protection
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxx
xxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXX
xxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxXxxxxxxxxxxxxxxxxxxxXXXxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxXx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxx
xxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxXxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxXXXxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxx
Figure 1.4
XxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxx
Figure 1.5
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxXXXxxxxps@glenlivet> show mpls lsp transit
Transit LSP: 2 sessions
To
From
State
10.200.86.3
10.200.86.5
10.200.86.9
10.200.86.5
Total 2 displayed, Up 2, Down
XxxxxxxxxxxxxxxxxxxXXXxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxXxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxx
xxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxXXXxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxXXXxxXxxxxxxxxxxxxxxxxxXXXxx ps@glenlivet> show mpls lsp transit name dalwhinnieto-oban
Transit LSP: 5 sessions
To
From
State Rt Style Labelin Labelout LSPname
10.200.86.3
10.200.86.5
Up
1 1 SE 303168 303296 dalwhinnie-to-oban
Total 1 displayed, Up 1, Down 0
ps@glenlivet> show route table mpls.0 label 303168 detail | match Label
Label-switched-path dalwhinnie-to-oban
Label operation: Swap 303296
Label-switched-path Bypass->192.168.86.9
Label operation: Swap 303296, Push 300880(top)
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxps@mortlach> show route table mpls.0 label 300880 detail
mpls.0: 27 destinations, 27 routes (27 active, 0 holddown, 0 hidden)
300880 (1 entry, 1 announced)
*RSVP Preference: 7
Next hop type: Router, Next hop index: 584
Next-hop reference count: 3
Next hop: 192.168.86.50 via fe-2/0/0.0 weight 0x1, selected
Label-switched-path Bypass->192.168.86.9
Label operation: Pop
State: <Active Int>
Local AS: 7176
Age: 54:59
Metric: 1
Task: RSVP
Announcement bits (1): 0-KRT
AS path: I
300880(S=0) (1 entry, 1 announced)
*RSVP Preference: 7
Next hop type: Router, Next hop index: 594
Next-hop reference count: 2
Next hop: 192.168.86.50 via fe-2/0/0.0 weight 0x1, selected
Label-switched-path Bypass->192.168.86.9
Label operation: Pop
State: <Active Int>
Local AS: 7176
Age: 54:59
Metric: 1
Task: RSVP
Announcement bits (1): 0-KRT
AS path: I
NOTE The (S=0) entry in the mpls.0 table for a given label refers to a packet coming into the
router with a label stack depth n>=2, and exiting the router with a label stack depth of n-1. The
information without the S=0 note refers to a packet entering the router with a label stack depth of
1 and exiting the router with no label. In this example, the packet enters the router with a stack
depth n=2.
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xXxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXx
xxx
Figure 1.6
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxX
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxX
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx xxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxXXXxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxXxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxx[edit protocols mpls]
ps@dalwhinnie# show
label-switched-path dalwhinnie-to-oban {
to 10.200.86.3;
link-protection;
}
label-switched-path dalwhinnie-to-oban-lo-priority {
to 10.200.86.3;
link-protection;
}
path via-tormore;
interface ge-0/0/2.0;
interface ge-0/0/3.0;
[edit protocols rsvp]
ps@dalwhinnie# show
interface ge-0/0/2.0 {
link-protection;
}
interface ge-0/0/3.0 {
link-protection;
}
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxTIP
When using link
protection, it is a best practice to enable the link protection capability on every RSVP interface on
each router in the RSVP domain in order to ensure that link protection for an RSVP LSP is available
no matter which routers or core-facing interfaces the LSP may transit at a given point in time.
Node-link Protection
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxX
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxx
xxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXX
XxxXxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxx
xxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxx
xxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxx
xxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxXxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxx
Figure 1.7
node-link-protection
keyword
within each MPLS LSP where this protection is desired. Additionally, link protection
must also be configured for each RSVP interface that the node-link protected LSP
may traverse. In this case, when the local router sees an LSP requesting node-link
protection, it attempts to signal a bypass LSP to the next next-hop router for the
LSP; if it cannot do so then it signals a next-hop bypass LSP. As is the case with
link-protection, it is a best practice to configure link-protection under every inter
face configured for RSVP on each router in the RSVP domain if node-link protection
is enabled. This ensures that any core-facing interface that the LSP may traverse is
able to provide the node-link protection. Here the
node-link-protection
keyword
is included in the LSP configuration:
ps@dalwhinnie> show configuration protocols mpls
label-switched-path dalwhinnie-to-oban {
to 10.200.86.3;
node-link-protection;
}
interface ge-0/0/2.0;
interface ge-0/0/3.0;
ps@dalwhinnie> show configuration protocols rsvp
interface ge-0/0/2.0 {
link-protection;
}
interface ge-0/0/3.0 {
link-protection;
}
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
XXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxX
XXxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxXxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxWARN
ING
Much of the official Juniper documentation on node-link protection suggests that each
ingress and transit router in an LSPs path signals both a next-next-hop LSP AND a next-hop LSP.
However, this books lab results show that each of these routers signals one or the other: the router
signals a next-next-hop bypass LSP for protection if the network architecture supports it; if it does
not, then, and only then, will the router signal a next-hop bypass LSP for a node-link protected
LSPs protection.
XxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx ps@dalwhinnie>
show mpls lsp detail
Ingress LSP: 1 sessions
10.200.86.3
From: 10.200.86.5, State: Up, ActiveRoute: 0, LSPname: dalwhinnie-to-oban
ActivePath: (primary)
Node/Link protection desired
LoadBalance: Random
Encoding type: Packet, Switching type: Packet, GPID: IPv4
*Primary
State: Up
Priorities: 7 0
SmartOptimizeTimer: 180
Computed ERO (S [L] denotes strict [loose] hops): (CSPF metric: 3)
192.168.86.5 S 192.168.86.9 S 192.168.86.25 S
Received RRO (ProtectionFlag 1=Available 2=InUse 4=B/W 8=Node 10=SoftPreempt
20=Node-ID):
10.200.86.6(flag=0x29) 192.168.86.5(flag=9 Label=300416)
10.200.86.1(flag=0x21) 192.168.86.9(flag=1 Label=300400) 10.200.86.3(flag=0x20)
192.168.86.25(Label=3)
XxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxX
xxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxXxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxx ps@dalwhinnie> show mpls lsp
bypass ingress
Ingress LSP: 2 sessions
To
From
State Rt Style Labelin Labelout LSPname
10.200.86.1
10.200.86.5
Up
0 1 SE
- 300384 Bypass->192.168.86.5->192.168.86.9
Total 1 displayed, Up 1, Down 0
ps@dalwhinnie> show mpls lsp bypass name Bypass->192.168.86.5->192.168.86.9 detail
Ingress LSP: 2 sessions
10.200.86.1
From: 10.200.86.5, LSPstate: Up, ActiveRoute: 0
LSPname: Bypass->192.168.86.5->192.168.86.9
Suggested label received: -, Suggested label sent: Recovery label received: -, Recovery label sent: 300848
Resv style: 1 SE, Label in: -, Label out: 300848
Time left: -, Since: Wed Dec 8 05:54:30 2010
Tspec: rate 0bps size 0bps peak Infbps m 20 M 1500
Port number: sender 1 receiver 1845 protocol 0
Type: Bypass LSP
Number of data route tunnel through: 1
Number of RSVP session tunnel through: 0
PATH rcvfrom: localclient
Adspec: sent MTU 1500
Path MTU: received 1500
PATH sentto: 192.168.86.29 (ge-0/0/3.0) 4 pkts
RESV rcvfrom: 192.168.86.29 (ge-0/0/3.0) 4 pkts
Explct route: 192.168.86.29 192.168.86.1 192.168.86.13 192.168.86.18
Record route: <self> 192.168.86.29 192.168.86.1 192.168.86.13 192.168.86.18
Total 1 displayed, Up 1, Down 0
XxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
XXXxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxx ps@blair> show mpls
lsp transit name dalwhinnie-to-oban detail
Transit LSP: 12 sessions
10.200.86.3
From: 10.200.86.5, LSPstate: Up, ActiveRoute: 1
LSPname: dalwhinnie-to-oban, LSPpath: Primary
Suggested label received: -, Suggested label sent: Recovery label received: -, Recovery label sent: 3
Resv style: 1 SE, Label in: 303744, Label out: 3
Time left: 144, Since: Wed Dec 8 07:21:19 2010
Tspec: rate 0bps size 0bps peak Infbps m 20 M 1500
Port number: sender 3 receiver 1843 protocol 0
Node/Link protection desired
Type: Link protected LSP
PATH rcvfrom: 192.168.86.10 (ge-0/0/1.0) 41 pkts
Adspec: received MTU 1500 sent MTU 1500
PATH sentto: 192.168.86.25 (ge-6/0/0.0) 43 pkts
RESV rcvfrom: 192.168.86.25 (ge-6/0/0.0) 41 pkts
Explct route: 192.168.86.25
Record route: 192.168.86.6 192.168.86.10 <self> 10.200.86.3 (node-id) 192.168.86.25
Total 1 displayed, Up 1, Down 0
ps@blair> show mpls lsp bypass ingress
Ingress LSP: 2 sessions
To
From
State Rt Style Labelin Labelout LSPname
10.200.86.3
10.200.86.1
Up
0 1 SE
- 301360 Bypass->192.168.86.25
10.200.86.4
10.200.86.1
Up
0 1 SE
- 301168 Bypass->192.168.86.17
Total 2 displayed, Up 2, Down 0
ps@blair>
ps@blair> show mpls lsp bypass name Bypass->192.168.86.25 detail
Ingress LSP: 2 sessions
10.200.86.3
From: 10.200.86.1, LSPstate: Up, ActiveRoute: 0
LSPname: Bypass->192.168.86.25
Suggested label received: -, Suggested label sent: Recovery label received: -, Recovery label sent: 301360
Resv style: 1 SE, Label in: -, Label out: 301360
Time left: -, Since: Wed Dec 8 05:21:15 2010
Tspec: rate 0bps size 0bps peak Infbps m 20 M 1500
Port number: sender 1 receiver 49268 protocol 0
Type: Bypass LSP
Number of data route tunnel through: 2
Number of RSVP session tunnel through: 0
PATH rcvfrom: localclient
Adspec: sent MTU 1500
Path MTU: received 1500
PATH sentto: 192.168.86.17 (ge-0/0/3.0) 185 pkts
RESV rcvfrom: 192.168.86.17 (ge-0/0/3.0) 185 pkts
Explct route: 192.168.86.17 192.168.86.33 192.168.86.38
Record route: <self> 192.168.86.17 192.168.86.33 192.168.86.38
Total 1 displayed, Up 1, Down 0
Egress LSP: 3 sessions
Total 0 displayed, Up 0, Down 0
Transit LSP: 12 sessions
Total 0 displayed, Up 0, Down 0
ps@blair>
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxXxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxXxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxXxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxThere are some differences
in performance between the next-hop bypass LSP and
the next-next-hop bypass LSP. As explained previously, link protection relies on the
routers hardware to detect a link failure, and so the PLR router can quickly detect the
break and switch the protected traffic to the next-hop LSP. Node-protection, on the
other hand, relies on the receipt of hello messages from the neighboring router to
determine if that router still exists. The time it takes for the PLR router to switch
traffic onto a next-next-hop LSP is dependent on the frequency of hello messages
from the neighboring router and the time it takes the PLR router to detect the absence
of those messages. Once the failure is detected, however, the PLR can quickly switch
the traffic to the next-next-hop bypass LSP. Because of this difference between how
next-hop and next-next-hop LSPs detect failures, when using node-protection it is
reasonable to expect slightly longer failover times for your next-next-hop LSPs as
compared to the failover times for a next-hop LSP. This difference in failover time
may be an important factor in determining whether to employ link-node-protection
or link-protection. Another closely related factor to consider is the likelihood of an
entire node failing, especially if redundant routing-engines and power supplies are
available for your specific router model.
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxx
xxxxxxxxxxxxxXxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxXXXxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxx
xxxxXxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxx
xxxxxxxXXXxxxFast Reroute
XxxxxXxxxxxxxxXXXxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxx
xxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxx
xxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxx
xxxxxxxxxxxxxxXXXxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxX
XXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxXXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxXXXxxXxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxXXXxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXX
xxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxXxxXxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXX
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxXxxxxx
xxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxXxxXxxxxxxxXxxxXxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxx
Figure 1.8
XxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxXxxxx
xxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxXXXxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxx [edit protocols mpls]
ps@dalwhinnie# show
label-switched-path dalwhinnie-to-oban {
to 10.200.86.3;
fast-reroute;
}
interface ge-0/0/2.0;
interface ge-0/0/3.0;
[edit protocols mpls]
ps@dalwhinnie#
NOTE If a fast-reroute protected LSP has any link-coloring restrictions, the FRR detours also inherit
those restrictions. Link-coloring is covered in the Traffic Engineering section of this chapter.
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxXXXxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxXXXxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx ps@dalwhinnie> show rsvp
session lsp name dalwhinnie-to-oban detail
Ingress RSVP: 1 sessions
10.200.86.3
From: 10.200.86.5, LSPstate: Up, ActiveRoute: 0
LSPname: dalwhinnie-to-oban, LSPpath: Primary
Suggested label received: -, Suggested label sent: Recovery label received: -, Recovery label sent: 300432
Resv style: 1 FF, Label in: -, Label out: 300432
Time left: -, Since: Wed Jul 21 03:36:04 2010
Tspec: rate 0bps size 0bps peak Infbps m 20 M 1500
Port number: sender 1 receiver 1773 protocol 0
FastReroute desired
PATH rcvfrom: localclient
Adspec: sent MTU 1500
Path MTU: received 1500
PATH sentto: 192.168.86.5 (ge-0/0/2.0) 37 pkts
RESV rcvfrom: 192.168.86.5 (ge-0/0/2.0) 34 pkts
Explct route: 192.168.86.5 192.168.86.9 192.168.86.25
Record route: <self> 192.168.86.5 192.168.86.9 192.168.86.25
Detour is Up
Detour Tspec: rate 0bps size 0bps peak Infbps m 20 M 1500
Detour adspec: sent MTU 1500
Path MTU: received 1500
Detour PATH sentto: 192.168.86.29 (ge-0/0/3.0) 34 pkts
Detour RESV rcvfrom: 192.168.86.29 (ge-0/0/3.0) 32 pkts
Detour Explct route: 192.168.86.29 192.168.86.1 192.168.86.13
192.168.86.33 192.168.86.38
Detour Record route: <self> 192.168.86.29 192.168.86.1 192.168.86.13
192.168.86.33 192.168.86.38
Detour Label out: 300400
Total 1 displayed, Up 1, Down 0
XxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxx
xXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXx
xxxxxxxxxxxxxxxps@glenlivet> show rsvp session transit detail lsp name dalwhinnie-to-oban
Transit RSVP: 1 sessions
10.200.86.3
From: 10.200.86.5, LSPstate: Up, ActiveRoute: 1
LSPname: dalwhinnie-to-oban, LSPpath: Primary
Suggested label received: -, Suggested label sent: Recovery label received: -, Recovery label sent: 300416
Resv style: 1 FF, Label in: 300432, Label out: 300416
Time left: 130, Since: Wed Jul 21 03:34:58 2010
Tspec: rate 0bps size 0bps peak Infbps m 20 M 1500
Port number: sender 1 receiver 1773 protocol 0
FastReroute desired
PATH rcvfrom: 192.168.86.6 (ge-0/0/2.0) 44 pkts
Adspec: received MTU 1500 sent MTU 1500
PATH sentto: 192.168.86.9 (ge-0/0/1.0) 42 pkts
RESV rcvfrom: 192.168.86.9 (ge-0/0/1.0) 40 pkts
Explct route: 192.168.86.9 192.168.86.25
Record route: 192.168.86.6 <self> 192.168.86.9 192.168.86.25
Detour is Up
Detour Tspec: rate 0bps size 0bps peak Infbps m 20 M 1500
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxX
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxXxxxxxxxxxxxxxxxxSecondary LSP
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxX
XXxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxXxxxxxxxxxxxxxxxxxxxx
xxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxXXXxxxxxxxxxxxxxxxxxxXxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxXXXxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxx xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxx [edit protocols mpls]
ps@dalwhinnie# show
label-switched-path dalwhinnie-to-oban {
to 10.200.86.3;
primary via-blair;
secondary via-tormore {
standby;
}
}
path via-tormore {
10.200.86.9 loose;
}
path via-blair {
192.168.86.5 strict;
192.168.86.9 strict;
192.168.86.25 strict;
}
interface ge-0/0/2.0;
interface ge-0/0/3.0;
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxX
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxNOTE Hops in a path can be defined as loose or strict. An LSP path must traverse
all configured hops in the order in which they are configured. At any given router in the LSP path,
the next strict hop must be directly connected to the router, while a loose hop can be any hop
reachable in the network from that router.
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxXxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxXXxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxx ps@dalwhinnie> show mpls lsp name dalwhinnie-to-oban detail
Ingress LSP: 2 sessions
10.200.86.3
From: 10.200.86.5, State: Up, ActiveRoute: 0, LSPname: dalwhinnie-to-oban
ActivePath: via-blair (primary)
LoadBalance: Random
XxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxx
Figure 1.9
WARNING
Even properly planned failover scenarios using link-protection, node-link protection,
or secondary LSPs may not tolerate multiple network link or router failures.
XxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxXxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxXXXxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxx[edit protocols mpls]
ps@dalwhinnie# show
label-switched-path dalwhinnie-to-oban {
to 10.200.86.3;
primary via-blair;
secondary via-tormore {
standby;
}
}
label-switched-path dalwhinnie-to-tormore {
to 10.200.86.9;
secondary via-talisker {
standby;
}
secondary alt-path {
standby;
}
}
path via-tormore {
10.200.86.9 loose;
}
path via-talisker {
10.200.86.4 loose;
}
path via-blair {
192.168.86.5 strict;
192.168.86.9 strict;
192.168.86.25 strict;
}
path alt-path;
interface ge-0/0/2.0;
interface ge-0/0/3.0;
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxx
xxxxxxxxxxxXXXxxxxxxxxxxx[edit protocols mpls]
ps@dalwhinnie# run show mpls lsp name dalwhinnie-to-tormore detail
Ingress LSP: 2 sessions
10.200.86.9
From: 10.200.86.5, State: Up, ActiveRoute: 0, LSPname: dalwhinnie-to-tormore
ActivePath: via-talisker (secondary)
LoadBalance: Random
Encoding type: Packet, Switching type: Packet, GPID: IPv4
*Standby via-talisker
State: Up
Priorities: 7 0
SmartOptimizeTimer: 180
Computed ERO (S [L] denotes strict [loose] hops): (CSPF metric: 4)
192.168.86.5 S 192.168.86.9 S 192.168.86.17 S 192.168.86.33 S
Received RRO (ProtectionFlag 1=Available 2=InUse 4=B/W 8=Node 10=SoftPreempt 20=Node-ID):
192.168.86.5 192.168.86.9 192.168.86.17 192.168.86.33
Standby alt-path
State: Up
Priorities: 7 0
SmartOptimizeTimer: 180
Computed ERO (S [L] denotes strict [loose] hops): (CSPF metric: 4)
192.168.86.5 S 192.168.86.9 S 192.168.86.17 S 192.168.86.33 S
Received RRO (ProtectionFlag 1=Available 2=InUse 4=B/W 8=Node 10=SoftPreempt 20=Node-ID):
192.168.86.5 192.168.86.9 192.168.86.17 192.168.86.33
Total 1 displayed, Up 1, Down 0
Egress LSP: 0 sessions
Total 0 displayed, Up 0, Down 0
Transit LSP: 0 sessions
Total 0 displayed, Up 0, Down 0
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxXXXxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxXXXxxxps@dalwhinnie> show configuration protocols mpls
label-switched-path dalwhinnie-to-oban {
to 10.200.86.3;
primary via-blair;
secondary alt-path {
standby;
}
}
label-switched-path dalwhinnie-to-tormore {
to 10.200.86.9;
secondary via-talisker {
standby;
}
secondary alt-path {
standby;
}
}
. . . <snipped for brevity> . . .
path alt-path;
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxXXXxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxps@dalwhinnie> show mpls lsp detail
Ingress LSP: 2 sessions
10.200.86.3
From: 10.200.86.5, State: Up, ActiveRoute: 0, LSPname: dalwhinnie-to-oban
ActivePath: via-blair (primary)
LoadBalance: Random
Encoding type: Packet, Switching type: Packet, GPID: IPv4
*Primary via-blair
State: Up
...
. . . <snipped for brevity> . . .
...
Standby alt-path
State: Up
Priorities: 7 0
SmartOptimizeTimer: 180
Computed ERO (S [L] denotes strict [loose] hops): (CSPF metric: 5)
192.168.86.29 S 192.168.86.1 S 192.168.86.13 S 192.168.86.33 S 192.168.86.38 S
Received RRO (ProtectionFlag 1=Available 2=InUse 4=B/W 8=Node 10=SoftPreempt 20=Node-ID):
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxXXXXxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXX
xXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxX
XXxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxLoop-Free Alternates in IGPs
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxXXXxxxxxxxxxxxXXXxxxXxxxxxxxXXXXxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXX
xXXXXxxxxxxxxxxXXXXxxxxxxxxXxxXxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxx
xxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxXXXxxXXXXxxx
xXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxx
xxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
XXXxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxx
XXXxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxXxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxXXXXxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxXXXxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxx
xXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxXxXXXxxXx
XXXxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxXXxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxXXxxxxxxxxxxxxxxxxxxxxx
xXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxXXXXxxxxxXXXXxxxx[edit protocols]
ps@dalwhinnie# show ospf
area 0.0.0.0 {
interface ge-0/0/0.0 {
link-protection;
}
interface ge-0/0/1.0 {
node-link-protection;
}
}
[edit protocols]
ps@dalwhinnie# show ospf3
area 0.0.0.0 {
interface ge-0/0/0.0 {
link-protection;
}
interface ge-0/0/1.0 {
node-link-protection;
}
}
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxXXXXxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxx
xxxxxxxxxxxxxxxxx[edit protocols]
tim@srx100# show ospf area 0 interface ge-1/0/0.0
no-eligible-backup;
TIP
When configuring link protection, it is also necessary to configure a per-packet loadbalancing routing policy to ensure that the IGP installs all the next-hops for a given route into the
routing table. Below is a very basic per-packet load-balancing policy; apply the policy at the [edit
routing-options forwarding-table] level in the hierarchy.
[edit]
ps@dalwhinnie# show policy-options
policy-statement basic-load-balancing-policy {
then {
load-balance per-packet;
}
}
[edit]
ps@dalwhinnie# show routing-options
...
...
router-id 10.200.86.5;
autonomous-system 7176;
forwarding-table {
export basic-load-balancing-policy;
}
...
...
CAUTION
of this book.
LFA faces some limitations in certain topologies. That discussion is outside the scope
Traffic Engineering
XxxxxxxxxxxxxxxxxxxxxXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx LSP Metrics
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxXXXxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxXXXxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxXXXxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxXXXxxxXxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxx[edit protocols mpls]
ps@dalwhinnie# show label-switched-path dalwhinnie-to-oban
to 10.200.86.3;
metric 20;
link-protection;
Link Coloring
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxXxxxxxxxXxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
Figure 1.10
Link Coloring
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxXXXxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxX
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx xxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxLSP dalwhinnie-tooban is required to take gold links through the network to reach oban. Any bypass LSPs protecting
this link, however, would not be required to contain gold links in their path. This is because a
bypass LSP can be used to protect multiple LSPs that may have many different constraints. The fast
reroute detours for an LSP protected by FRR, on the other hand, would inherit the primary LSPs
constraints and be required to take gold links in our example.
LSP dalwhinnie-to-oban-lo-priority is explicitly forbidden to take any gold colored links. Note,
however, that if this LSP is configured for link protection, then the bypass LSPs protecting this LSP
may take gold links, unless expressly forbidden to do so. Primary and secondary paths and bypass
LSPs can be configured with admin-group restrictions as well. Keep in mind that if this LSP is
configured for fast reroute, instead of a link-protection bypass LSP, then the FRR detour would be
forbidden to take gold links.
NOTE Because LSPs are unidirectional, if the network engineer desires an equivalent gold path in
the opposite direction, from oban to dalwhinnie, then she must provision an LSP on oban to
dalwhinnie and then add mpls interfaces ge-0/0/2.0 on oban, ge-0/0/1.0 on blair, and ge-0/0/1.0 on
glenlivet to the gold admin-group.
XxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx ps@dalwhinnie>
show configuration protocols mpls
admin-groups {
gold 1;
}
label-switched-path dalwhinnie-to-oban {
to 10.200.86.3;
admin-group include-any gold;
link-protection;
}
label-switched-path dalwhinnie-to-oban-lo-priority {
to 10.200.86.3;
admin-group exclude gold;
link-protection;
}
path via-tormore;
interface ge-0/0/2.0 {
admin-group gold;
}
interface ge-0/0/3.0;
ps@dalwhinnie> show configuration protocols rsvp
interface ge-0/0/2.0 {
link-protection;
}
interface ge-0/0/3.0 {
link-protection;
}
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxXX
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxX
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxx[edit protocols mpls]
ps@dalwhinnie# show
admin-groups {
gold 1;
}
label-switched-path dalwhinnie-to-oban {
to 10.200.86.3;
primary via-tormore {
admin-group include-all gold;
}
secondary alt-path {
admin-group include-all gold;
}
}
interface ge-0/0/2.0 {
admin-group gold;
}
XxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx [edit protocols rsvp]
ps@dalwhinnie# show
interface ge-0/0/2.0 {
link-protection {
admin-group include-any gold;
}
}
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxx[edit protocols mpls label-switched-path dalwhinnie-to-oban]
ps@dalwhinnie# set primary via-tormore admin-group ?
Possible completions:
...
+ exclude
Groups, all of which must be absent
+ include-all
Groups, all of which must be present
+ include-any
Groups, one or more of which must be present
NOTE When there are no admin-group constraints on an LSP, then that LSP is allowed to consider
possible paths through the network regardless of any link coloring configured on any router
interfaces.
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxXXXXxxxxxxxxxXxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXX
XxxxxxxxxxxxxxxxxxXxxxXXxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxx
xxxxxXXxxxxxxxxxxxxxxxxxxxxXXXXxXXXXxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxXxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx ps@glenlivet> show ted database
extensive | find 10.200.86.5
NodeID: 10.200.86.5
Type: Rtr, Age: 877 secs, LinkIn: 2, LinkOut: 2
Protocol: OSPF(0.0.0.0)
To: 10.200.86.6, Local: 192.168.86.6, Remote: 192.168.86.5
Local interface index: 71, Remote interface index: 0
Color: 0x2 gold
Metric: 1
Static BW: 1000Mbps
Reservable BW: 1000Mbps
Available BW [priority] bps:
[0] 1000Mbps
[1] 1000Mbps [2] 1000Mbps [3] 1000Mbps
[4] 1000Mbps
[5] 1000Mbps [6] 1000Mbps [7] 1000Mbps
Interface Switching Capability Descriptor(1):
Switching type: Packet
Encoding type: Packet
Maximum LSP BW [priority] bps:
[0] 1000Mbps
[1] 1000Mbps [2] 1000Mbps [3] 1000Mbps
[4] 1000Mbps
[5] 1000Mbps [6] 1000Mbps [7] 1000Mbps
To: 10.200.86.7, Local: 192.168.86.30, Remote: 192.168.86.29
Local interface index: 72, Remote interface index: 0
Color: 0 <none>
Metric: 1
Static BW: 1000Mbps
Reservable BW: 1000Mbps
[3] 1000Mbps
[7] 1000Mbps
[3] 1000Mbps
[7] 1000Mbps
XxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
XXxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxXXxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxNOTE Although in our example the
gold admin group actually has a value of 1, 1 is the second available value in an ordered list of 32
numbers with values 0-31.
XxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxX
XXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxx
xxxxxxxxxxxxxxxxxxxxxps@dalwhinnie> show mpls lsp name dalwhinnie-to-oban detail ingress
Ingress LSP: 1 sessions
10.200.86.3
XxxxxxxxxxxxxxxxxXXXxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx ps@glenlivet> show
configuration protocols rsvp
interface ge-0/0/1.0 {
link-protection {
path {
192.168.86.45 strict;
192.168.86.21 strict;
192.168.86.18 strict;
}
}
}
...
...
...
xps@glenlivet> show mpls lsp bypass ingress detail
Ingress LSP: 1 sessions
10.200.86.1
From: 10.200.86.6, LSPstate: Up, ActiveRoute: 0
LSPname: Bypass->192.168.86.9
Suggested label received: -, Suggested label sent: ...
...
...
Explct route: 192.168.86.45 192.168.86.21 192.168.86.18
Record route: <self> 192.168.86.45 192.168.86.21 192.168.86.18
Total 1 displayed, Up 1, Down 0
XxxxxxxxxxxxxxxxxXXXxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxXxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxx
Figure 1.11
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxXXXxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxXXXXxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxX
XXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx BGP Next-hop
Installation
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxXXXXxXXXxxxxxxxxxxx ps@d
alwhinnie> show route table inet.3 | match metric
10.200.86.1/32
*[LDP/9] 00:03:40, metric 1
10.200.86.2/32
*[LDP/9] 00:03:40, metric 1
10.200.86.3/32
*[RSVP/7] 00:03:40, metric 3
[LDP/9] 00:03:40, metric 1
10.200.86.4/32
*[LDP/9] 00:03:40, metric 1
10.200.86.6/32
*[LDP/9] 00:03:39, metric 1
10.200.86.7/32
*[LDP/9] 00:03:39, metric 1
10.200.86.8/32
*[LDP/9] 00:03:40, metric 1
10.200.86.9/32
*[LDP/9] 00:03:40, metric 1
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxXXX
xxXxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxXXXxXXXxxxXxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxXXXxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxXXXxxxxxxxxxxps@dalwhinnie> show route 172.16.0/24
inet.0: 34 destinations, 34 routes (33 active, 0 holddown, 1 hidden)
+ = Active Route, - = Last Active, * = Both
172.16.0.0/24
*[BGP/170] 2d 20:09:01, localpref 100, from 10.200.86.3
AS path: I
> to 192.168.86.5 via ge-0/0/2.0, label-switched-path dalwhinnie-to-oban
to 192.168.86.29 via ge-0/0/3.0, label-switched-path Bypass->192.168.86.5
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxXXXXxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxx
xxxxxxxXxxxxxxxxxxxxxxxxxxXXXxxxxxxXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxps@dalwhinnie> show route 172.17.0/24 detail
inet.0: 34 destinations, 34 routes (33 active, 0 holddown, 1 hidden)
172.17.0.0/24 (1 entry, 1 announced)
*BGP Preference: 170/-101
Next hop type: Indirect
Next-hop reference count: 3
Source: 10.200.86.3
Next hop type: Router, Next hop index: 554
Next hop: 192.168.86.5 via ge-0/0/2.0, selected
Protocol next hop: 192.168.90.14
...
...
...
Router ID: 10.200.86.3
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxXXXxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx xxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxXxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxXXxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxXXXxxxxxxxxxxxxxx
xXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxx
Figure 1.12
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxXXXxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxXXxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxX
xxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxXXXxxxxxxxxxxxxxxX
XXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxXXXxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXxxxxxxxxxxxxxxxxxxx ps@dalw
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxXXXxxXxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxx
xxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx [edit
protocols mpls]
ps@dalwhinnie# show
label-switched-path dalwhinnie-to-oban {
to 10.200.86.3;
install 192.168.90.12/30 active;
link-protection;
primary via-blair;
}
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx xxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx xxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxx ps@dalwhinnie> show route 192.168.90.12/30
inet.0: 34 destinations, 35 routes (33 active, 0 holddown, 1 hidden)
+ = Active Route, - = Last Active, * = Both
192.168.90.12/30 *[RSVP/7] 00:00:26, metric 3
> to 192.168.86.5 via ge-0/0/2.0, label-switched-path dalwhinnie-to-oban
to 192.168.86.29 via ge-0/0/3.0, label-switched-path Bypass->192.168.86.5
[OSPF/10] 1d 14:07:52, metric 4
> to 192.168.86.5 via ge-0/0/2.0
ps@dalwhinnie> traceroute 192.168.90.14 no-resolve
traceroute to 192.168.90.14 (192.168.90.14), 30 hops max, 40 byte packets
1 192.168.86.5 4.492 ms 2.691 ms 2.833 ms
MPLS Label=300944 CoS=0 TTL=1 S=1
2 192.168.86.9 4.157 ms 4.080 ms 4.643 ms
MPLS Label=300944 CoS=0 TTL=1 S=1
3 192.168.86.25 4.677 ms 4.859 ms 4.624 ms
4 192.168.90.14 10.693 ms 9.747 ms 3.859 ms
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxXXXxxXxxxxxxxxxxxxxxxxxxxXXX
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxx ps@dalwhinnie>
show route 172.17.0.1/24
inet.0: 34 destinations, 35 routes (33 active, 0 holddown, 1 hidden)
+ = Active Route, - = Last Active, * = Both
172.17.0.0/24
*[BGP/170] 1d 07:34:55, localpref 100, from 10.200.86.3
AS path: 65432 I
> to 192.168.86.5 via ge-0/0/2.0, label-switched-path dalwhinnie-to-oban
to 192.168.86.29 via ge-0/0/3.0, label-switched-path Bypass->192.168.86.5
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx xxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxXxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx [edit protocols mpls]
ps@dalwhinnie# delete label-switched-path dalwhinnie-to-oban install 192.168.90.12/30
Traffic-engineering bgp-igp
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxXXXxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx ps@dalwhinnie>
show route 10.200.86.3
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxXxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx xxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxx [edit protocols mpls]
ps@dalwhinnie# show
traffic-engineering bgp-igp;
label-switched-path dalwhinnie-to-oban {
to 10.200.86.3;
link-protection;
primary via-blair;
}
...
...
...
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxTraffic-engineering bgp-igp-both-ribs
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxXXXXx
xxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxx xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxXXXxxxxxxxxxx [edit protocols mpls]
ps@dalwhinnie# show
traffic-engineering bgp-igp-both-ribs;
label-switched-path dalwhinnie-to-oban {
to 10.200.86.3;
link-protection;
primary via-blair;
}
[edit]
ps@dalwhinnie#
10.200.86.1/32
10.200.86.2/32
10.200.86.3/32
10.200.86.4/32
10.200.86.6/32
10.200.86.7/32
10.200.86.8/32
10.200.86.9/32
[edit]
ps@dalwhinnie#
10.200.86.1/32
10.200.86.2/32
10.200.86.3/32
10.200.86.4/32
10.200.86.5/32
10.200.86.6/32
10.200.86.7/32
10.200.86.8/32
10.200.86.9/32
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx Traffic-engineering
mpls-forwarding
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxXXXxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx [edit]
ps@dalwhinnie# run show route 10.200.86.3
inet.0: 34 destinations, 43 routes (33 active, 0 holddown, 1 hidden)
+ = Active Route, - = Last Active, * = Both
10.200.86.3/32
*[RSVP/7] 00:07:51, metric 3
> to 192.168.86.5 via ge-0/0/2.0, label-switched-path dalwhinnie-to-oban
to 192.168.86.29 via ge-0/0/3.0, label-switched-path Bypass->192.168.86.5
[LDP/9] 00:07:52, metric 1
> to 192.168.86.5 via ge-0/0/2.0, Push 300960
[OSPF/10] 00:30:06, metric 3
> to 192.168.86.5 via ge-0/0/2.0
inet.3: 8 destinations, 9 routes (8 active, 0 holddown, 0 hidden)
+ = Active Route, - = Last Active, * = Both
10.200.86.3/32
*[RSVP/7] 00:07:51, metric 3
> to 192.168.86.5 via ge-0/0/2.0, label-switched-path dalwhinnie-to-oban
to 192.168.86.29 via ge-0/0/3.0, label-switched-path Bypass->192.168.86.5
[LDP/9] 00:07:52, metric 1
> to 192.168.86.5 via ge-0/0/2.0, Push 300960
[edit]
ps@dalwhinnie# delete protocols mpls traffic-engineering bgp-igp-both-ribs
[edit]
ps@dalwhinnie# set protocols mpls traffic-engineering mpls-forwarding
[edit]
ps@dalwhinnie# commit
commit complete
[edit]
ps@dalwhinnie# run show route 10.200.86.3
inet.0: 34 destinations, 43 routes (33 active, 0 holddown, 1 hidden)
@ = Routing Use Only, # = Forwarding Use Only
+ = Active Route, - = Last Active, * = Both
10.200.86.3/32
@[OSPF/10] 00:31:57, metric 3
> to 192.168.86.5 via ge-0/0/2.0
#[RSVP/7] 00:00:10, metric 3
> to 192.168.86.5 via ge-0/0/2.0, label-switched-path dalwhinnie-to-oban
to 192.168.86.29 via ge-0/0/3.0, label-switched-path Bypass->192.168.86.5
[LDP/9] 00:00:11, metric 1
> to 192.168.86.5 via ge-0/0/2.0, Push 300960
inet.3: 8 destinations, 9 routes (8 active, 0 holddown, 0 hidden)
+ = Active Route, - = Last Active, * = Both
10.200.86.3/32
*[RSVP/7] 00:00:10, metric 3
> to 192.168.86.5 via ge-0/0/2.0, label-switched-path dalwhinnie-to-oban
to 192.168.86.29 via ge-0/0/3.0, label-switched-path Bypass->192.168.86.5
[LDP/9] 00:00:11, metric 1
> to 192.168.86.5 via ge-0/0/2.0, Push 300960
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx[edit]
ps@dalwhinnie# show protocols mpls
traffic-engineering bgp-igp-both-ribs;
...
...
IGP Shortcuts
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxXXXxxxxXXXXxXXXxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxXxxxxxx
xxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxXXXxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxx[edit]
ps@dalwhinnie# run show route 192.168.86.38
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXx
xXxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxx [edit protocols mpls]
ps@dalwhinnie# show
traffic-engineering bgp-igp-both-ribs;
label-switched-path dalwhinnie-to-oban {
to 10.200.86.3;
link-protection;
primary via-blair;
}
[edit]
ps@dalwhinnie# show protocols ospf
traffic-engineering {
shortcuts;
}
[edit]
ps@dalwhinnie# commit
commit complete
[edit]
ps@dalwhinnie# run traceroute 192.168.86.38 no-resolve
traceroute to 192.168.86.38 (192.168.86.38), 30 hops max, 40 byte packets
1 192.168.86.5 3.190 ms 2.776 ms 3.606 ms
MPLS Label=301168 CoS=0 TTL=1 S=1
2 192.168.86.9 2.676 ms 4.863 ms 2.578 ms
MPLS Label=301072 CoS=0 TTL=1 S=1
3 192.168.86.38 3.719 ms 3.799 ms 3.820 ms
NOTE Unlike OSPF, ISIS supports traffic-engineering and creation of a traffic-engineering database by
default. So adding the shortcuts configuration requires explicit configuration of traffic-engineering in ISIS.
NOTE Our example already had protocols mpls traffic-engineering configured before turning on the IGP
shortcuts. If protocols mpls traffic-engineering is not configured, the shortcuts configuration moves all IGP
addresses that could use an LSP as a next-hop into the inet.3 table, where they can be used as BGP
next-hops. In our example, because dalwhinnie already had traffic-engineering bgp-igp-both-ribs
configured, all IGP routes that could use an LSP as a next-hop were populated into the inet.0 table
instead.
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxXXXxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxx xxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxx xxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxXXXXxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxAdvertising LSPs Directly Into the IGP
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
XXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxXxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxXXXxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXX
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx [edit protocols ospf]
ps@lagavulin# show
traffic-engineering;
area 0.0.0.0 {
interface ge-0/0/2.0 {
interface-type p2p;
}
interface ge-0/0/3.0 {
interface-type p2p;
}
interface lo0.0;
label-switched-path lagavulin-to-oban {
metric 2;
}
label-switched-path lagavulin-to-tormore {
metric 2;
}
}
ps@lagavulin> show ospf neighbor
Address
Interface
State
ID
Pri Dead
192.168.86.1
ge-0/0/2.0
Full
10.200.86.8
128 32
192.168.86.30 ge-0/0/3.0
Full
10.200.86.5
128 35
10.200.86.3
lagavulin-to-oban
Full
10.200.86.3
0
0
10.200.86.9
lagavulin-to-tormore Full
10.200.86.9
0
0
ps@lagavulin> show ospf interface
Interface
State Area
DR ID
BDR ID
Nbrs
ge-0/0/2.0
PtToPt 0.0.0.0
0.0.0.0
0.0.0.0
1
ge-0/0/3.0
PtToPt 0.0.0.0
0.0.0.0
0.0.0.0
1
lagavulin-to-oban PtToPt 0.0.0.0
0.0.0.0
0.0.0.0
lagavulin-to-tormorePtToPt 0.0.0.0
0.0.0.0
0.0.0.0
lo0.0
DR
0.0.0.0
10.200.86.7
0.0.0.0
0
1
1
ps@lagavulin>
XxxxxxxxxxxxxxxXXXXxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxXXXxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxX
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxx
xxxxxxxxxxxxxXXXxxxps@lagavulin> show route 10.200.86.3
inet.0: 33 destinations, 33 routes (33 active, 0 holddown, 0 hidden)
+ = Active Route, - = Last Active, * = Both
10.200.86.3/32
*[OSPF/10] 00:12:56, metric 2
> to 192.168.86.1 via ge-0/0/2.0, label-switched-path lagavulin-to-oban
inet.3: 8 destinations, 8 routes (8 active, 0 holddown, 0 hidden)
+ = Active Route, - = Last Active, * = Both
10.200.86.3/32
*[RSVP/7] 00:12:51, metric 2
> to 192.168.86.1 via ge-0/0/2.0, label-switched-path lagavulin-to-oban
ps@lagavulin> show route 192.168.86.33
inet.0: 33 destinations, 33 routes (33 active, 0 holddown, 0 hidden)
+ = Active Route, - = Last Active, * = Both
192.168.86.32/30 *[OSPF/10] 00:09:43, metric 3
> to 192.168.86.1 via ge-0/0/2.0
to 192.168.86.1 via ge-0/0/2.0, label-switched-path lagavulin-to-tormore
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxXXXxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxx
xxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxXXXXxXxxxxxxXXXxxxxxXXXXxXXXxxxXXXxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxx
xxxxXXXxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxx
xxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXX
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxTIP
It is considered a best practice
to NOT implement both IGP shortcuts and LSP advertisement into IGP.
Policy-based LSP-mapping
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxX
XXxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxXXXXxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxX
XXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxXxxxx
xxxxxxxxxxxxxxxxxXXXXxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx [edit protocols ospf]
ps@lagavulin# show
traffic-engineering;
area 0.0.0.0 {
interface ge-0/0/2.0 {
interface-type p2p;
}
interface ge-0/0/3.0 {
interface-type p2p;
}
interface lo0.0 {
passive;
}
}
[edit protocols mpls]
ps@lagavulin# show
label-switched-path lagavulin-to-tormore {
to 10.200.86.9;
}
label-switched-path lagavulin-to-oban {
to 10.200.86.3;
primary via-blair;
}
label-switched-path lagavulin-to-oban-prime {
to 10.200.86.3;
primary via-talisker;
}
path via-blair {
10.200.86.1 loose;
}
path via-talisker {
10.200.86.4 loose;
}
interface ge-0/0/2.0;
interface ge-0/0/3.0;
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxXXXxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxX
XXxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxXXXxxxxxxxxxxxxps@lagavulin> show route protocol bgp range 172.16.0.0/22
inet.0: 36 destinations, 36 routes (36 active, 0 holddown, 0 hidden)
+ = Active Route, - = Last Active, * = Both
172.16.0.0/24
*[BGP/170] 00:00:25, localpref 100, from 10.200.86.3
AS path: I
to 192.168.86.1 via ge-0/0/2.0, label-switched-path lagavulin-to-oban
> to 192.168.86.1 via ge-0/0/2.0, label-switched-path lagavulin-to-oban-prime
172.16.1.0/24
*[BGP/170] 00:00:25, localpref 100, from 10.200.86.3
AS path: I
to 192.168.86.1 via ge-0/0/2.0, label-switched-path lagavulin-to-oban
> to 192.168.86.1 via ge-0/0/2.0, label-switched-path lagavulin-to-oban-prime
172.16.2.0/24
*[BGP/170] 00:00:25, localpref 100, from 10.200.86.3
AS path: I
to 192.168.86.1 via ge-0/0/2.0, label-switched-path lagavulin-to-oban
> to 192.168.86.1 via ge-0/0/2.0, label-switched-path lagavulin-to-oban-prime
172.16.3.0/24
*[BGP/170] 00:00:25, localpref 100, from 10.200.86.3
AS path: I
to 192.168.86.1 via ge-0/0/2.0, label-switched-path lagavulin-to-oban
> to 192.168.86.1 via ge-0/0/2.0, label-switched-path lagavulin-to-oban-prime
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxXxxxxxxxxxxxxxxxxx
xxxxxXXXxxxxxxxxxNOTE
The results above suggest that all traffic to routes within 172.16.0/22
will take the lagavulin-to-oban-prime LSP. However, by default, when there are multiple equal cost
paths to the same destination for an active route, the Junos OS uses a hash algorithm to choose
one of the next-hops to install into the forwarding-table
Figure 1.13
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx [edit policy-options]
ps@lagavulin# show
policy-statement map-routes-to-oban-lsps {
term 10 {
from {
protocol bgp;
neighbor 10.200.86.3;
route-filter 172.16.0.0/24 orlonger;
route-filter 172.16.1.0/24 orlonger;
}
then {
install-nexthop lsp lagavulin-to-oban;
accept;
}
}
term 20 {
from {
protocol bgp;
neighbor 10.200.86.3;
route-filter 172.16.2.0/24 orlonger;
route-filter 172.16.3.0/24 orlonger;
}
then {
install-nexthop lsp lagavulin-to-oban-prime;
accept;
}
}
}
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxx ps
@lagavulin> show route protocol bgp range 172.16.0.0/22
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
XXXxxxXxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxXxxxxxxxxxxxxxxxx xxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxX
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx TE Summary
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxXxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxTable 1.1
Summary of TE Options
}
...
...
It can be a fairly useful, if static, tool: it reserves bandwidth on each transit link, but
manual updates to each LSPs bandwidth are still necessary if the traffic on the LSP
continues to grow. Additionally, it may be inefficient to statically reserve a large
amount of bandwidth for an LSP for future growth if that LSP only needs to carry a
small amount of traffic in the near- to mid-term because that bandwidth reservation
may consume bandwidth needed for other LSPs. This option may be acceptable for
an LSP that carries a constant, easily predictable amount of traffic that is not expect
ed to grow very much, if at all. Happily, though, the Junos OS offers more dynamic
options to manage LSP bandwidth.
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxx
xxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx[edit protocols
mpls]
ps@lagavulin# show
statistics {
file auto-bw;
interval 600; ## interval to calculate average bandwidth usage; default is 300 seconds
auto-bandwidth;
}
label-switched-path lagavulin-to-oban {
to 10.200.86.3;
auto-bandwidth {
adjust-interval 7200; ## bandwidth reallocation interval; default is 86,400 seconds
adjust-threshold 20; ## specifies the sensitivity of the adjust-interval (optional)
minimum-bandwidth 64k; ## optional min bandwidth reservation for LSP
maximum-bandwidth 150m; ## optional hard max limit bandwidth reservation for LSP
}
primary via-blair;
}
TIP
It is considered a best practice to explicitly specify the values of the MPLS statistics interval
and the LSPs auto-bandwidth adjust-interval, even if you are using the default values. Doing so
helps to act as a reminder or a notice to Operations and Engineering as to what type of behavior to
expect from automatic bandwidth allocation and when to expect it.
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXx
xxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxThe average bandwidth on each LSP is measured
every 600 seconds.
The configured adjust-interval value of 7200 means that the lagavulin-to-oban LSP can adjust its
bandwidth allocation every 7200 seconds based on the traffic statistics for that period.
The LSPs adjust-threshold is 20%. If the current bandwidth allocation for this LSP is 100Mbps
and the bandwidth demand increases to 110 Mbps or decreases to 90 Mbps (10%), the LSPs
bandwidth allocation is not adjusted. But if the bandwidth demand increases to 125 Mbps or
decreases to 75 Mbps (25%), then the LSP bandwidth is adjusted to 125 Mbps or 75 Mbps,
respectively.
XxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
XxxxxxxxxxxxxxxxxxxxxxxxxTIP
When configuring the LSPs auto-bandwidth adjust-interval
and the MPLS statistics interval, it is a best practice to set the LSPs auto-bandwidth adjust-interval
at no less than three times the value of the MPLS statistics interval. Or, to put it mathematically,
3*(MPLS statistics interval) < = (LSP auto-bandwidth adjust-interval). This minimizes unnecessary
LSP resignaling by ensuring that the LSP has a minimum of three MPLS statistics batches to draw
upon before deciding if it needs to adjust its bandwidth allocation.
WARNING
As of this writing, some of the Junos documentation up to and including 10.0
incorrectly indicates that the LSP auto-bandwidth adjust-interval should be no MORE than three
times the value of the MPLS statistics interval (3*(MPLS statistics interval) > = (LSP auto-bandwidth
adjust-interval)). This is being remedied, but the remedy date for corrected documentation is
unknown at the time of this writing.
Monitor-only
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxx [edit protocols mpls]
ps@lagavulin# show label-switched-path lagavulin-to-oban-prime
to 10.200.86.3;
bandwidth 150m;
auto-bandwidth {
adjust-interval 86400;
monitor-bandwidth;
}
primary via-talisker;
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxManual Bandwidth Adjustment Trigger
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxx
xxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxp
s@lagavulin> request mpls lsp adjust-autobandwidth ?
Possible completions:
<[Enter]>
Execute this command
name
Regular expression for LSP names to match
|
Pipe through a command
ps@lagavulin> request mpls lsp adjust-autobandwidth
XxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxXXXxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxNOTE
When a manual
trigger for automatic bandwidth adjustment is used, the adjust-interval timer on each affected LSP
is not reset.
file auto-bw;
interval 600;
auto-bandwidth;
}
label-switched-path lagavulin-to-oban {
to 10.200.86.3;
auto-bandwidth {
adjust-interval 7200;
adjust-threshold 20;
minimum-bandwidth 64k;
maximum-bandwidth 150m;
}
primary via-blair;
}
XxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx ps@lag
avulin> show mpls lsp name lagavulin-to-oban detail
Ingress LSP: 6 sessions
10.200.86.3
From: 10.200.86.7, State: Up, ActiveRoute: 0, LSPname: lagavulin-to-oban
ActivePath: via-blair (primary)
LoadBalance: Random
Autobandwidth
MinBW: 64kbps MaxBW: 150Mbps
AdjustTimer: 7200 secs AdjustThreshold: 20%
Max AvgBW util: 90.4322Mbps, Bandwidth Adjustment in 6423 second(s).
Overflow limit: 0, Overflow sample count: 0
Encoding type: Packet, Switching type: Packet, GPID: IPv4
*Primary via-blair
State: Up
Priorities: 7 0
Bandwidth: 90.4322Mbps
SmartOptimizeTimer: 180
Computed ERO (S [L] denotes strict [loose] hops): (CSPF metric: 4)
192.168.86.30 S 192.168.86.5 S 192.168.86.9 S 192.168.86.25 S
Received RRO (ProtectionFlag 1=Available 2=InUse 4=B/W 8=Node 10=SoftPreempt 20=Node-ID):
192.168.86.30 192.168.86.5 192.168.86.9 192.168.86.25
...
...
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxXxxxxxxxxxxXxxxXxxXXxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxx ps@lagavulin> show mpls lsp
name lagavulin-to-oban extensive
Ingress LSP: 6 sessions
10.200.86.3
From: 10.200.86.7, State: Up, ActiveRoute: 0, LSPname: lagavulin-to-oban
ActivePath: via-blair (primary)
LoadBalance: Random
Autobandwidth
MinBW: 64kbps MaxBW: 150Mbps
AdjustTimer: 7200 secs AdjustThreshold: 20%
Max AvgBW util: 110.722Mbps, Bandwidth Adjustment in 6317 second(s).
Overflow limit: 0, Overflow sample count: 0
Encoding type: Packet, Switching type: Packet, GPID: IPv4
*Primary via-blair
State: Up
Priorities: 7 0
Bandwidth: 90.4322Mbps
SmartOptimizeTimer: 180
Computed ERO (S [L] denotes strict [loose] hops): (CSPF metric: 4)
192.168.86.30 S 192.168.86.5 S 192.168.86.9 S 192.168.86.25 S
Received RRO (ProtectionFlag 1=Available 2=InUse 4=B/W 8=Node 10=SoftPreempt 20=Node-ID):
192.168.86.30 192.168.86.5 192.168.86.9 192.168.86.25
...
...
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxps@lagavulin> request mpls lsp adjustautobandwidth name "lagavulin-to-oban"
ps@lagavulin> show mpls lsp name lagavulin-to-oban extensive
Ingress LSP: 6 sessions
10.200.86.3
From: 10.200.86.7, State: Up, ActiveRoute: 0, LSPname: lagavulin-to-oban
ActivePath: via-blair (primary)
LoadBalance: Random
Autobandwidth
MinBW: 64kbps MaxBW: 150Mbps
AdjustTimer: 7200 secs AdjustThreshold: 20%
Max AvgBW util: 111.402Mbps, Bandwidth Adjustment in 6302 second(s).
Overflow limit: 0, Overflow sample count: 0
Encoding type: Packet, Switching type: Packet, GPID: IPv4
*Primary via-blair
State: Up
Priorities: 7 0
Bandwidth: 110.722Mbps
SmartOptimizeTimer: 180
Computed ERO (S [L] denotes strict [loose] hops): (CSPF metric: 4)
192.168.86.30 S 192.168.86.5 S 192.168.86.9 S 192.168.86.25 S
Received RRO (ProtectionFlag 1=Available 2=InUse 4=B/W 8=Node 10=SoftPreempt 20=Node-ID):
192.168.86.30 192.168.86.5 192.168.86.9 192.168.86.25
11 Jan 5 08:05:25.662 Record Route: 192.168.86.30 192.168.86.5 192.168.86.9 192.168.86.25
10 Jan 5 08:05:25.662 Up
9 Jan 5 08:05:25.662 Automatic Autobw adjustment succeeded
8 Jan 5 08:05:25.629 Originate make-before-break call
...
...
ps@lagavulin> show log messages | match "bandwidth changed"
Jan 5 08:05:25 lagavulin rpd[1075]: RPD_MPLS_PATH_BANDWIDTH_CHANGE: MPLS path via-blair (lsp lagavulin-to-oban)
bandwidth changed, path bandwidth 110721928 bps
Jan 5 08:05:26 lagavulin rpd[1075]: RPD_MPLS_LSP_BANDWIDTH_CHANGE: MPLS LSP lagavulin-to-oban bandwidth changed,
lsp bandwidth 110721928 bps
Jan 6 05:41:26 lagavulin mgd[97769]: UI_CMDLINE_READ_LINE: User 'ps, command 'show log messages | match "bandwidth
changed" '
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxXxxxx
xXxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxXxxXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxXxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxWARNING
Automatic bandwidth allocation adjustment does not create
bandwidth, but can only act as a tool to help optimize existing bandwidth and assist in
understanding when it is time to augment the network. It is certainly not a substitute for proper
network planning, but rather a tool to assist in efficient utilization of existing resources.
XxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxx
xxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
XXXxxDid the average bandwidth utilization for the LSP during the interval exceed the current
maximum average bandwidth utilization?
Has the change in the maximum average bandwidth utilization exceeded the configured adjustthreshold?
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxXx
xXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxXxxxXxxXXxxxxxxxxxxxxxxxxxxxXxxxxxXxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxx
xxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxXxxxXxxXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxXxxXXxxxxxxxxxxxxxxxxxxxxxx
xxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxXxxxXxxXXxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx ps@lagavulin> show mpls
lsp name lagavulin-to-oban detail
Ingress LSP: 6 sessions
10.200.86.3
From: 10.200.86.7, State: Up, ActiveRoute: 0, LSPname: lagavulin-to-oban
ActivePath: via-blair (primary)
LoadBalance: Random
Autobandwidth
MinBW: 64kbps MaxBW: 150Mbps
AdjustTimer: 7200 secs AdjustThreshold: 20%
Max AvgBW util: 90.4322Mbps, Bandwidth Adjustment in 6423 second(s).
Overflow limit: 2, Overflow sample count: 0
Encoding type: Packet, Switching type: Packet, GPID: IPv4
*Primary via-blair
State: Up
Priorities: 7 0
Bandwidth: 25.6762Mbps
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxx
xxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxNOTE
As of the time of this writing, the adjust-threshold-overflow-limit can only increase
the LSPs bandwidth allocation; the ability to decrease LSP bandwidth allocation based on sudden
decreases in bandwidth is not available. Downward LSP resizing, if necessary, is done at the end of
each adjust-interval period.
Most-fill/least-fill/random
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxXXXxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxXxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxavailable bandwidth ratio = (available bandwidth)/(reservable bandwidth)
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxx [edit protocols mpls]
ps@dalwhinnie# run show rsvp interface
RSVP interface: 2 active
Active Subscr- Static
Available Reserved Highwater
Interface State resv iption BW
BW
BW
mark
ge-0/0/2.0 Up
1 100% 1000Mbps 850Mbps
150Mbps
150Mbps
xxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxx
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxXXxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxXxxxxxxxxXxxxxxxxxxxxxxIts possible to cap the amount of bandwidth that the RSVP protocol
can reserve on
an interface by specifying a bandwidth value in the [protocols rsvp] stanza. Here is
shown dalwhinnie.ge-0/0/2.0 capped at 500Mbps for RSVP bandwidth reservation.
[edit protocols rsvp]
ps@dalwhinnie# show interface ge-0/0/2.0
bandwidth 500m;
link-protection;
x[edit protocols]
ps@dalwhinnie# run show rsvp interface ge-0/0/2.0
Active Subscr- Static
Available Reserved Highwater
Interface State resv iption BW
BW
BW
mark
ge-0/0/2.0 Up
1 100% 500Mbps
350Mbps
150Mbps
150Mbps
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxx
xxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxTable 1.2 Most-fill/Least-fill/Random Behavior
xXxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx [edit
protocols mpls]
ps@lagavulin# show
...
...
label-switched-path lagavulin-to-oban {
to 10.200.86.3;
most-fill;
auto-bandwidth {
adjust-interval 7200;
adjust-threshold 20;
minimum-bandwidth 64k;
maximum-bandwidth 150m;
adjust-threshold-overflow-limit 2;
}
primary via-blair;
}
label-switched-path lagavulin-to-oban-prime {
to 10.200.86.3;
bandwidth 150m;
most-fill;
auto-bandwidth {
adjust-interval 86400;
}
primary via-talisker;
}
...
...
...
TIP
When using most-fill/least-fill/random for the CSPF tie-breaker, it is generally a best practice
to use only one method across all the LSPs in the network.
XxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxps@lagavulin> show mpls lsp name
lagavulin-to-oban detail
Ingress LSP: 6 sessions
10.200.86.3
From: 10.200.86.7, State: Up, ActiveRoute: 1, LSPname: lagavulin-to-oban
ActivePath: via-blair (primary)
LoadBalance: Most-fill
Autobandwidth
MinBW: 64kbps MaxBW: 150Mbps
AdjustTimer: 7200 secs AdjustThreshold: 20%
TIP
Configuring many options and features common to many or all of the LSPs may become
tedious. Junos groups (a type of template) can simplify configuration by applying common
configurations to selected LSPs. The example below applies auto-bandwidth attributes to all LSPs.
[edit]
ps@lagavulin# show
## Last changed: 2011-02-15 02:41:30 UTC
version 10.0R3.10;
groups {
LSP-ATTRIBUTES {
protocols {
mpls {
label-switched-path <*> {
auto-bandwidth {
adjust-interval 7200;
adjust-threshold 20;
minimum-bandwidth 64k;
maximum-bandwidth 150m;
}
}
}
}
}
}
apply-groups LSP-ATTRIBUTES;
...
...
[edit]
ps@lagavulin# show protocols mpls
statistics {
file auto-bw;
interval 600;
auto-bandwidth;
}
...
...
label-switched-path lagavulin-to-dalwhinnie {
to 10.200.86.5;
}
...
...
[edit]
ps@lagavulin# show protocols mpls | display inheritance
statistics {
file auto-bw;
interval 600;
auto-bandwidth;
}
...
...
label-switched-path lagavulin-to-dalwhinnie {
to 10.200.86.5;
##
## 'auto-bandwidth' was inherited from group 'LSP-ATTRIBUTES'
##
auto-bandwidth {
##
## '7200' was inherited from group 'LSP-ATTRIBUTES'
##
adjust-interval 7200;
##
## '20' was inherited from group 'LSP-ATTRIBUTES'
##
adjust-threshold 20;
##
## '64k' was inherited from group 'LSP-ATTRIBUTES'
##
minimum-bandwidth 64k;
##
## '150m' was inherited from group 'LSP-ATTRIBUTES'
##
maximum-bandwidth 150m;
}
}
...
...
[edit]
ps@lagavulin# run show mpls lsp name lagavulin-to-dalwhinnie detail
Ingress LSP: 5 sessions
10.200.86.5
From: 10.200.86.7, State: Up, ActiveRoute: 1, LSPname: lagavulin-to-dalwhinnie
ActivePath: (primary)
LoadBalance: Random
Autobandwidth
MinBW: 64kbps MaxBW: 150Mbps
AdjustTimer: 7200 secs AdjustThreshold: 20%
Max AvgBW util: 112bps, Bandwidth Adjustment in 216 second(s).
Overflow limit: 0, Overflow sample count: 0
Encoding type: Packet, Switching type: Packet, GPID: IPv4
*Primary
State: Up
Priorities: 7 0
Bandwidth: 64kbps
SmartOptimizeTimer: 180
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxx
xxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxMORE? An in-depth discussion on Junos groups
is beyond the scope of this book; more information on this Junos feature can be found in the Day
One book Configuring Junos Basics. A free download is available at www.juniper.net/dayone and
Summary
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxXXXXxxxxxxxxxxXXXxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx Chapter 2: MPLS Services Concepts 69
68
Introduction. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . 68
Layer 3
VPN. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 69
Layer 2 MPLS
VPN . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .77
VPLS. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . .91
Summary. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
. 98
XXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxXXXxxX
xXXXxxxXxxxxxxxXXXxxXxXXXxxxxxxxXXXXxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxIntroduction
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxXXxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxXxxxXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXx
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxXxxxxxxxxxxxXxxxxxxxxxxxXXxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxXXX
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxXxxxXxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXxx
xxxxxxxxxxxxxxxxxxXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxXXxxXxxxxxxxxxxxxxxxXXxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxXxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxXXxx
Figure 2.1
Figure 2.2 shows a generic network layout for CE, PE, and P routers, that well use in
this chapter as the generic starting point for a discussion on MPLS services. Depend
ing on network size, user requirements, potential for growth, and a host of other
factors, some router roles are often combined. A very common example of this is for
a single router to have both a PE and P role. Network architecture decisions such as
this are examined in Chapter 3. Note that due to this networks size and require
ments, Figure 2.2s PE routers also fulfill some roles of P routers in that they act as
paths for transit LSPs.
Figure 2.2
Layer 3 VPN
XxxxxxxxXXXxxXxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxx
xxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxx
xxxxxxxxXXXxxxxxxxxxxXxXxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxXxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXX
XxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXxxxxxxxxxxxxxxxxxxX
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXxxxxxXXxxxxxxxxxxxxxxxxx
xxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXX
XxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxXxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxx
xxXxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxMORE? The
L3VPN is based on the IETF RFC 4364. For more information, see http://tools.ietf.org/html/rfc4364.
Figure 2.3
XxxxxxxxxxxxxxxxxxxxxxXXxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxx
xxxxxxxxxxxxxxxxXXxXXXxxxxxxxxXxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxXXxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxXXxxxxxxxxxXxxxXXx
xxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxXXxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXxxxxxxxxxxxxxxxxxxxxXxXXxxxxxx
xxxxxXxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxx
xxxxxXXXxXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxXXxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxXXXxxx
xxxxxxXxxXxxxxxxxxxxxxxxxXXxxxxxxXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxXXXxxxxxxxxxXXxxx
XXxxxxxxxXXxxxxxxxxxxxxxxxxxxxxxxxxxxxXxXXXxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxXxxxxxxxxxxxxxxxxXXxxxxxxXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx Figure 2.4
MPLS Network with L3VPN Service
xxxxxxxxxxxxxxxxxXXxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxps@dalwhinnie> show route table bgp.l3vpn.0
bgp.l3vpn.0: 4 destinations, 4 routes (4 active, 0 holddown, 0 hidden)
+ = Active Route, - = Last Active, * = Both
192.168.90.14:20:172.17.0.0/24
*[BGP/170] 2d 13:53:39, localpref 100, from 10.200.86.3
AS path: 65432 I
> to 192.168.86.5 via ge-0/0/2.0, label-switched-path dalwhinnie-to-oban
to 192.168.86.29 via ge-0/0/3.0, label-switched-path dalwhinnie-to-oban
192.168.90.14:20:192.168.90.12/30
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxAt this point, dalwhinnies bgp.l3vpn.0 table shows four VPN-IPv4 routes it is
receiving from other PEs. How do dalwhinnies two configured L3VPN routinginstances know which routes to import? The routing-instances use the route-target
(RT) to make this determination.
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxXXXxxxxxxxxxxxxxxx
xxxxxps@dalwhinnie> show configuration routing-instances
aspen {
instance-type vrf;
interface ge-0/0/1.801;
route-distinguisher 192.168.90.6:20;
vrf-target target:100:200;
vrf-table-label;
protocols {
bgp {
group ce2 {
neighbor 192.168.90.6 {
peer-as 65432;
}
}
}
}
}
spruce {
instance-type vrf;
interface ge-0/0/1.800;
route-distinguisher 192.168.90.2:30;
vrf-target target:100:300;
vrf-table-label;
protocols {
bgp {
group ce1 {
neighbor 192.168.90.2 {
peer-as 65433;
}
}
}
}
}
XxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx xxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxps@dalwhinnie> show route 172.17.0.0/24 detail
aspen.inet.0: 4 destinations, 4 routes (4 active, 0 holddown, 0 hidden)
172.17.0.0/24 (1 entry, 1 announced)
*BGP Preference: 170/-101
Route Distinguisher: 192.168.90.14:20
...
...
...
Communities: target:100:200
Import Accepted
VPN Label: 16
Localpref: 100
Router ID: 10.200.86.3
Primary Routing Table bgp.l3vpn.0
spruce.inet.0: 4 destinations, 4 routes (4 active, 0 holddown, 0 hidden)
172.17.0.0/24 (1 entry, 1 announced)
*BGP Preference: 170/-101
Route Distinguisher: 192.168.90.18:30
...
...
...
Communities: target:100:300
Import Accepted
VPN Label: 16
Localpref: 100
Router ID: 10.200.86.9
Primary Routing Table bgp.l3vpn.0
bgp.l3vpn.0: 4 destinations, 4 routes (4 active, 0 holddown, 0 hidden)
192.168.90.14:20:172.17.0.0/24 (1 entry, 0 announced)
*BGP Preference: 170/-101
Route Distinguisher: 192.168.90.14:20
...
...
...
Communities: target:100:200
Import Accepted
VPN Label: 16
Localpref: 100
Router ID: 10.200.86.3
Secondary Tables: aspen.inet.0
192.168.90.18:30:172.17.0.0/24 (1 entry, 0 announced)
*BGP Preference: 170/-101
Route Distinguisher: 192.168.90.18:30
...
...
...
Communities: target:100:300
Import Accepted
VPN Label: 16
Localpref: 100
Router ID: 10.200.86.9
Secondary Tables: spruce.inet.0
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxSwap the 301328 label for the 301248 label.
Send the packet along the dalwhinnie-to-oban LSP.
Route the packet out interface ge-0/0/1.0 to the blair router.
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxps@blair> show route table mpls.0 label 301248 detail
mpls.0: 52 destinations, 52 routes (52 active, 0 holddown, 0 hidden)
. . . <truncated for brevity> . . .
301248 (S=0) (1 entry, 1 announced)
*RSVP Preference: 7
Next hop type: Router
Next-hop reference count: 1
Next hop: 192.168.86.25 via ge-6/0/0.0 weight 0x1, selected
Label-switched-path dalwhinnie-to-oban
Label operation: Pop
Next hop: 192.168.86.17 via ge-0/0/3.0 weight 0x8001
Label-switched-path Bypass->192.168.86.25
Label operation: Swap 299920
State: <Active Int>
NOTE The (S=0) entry in the mpls.0 table refers to a packet coming into the router with a label
stack depth of n>=2 exiting the router with a label stack depth of n-1. The information without the
S=0 label refers to a packet entering the router with a label stack depth of 1 and exiting the router
with no label. In the example above, the packet enters the router with a stack depth n=2.
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxps@oba
n> show route table mpls.0 label 16
mpls.0: 32 destinations, 32 routes (32 active, 0 holddown, 0 hidden)
+ = Active Route, - = Last Active, * = Both
16
*[VPN/0] 4d 17:56:27
to table aspen.inet.0, Pop
ps@oban>
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxXXxxxxxxXXxxxxps@oban> show route 192.168.90.14 table aspen detail
aspen.inet.0: 4 destinations, 4 routes (4 active, 0 holddown, 0 hidden)
192.168.90.12/30 (1 entry, 1 announced)
*Direct Preference: 0
Next hop type: Interface
Next-hop reference count: 1
Next hop: via ge-0/0/1.803, selected
State: <Active Int>
Age: 5d 18:11:12
Task: IF
Announcement bits (1): 1-BGP RT Background
AS path: I
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxx
Figure 2.5
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx xxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx xxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxps@lagavulin> show configuration routing-instances pine
instance-type l2vpn;
interface ge-0/0/1.802;
route-distinguisher 10.200.86.7:10;
vrf-target target:200:100;
protocols {
l2vpn {
encapsulation-type ethernet-vlan;
site ce3 {
site-identifier 3;
interface ge-0/0/1.802 {
remote-site-id 6;
}
}
}
}
XxxxxXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxXxxxXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx ps@lagavulin> show configuration
interfaces ge-0/0/1
vlan-tagging;
encapsulation vlan-ccc;
unit 400 {
vlan-id 400;
family inet {
address 192.168.90.17/30;
}
}
unit 802 {
description "to CE3";
encapsulation vlan-ccc;
vlan-id 802;
}
XxxxxxxxxxxxxXXXxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxMORE
?
For more information on ccc encapsulation on PE interfaces please see
http://www.juniper.net/techpubs/en_US/junos10.3/topics/usage-guidelines/vpns-configuring-cccencapsulation-for-layer-2-vpns.html. As of this writing, Junos 10.3 is the most recent Junos version.
MORE? For more information on using tcc encapsulation on PE interfaces please see
http://www.juniper.net/techpubs/en_US/junos10.3/information-products/topic-collections/configguide-vpns/index.html?topic-33769.html. As of this writing, Junos 10.3 is the most recent Junos
version.
L2VPN Control Plane
XXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxx
xxxxxxxxxxxxxxxxxxxxxxXXxxxxxxxxxxXxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxx ps@lagavulin> show configuration protocols bgp
family inet {
any;
}
family inet-vpn {
any;
}
family l2vpn {
signaling;
}
group ibgp {
type internal;
local-address 10.200.86.7;
. . . <snip> . . .
neighbor 10.200.86.9;
}
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxps@tormore> show route advertising-protocol
bgp 10.200.86.7 table pine
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxx
xxxxxxxxxxxXxxxXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
XXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxps@lagavulin> show route receive-protocol bgp 10.200.86.9 table
bgp.l2vpn.0 detail
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxps@lagavulin> show route receive-protocol bgp 10.200.86.9 table pine
pine.l2vpn.0: 2 destinations, 2 routes (2 active, 0 holddown, 0 hidden)
Prefix
Nexthop
MED
Lclpref AS path
10.200.86.9:10:6:3/96
*
10.200.86.9
100
I
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxx
xxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx ps@lagavulin> show route table pine
pine.l2vpn.0: 2 destinations, 2 routes (2 active, 0 holddown, 0 hidden)
+ = Active Route, - = Last Active, * = Both
10.200.86.7:10:3:5/96
*[L2VPN/170/-101] 2w4d 23:17:36, metric2 1
Indirect
10.200.86.9:10:6:3/96
*[BGP/170] 00:20:07, localpref 100, from 10.200.86.9
AS path: I
> to 192.168.86.1 via ge-0/0/2.0, label-switched-path lagavulin-to-tormore
to 192.168.86.1 via ge-0/0/2.0, label-switched-path lagavulin-to-tormore-v2
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx xxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx ps@lagavulin> show l2vpn connections extensive
Layer-2 VPN connections:
Legend for connection status (St)
EI -- encapsulation invalid
NC -- interface encapsulation not CCC/TCC/VPLS
. . .<truncated for brevity> . . .
PF -- Profile parse failure
PB -- Profile busy
RS -- remote site standby
Legend for interface status
Up -- operational
Dn -- down
Instance: pine
Local site: ce3 (3)
Number of local interfaces: 1
Number of local interfaces up: 1
ge-0/0/1.802
6
Label-base
Offset
Size Range
Preference
800000
5
2
2
100
status-vector: 0
connection-site
Type St
Time last up
# Up trans
6
rmt Up
Aug 24 04:50:31 2010
1
Remote PE: 10.200.86.9, Negotiated control-word: Yes (Null)
Incoming label: 800001, Outgoing label: 800000
Local interface: ge-0/0/1.802, Status: Up, Encapsulation: VLAN
Connection History:
Aug 24 04:50:31 2010 status update timer
Aug 24 04:50:30 2010 PE route changed
Aug 24 04:50:30 2010 Out lbl Update
800000
Aug 24 04:50:30 2010 In lbl Update
800001
Aug 24 04:50:30 2010 loc intf up
ge-0/0/1.802
NOTE At first glance, the l2vpn routes can appear to be a bit tough to understand. In a nutshell,
the first two parts (10.200.86.9:10 and :6, for example) are the configured RD of the router
advertising the route and the site ID where the advertisement is coming from. The last part (:3) is
the label-offset (this offset is generated automatically and is used internally to generate VPN
labels). The /96 indicates that the netmask for the 96 bit address is all 1s. See
http://tools.ietf.org/html/draft-kompella-l2vpn-l2vpn-00 for a more in-depth breakdown on each part
of the l2vpn route.
L2VPN Forwarding Plane
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxx xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxXXXxx
ps@lagavulin> show route table pine
pine.l2vpn.0: 2 destinations, 2 routes (2 active, 0 holddown, 0 hidden)
+ = Active Route, - = Last Active, * = Both
10.200.86.7:10:3:5/96
*[L2VPN/170/-101] 2w5d 22:06:26, metric2 1
Indirect
10.200.86.9:10:6:3/96
*[BGP/170] 23:08:57, localpref 100, from 10.200.86.9
AS path: I
> to 192.168.86.1 via ge-0/0/2.0, label-switched-path lagavulin-to-tormore
to 192.168.86.1 via ge-0/0/2.0, label-switched-path lagavulin-to-tormore-v2
XxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx ps@lagavulin>
show rsvp session lsp name lagavulin-to-tormore detail
Ingress RSVP: 10 sessions
10.200.86.9
From: 10.200.86.7, LSPstate: Up, ActiveRoute: 0
LSPname: lagavulin-to-tormore, LSPpath: Primary
Suggested label received: -, Suggested label sent: Recovery label received: -, Recovery label sent: 302160
Resv style: 1 FF, Label in: -, Label out: 302160
Time left: -, Since: Thu Aug 5 23:50:59 2010
Tspec: rate 0bps size 0bps peak Infbps m 20 M 1500
Port number: sender 1 receiver 34752 protocol 0
PATH rcvfrom: localclient
Adspec: sent MTU 1500
Path MTU: received 1500
PATH sentto: 192.168.86.1 (ge-0/0/2.0) 36871 pkts
RESV rcvfrom: 192.168.86.1 (ge-0/0/2.0) 36848 pkts
Explct route: 192.168.86.1 192.168.86.13 192.168.86.33
Record route: <self> 192.168.86.1 192.168.86.13 192.168.86.33
Total 1 displayed, Up 1, Down 0
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxps@macduff> show route table mpls.0 label 302160 detail
mpls.0: 35 destinations, 35 routes (35 active, 0 holddown, 0 hidden)
302160 (1 entry, 1 announced)
*RSVP Preference: 7
Next hop type: Router, Next hop index: 561
Next-hop reference count: 3
Next hop: 192.168.86.13 via ge-0/0/1.0 weight 0x1, selected
Label-switched-path lagavulin-to-tormore
Label operation: Swap 300144
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxps@talisker> show route table mpls.0 label 300144 detail
mpls.0: 43 destinations, 43 routes (43 active, 0 holddown, 0 hidden)
. . . <truncated for brevity> . . .
300144 (S=0)(1 entry, 1 announced)
*RSVP Preference: 7
Next hop type: Router, Next hop index: 592
Next-hop reference count: 2
Next hop: 192.168.86.33 via fe-2/0/1.0 weight 0x1, selected
Label-switched-path lagavulin-to-tormore
Label operation: Pop
. . . <truncated for brevity> . . .
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxXXxxxps@tormore> show route table mpls.0 label 800000
mpls.0: 21 destinations, 21 routes (21 active, 0 holddown, 0 hidden)
+ = Active Route, - = Last Active, * = Both
800000
*[L2VPN/7] 23:59:23
> via ge-0/0/1.802, Pop
Offset: 4
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
Figure 2.7
l2circuits
XxxxxxxxxxxxxxxxXxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxXxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxNOTE
Layer 2 circuits are based on IETF RFC
4447. That document is available at http://www.rfc-editor.org/rfc/rfc4447.txt.
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXXxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXxxxxxxxxxxxxxxxxxxxxxxxxxxxXXx
xxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxx [edit]
ps@dalwhinnie# show protocols l2circuit local-switching
interface ge-0/0/1.200 {
end-interface {
interface ge-0/0/3.200;
}
}
NOTE Since this book focuses on MPLS and MPLS services, further study of local-switching is
beyond its scope.
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxx
Figure 2.8
XxxXxxxxxxxxxxxxxxxXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXxxxxxxxxxxxxXxxxxxxxxxx
xxxxxxxxXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxXXxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxXXXxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxps@dalwhinnie> show configuration interfaces ge-0/0/1
vlan-tagging;
encapsulation vlan-ccc;
unit 403 {
description "to CE2";
vlan-id 403;
family inet {
address 192.168.90.5/30;
}
}
unit 805 {
description "to CE1";
encapsulation vlan-ccc;
vlan-id 805;
}
ps@dalwhinnie> show configuration protocols ldp
interface ge-0/0/2.0;
interface ge-0/0/3.0;
interface lo0.0;
ps@dalwhinnie> show configuration protocols l2circuit
neighbor 10.200.86.9 {
interface ge-0/0/1.805 {
virtual-circuit-id 10;
}
}
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx ps@tor
more> show configuration interfaces ge-0/0/1
vlan-tagging;
encapsulation vlan-ccc;
unit 802 {
description "to CE6";
encapsulation vlan-ccc;
vlan-id 802;
}
unit 805 {
description "to ce10";
encapsulation vlan-ccc;
vlan-id 805;
}
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
XXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxps
@tormore> show configuration protocols l2circuit
neighbor 10.200.86.5 {
interface ge-0/0/1.805 {
virtual-circuit-id 10;
}
}
ps@tormore> show ldp neighbor
Address
Interface
Label space ID
192.168.86.34
ge-0/0/2.0
10.200.86.4:0
192.168.86.38
ge-0/0/3.0
10.200.86.3:0
10.200.86.5
lo0.0
10.200.86.5:0
Hold time
11
14
37
XxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx ps@tormore> show route protocol ldp table l2circuit.0
extensive
l2circuit.0: 2 destinations, 2 routes (2 active, 0 holddown, 0 hidden)
10.200.86.5:CtrlWord:4:10:Remote/96 (1 entry, 1 announced)
*LDP Preference: 9
Next hop type: Discard
Next-hop reference count: 1
State: <Active Int>
Local AS: 7176
Age: 6d 7:24:08
Task: LDP
Announcement bits (1): 1-l2 circuit
AS path: I
VC Label 301136, MTU 1500, VLAN ID 805
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxx xxxxxxxxxxxxXxxxXxxxxxxxx
xXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxXxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxNOTE
The VC Label
300000 output beneath the L2CKT section means that tormore forwards packets that it receives
with label 300000 out its local CE-facing interface.
NOTE This output is a typical style for when an RSVP LSP is available between the circuit endpoint
routers. If the core is running LDP but not RSVP, the output would be similar, but would not have
the label-switched-path line; the label operation line would still be present, but the label shown
would be a label for an LDP LSP.
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
XXXXxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxps@talisker> show route table mpls.0 label 300592 detail
mpls.0: 43 destinations, 43 routes (43 active, 0 holddown, 0 hidden)
300592 (1 entry, 1 announced)
*RSVP Preference: 7
Next hop type: Router, Next hop index: 608
Next-hop reference count: 3
Next hop: 192.168.86.14 via fe-0/0/1.0 weight 0x1, selected
Label-switched-path tormore-to-dalwhinnie
Label operation: Swap 302368
. . . <truncated for brevity> . . .
ps@macduff> show route table mpls.0 label 302368 detail
mpls.0: 36 destinations, 36 routes (36 active, 0 holddown, 0 hidden)
302368 (1 entry, 1 announced)
*RSVP Preference: 7
Next hop type: Router, Next hop index: 596
Next-hop reference count: 3
Next hop: 192.168.86.2 via ge-0/0/2.0 weight 0x1, selected
Label-switched-path tormore-to-dalwhinnie
Label operation: Swap 299984
. . . <truncated for brevity> . . .
ps@lagavulin> show route table mpls.0 label 299984 detail
mpls.0: 11 destinations, 11 routes (11 active, 0 holddown, 0 hidden)
. . . <truncated for brevity> . . .
299984(S=0) (1 entry, 1 announced)
*RSVP Preference: 7
Next hop type: Router, Next hop index: 607
Next-hop reference count: 2
Next hop: 192.168.86.30 via ge-0/0/3.0 weight 0x1, selected
Label-switched-path tormore-to-dalwhinnie
Label operation: Pop
. . . <truncated for brevity> . . .
ps@dalwhinnie> show route table mpls.0 label 301136 detail
mpls.0: 15 destinations, 15 routes (15 active, 0 holddown, 0 hidden)
301136 (1 entry, 1 announced)
*L2CKT Preference: 7
Next hop type: Router, Next hop index: 571
Next-hop reference count: 2
Next hop: via ge-0/0/1.805, selected
Label operation: Pop
Offset: 4
Figure 2.9
xXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxXXxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxx
Figure 2.10
WARNING
It is important to understand that there is a Martini
encapsulation
, which describes
how layer 2 data is
encapsulated
when traversing an l2circuit or l2vpn and a Martini
tunnel
, which describes how the circuit is
signaled
. Martini tunnels (l2circuits) and
Kompella tunnels (l2vpn) use different signaling protocols (LDP and BGP, respec
tively), but use a common encapsulation (Martini encapsulation). In general,
Martini tunnels have wider vendor support, so they are typically preferred for
interop between different vendor PEs.
VPLS
XXXXxxxxxxxxxxxxXxxxxxxxXxxxxxxxXXXxXxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxXXxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxXXxxxxxxxxxXXXXxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxXXXxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxXxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxXXxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxx
xxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxx
xXXXXxxXXXxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxXXXxxxxxxx
xxxxxxxxxXXXxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxLDP signaled VPLS requires a full-mesh of LDP sessions between PE
routers; if a new router is added to the mesh, it requires provisioning the targeted LDP session to
that router on every other router in the mesh.
LDP requires manual provisioning of each circuit (via the neighbor statement within the VPLS
instance); BGP signaling has native auto-discovery.
NOTE Very recent developments (as of this writing) in LDP-VPLS do allow auto-discovery using
BGP. This does simplify provisioning, but still adds the extra protocol (LDP) to support VPLS. In
contrast, BGP-VPLS uses BGP for both signaling and auto-discovery.
BGP provides the signaling framework to provide all types of MPLS services (VPLS, layer 2 VPN,
and layer 3 VPN) in a scalable framework.
Hierarchical VPLS, a method to make LDP signaled VPLS more scalable, requires additional
capital in the form of layer 2 switches; BGP-signaled VPLS can scale without the additional layer 2
switches.
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXX
XxxxxxxxxxxxxxxxxxxxxXXXxxxxxXXXXxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxXXXXxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxXxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
XXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXxxx
xxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxx
Figure 2.11
VPLS Layout
XxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxx xxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxXXXXxXXXXxxxxxxxxxxxxxx family l2vpn {
signaling;
XxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxXxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx xxxxxxxxxxxXxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xps@lagavulin> show configuration interfaces ge-0/0/1
vlan-tagging;
encapsulation vlan-vpls;
unit 400 {
description "Internet connection";
vlan-id 400;
family inet {
address 192.168.90.17/30;
}
}
unit 804 {
description "VPLS to CE4";
encapsulation vlan-vpls;
vlan-id 804;
input-vlan-map pop;
output-vlan-map push;
family vpls;
}
NOTE Initially all the P and PE routers in the testbed (all J-series) were running Junos 9.6R4.4.
Junipers release notes for Junos 9.5 (http://www.juniper.net/techpubs/en_US/junos9.5/informationproducts/topic-collections/release-notes/9.5/j-series-new-features.html) state that VPLS support
begins in this load. However, attempting to configure VPLS on the J2350s resulted in a warning that
VPLS is not supported (see below). The routers running VPLS (coincidentally all were J2350s) were
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxXxxxxxxxXx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxXX
xxxxxxxxxxxxxxxxxxXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxNOTE
The MX
series routers do not have to use vlan-maps. See Appendix A for some MX-specific VPLS
configurations and capabilities.
Figure 2.12
The mechanics of the vlan-maps in Figure 2.12 shows the packet leaving router CE4
and arriving at lagavulin with a vlan-id of 804. The
input-vlan-map pop
on lagavu
lins ge-0/0/1.804 interface
pops
(similar to a label
pop
) the vlan-id tag from the
packet. The packet traverses the core, arriving at tormore. Upon egress from
tormore, the
output-vlan-map push
on ge-0/0/1.801
pushes
(similar to a label
push
)
the 801 vlan-id tag on to the packet and sends the packet to CE9. The
output-vlanmap push
function will automatically add the logical interfaces configured vlan-id to
the packet unless a different vlan-id is explicitly specified. If vlan-ids are the same at
every site in a given VPLS instance, then vlan-maps are not necessary.
XxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXxxxxxXXxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxXXXXxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXxxxxxxxxxxxxxxxxxxxxXXX
Xxxxxxxxxxxxps@lagavulin> show configuration routing-instances oak
instance-type vpls;
interface ge-0/0/1.804;
route-distinguisher 10.200.86.7:100;
vrf-target target:300:200;
protocols {
vpls {
site-range 5;
no-tunnel-services;
site ce4 {
site-identifier 1;
interface ge-0/0/1.804; ## matches interface to specific site
}
}
}
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxps@tormore> show configuration routing-instances oak
instance-type vpls;
interface ge-0/0/1.801;
route-distinguisher 10.200.86.9:100;
vrf-target target:300:200;
protocols {
vpls {
site-range 5;
no-tunnel-services;
site ce9 {
site-identifier 3;
interface ge-0/0/1.801; ## matches interface to specific site
}
}
Localpref: 100
AS path: I
Communities: target:300:200 Layer2-info: encaps:VPLS, control flags:, mtu: 0, site preference: 100
ps@lagavulin> show route receive-protocol bgp 10.200.86.3 detail table oak
oak.l2vpn.0: 3 destinations, 3 routes (3 active, 0 holddown, 0 hidden)
* 10.200.86.3:100:2:1/96 (1 entry, 1 announced)
Import Accepted
Route Distinguisher: 10.200.86.3:100
Label-base: 262145, range: 8
Nexthop: 10.200.86.3
Localpref: 0
AS path: I
Communities: target:300:200 Layer2-info: encaps:VPLS, control flags:Site-Down, mtu: 0, site preference: 100
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxXXxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxXXXXxxxxxxxxxxXxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxXxxxxxxxx
xxxxXXXxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxXxxxXXXxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
XxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxx
xxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxx
xxxxxps@lagavulin> show route forwarding-table vpn oak
Routing table: oak.vpls
VPLS:
Destination
Type RtRef Next hop
Type Index NhRef Netif
default
perm
0
rjct 565
1
lsi.1050113
user
0
comp 613
2
ge-0/0/1.804
user
0
comp 605
2
00:24:dc:df:07:05/48 dynm
0
indr 262150
4
192.168.86.1
Push 262145, Push 302160(top) 614 1 ge-0/0/2.0
00:26:88:03:1c:03/48 dynm
0
ucst 603
3 ge-0/0/1.804
10.200.86.7
Up
0 1 FF
- 302160 lagavulin-to-tormore
CAUTION
The next-hop label-switched-path for the specific MAC address in the VPLS
forwarding-table may not match the listed next-hop label-switched-path for the NLRI in the route
table if there are multiple, equal-cost LSPs between the ingress and egress PE routers. Notice that
the output below shows the label-switched-path lagavulin-to-tormore-v2 (instead of lagavulin-totormore in the preceding output) as the active path for the NLRI coming from tormore. In the case
of equal-cost paths, Junos uses a hashing algorithm to determine which path to use on a perdestination basis. In the case of VPLS, the hash determines the specific equal-cost LSP to reach a
given MAC:
ps@lagavulin> show route table oak
oak.l2vpn.0: 3 destinations, 3 routes (3 active, 0 holddown, 0 hidden)
+ = Active Route, - = Last Active, * = Both
. . . <snipped for brevity> . . .
10.200.86.9:100:3:1/96
*[BGP/170] 1w5d 20:37:32, localpref 100, from 10.200.86.9
AS path: I
to 192.168.86.1 via ge-0/0/2.0, label-switched-path lagavulin-to-tormore
> to 192.168.86.1 via ge-0/0/2.0, label-switched-path lagavulin-to-tormore-v2
Summary
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxXXXxxXxxxxxxxXXXxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxXxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx Chapter 3:
MPLS Core Implementations 101
100
This Week: Deploying MPLS
Purpose of Network. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
100
Router Roles. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
. 101
Core Label Distribution. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
105
Core MPLS Designs. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
106
MPLS Scaling. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
118
BGP Considerations. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
127
VPLS. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
. .137
Summary. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
.142
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxXxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx Purpose of Network
XxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxXXXXxXXXxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxPerformance
requirements: These are, admittedly, a very broad category, but the most commonly considered
performance requirements covered in this book are speed (latency), differences in latency (jitter),
bandwidth guarantees, prioritization (class-of-service), and class-based forwarding. Understanding
how the network needs to behave to meet these performance requirements will assist you in the
deployment of an IGP, and potentially MPLS metric schemes, class-of-service classification, and
scheduling parameters, and will likely play a major role in your traffic-engineering decisions.
Resiliency requirements: Resiliency is the ability of a network to adapt to a topology change.
Link down events are a great example of a topology change (a router down event is simply a super
set of a link down event), but link up events are just as important. How resilient a network needs to
be has a significant impact on your network design, specifically affecting timers, IGP and MPLS
resiliency features, and potentially class-of-service. Resiliency requirements and service
requirements are tightly coupled concepts. The question comes down to balancing resiliency and
complexity.
NOTE Complexity is a commonly underestimated consequence of network design. A network is
only as good as the operators ability to manage it.
:
.
.0 , ,
. , ,
. ,
, , ,
.
, ,
. (3 , 2 ,
)
.
.
.
, .
.
. :
.
The services offered on a network are always changing. Services are modified, extended,
removed, and added as fast as there is a profit to be made and this book in no way suggests that
doing it right in the beginning guarantees long-term success. Building a flexible and adaptive
network is what is important. The discussions and examples provided throughout this book seek to
help you build just that: a scalable, flexible, and most importantly, manageable MPLS network.
Router Roles
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxXxxxxxxxxxXxxxxxxxxxxxxxxxxxXxxxxxxxxXxxxxxXXxxxxxxxxxxXxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXxxx
xxxxxxxxXxxxXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXxxxxxxxxxxxxxxxxxxxxxXXxxxxxxxxxxxxxxXXXXxXXXxxxxXx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxXxXXxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxXXxxxxxxxxxxSeparated Provider (P)
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx Hybrid Provider (P) and
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxXxxxxxxxxxxxxXxxxxxxxxXxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXX
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxX
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx P/PE Design Selection
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxXxXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxEdge Connectivity
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxx
xxxxxxxxxxXxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxXx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxx
Figure 3.2
An U Edge Design
XxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxXxxxX
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
Figure 3.3
XxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxNOTE
Core ports are a finite sum
quantity and enough edge routers can consume all of these ports. A distribution layer may be
necessary in these cases, as shown in Figure 3.4.
Figure 3.4
XxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxXXxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxXxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxX
XxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xFinally, the other piece to this puzzle is whether edge routers exclusively serve edge
services. If traditional edge services are limited to edge routers only, the network can
support a separated P and PE network. If core ports provide edge services, then every
router in the network has the potential to be a PE and the network does not support
role separation in this way. Table 3.1 lists the possible combinations and P/PE
outcomes.
Table 3.1
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxXx
xxxxxxXXXxxxXxxxxxxxxxxxxXxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxx
xxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxx
xxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXX
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxXxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxXXXXxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxLDP in the Core
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXX
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx RSVP in the Core
XxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxXxxxxxxx
XXXxxxxxxXXXXxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxXXxXXX
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxXXXXxXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx Core
MPLS Designs
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxx
xxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxx
XXXxxxxxxxxxxxxxxxxxxxxxxxLDP-only Network
XxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxx
XxxxxxxxxxxxNOTE When using LDP, labels are bound to loopback addresses and exchanged
with LDP neighbors. A Juniper router will create a label for its own loopback address (generally a
label of 3), creates mappings for labels received from peers, and then advertises those local and
mapped labels to LDP peers.
XxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxps@mortlach> show route 10.200.86.4
inet.0: 13 destinations, 18 routes (13 active, 0 holddown, 0 hidden)
+ = Active Route, - = Last Active, * = Both
10.200.86.4/32
*[LDP/9] 00:00:04, metric 1
Selected route through blair (metric 20)
Figure 3.5
XxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxps@mortlach> show route table inet.3
inet.3: 3 destinations, 3 routes (3 active, 0 holddown, 0 hidden)
+ = Active Route, - = Last Active, * = Both
10.200.86.1/32
*[LDP/9] 00:08:50, metric 1
LDP label for blair, no label
> to 192.168.14.6 via ge-0/0/1.0
shown (label 3)
10.200.86.4/32
*[LDP/9] 00:01:12, metric 1
LDP label for talisker, via blair
> to 192.168.14.6 via ge-0/0/1.0, Push 100976
10.200.86.8/32
*[LDP/9] 00:08:49, metric 1
LDP label for macduff, no label
> to 192.168.14.1 via ge-0/0/1.0
shown (label 3)
If blair were to receive a packet with a label of 100976, it would consult its mpls table to find the label mapping for this label.
ps@blair> show route table mpls.0 label 100976
mpls.0: 8 destinations, 8 routes (8 active, 0 holddown, 0 hidden)
+ = Active Route, - = Last Active, * = Both
100976
*[LDP/9] 00:27:08, metric 1
to 192.168.14.14 via ge-0/0/1.0, Pop
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxThe important takeaway here is that LDP is not a routing
protocol. It simply distrib
utes labels and allows routers to associate them with selected routes. The IGP is still
the determining factor, meaning that an LDP network can be used to transport
mechanism for other protocols (or IP) for use with VPNs, but cannot be used for
other benefits associated with RSVP such as traffic-engineering and fast-reroute
(LDP fast-reroute is not yet standardized as of the writing of this book). If trafficengineering and improved resiliency are important aspects of your network, then
LDP should not be used as the primary label distribution protocol (it can be used in
conjunction with RSVP, which youll see later).
NOTE If the main goal of an MPLS design is its fast resiliency benefits, an alternative approach is
OSPF loop-free alternates (LFA). OSPF LFA provides fast failover without the MPLS overhead.
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxRSVP-TE
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxXxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxx
xxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxXXXxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxNOTE
LSP protection in any of its forms (Juniper fastreroute, secondary LSPs, link-protection, and link-node protection) can offer network resiliency that
cannot be attained through normal IP convergence, and this can be extremely valuable in
environments that support fault-sensitive traffic such as voice and video.
XXXXxXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
XXXxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxX
xxxxxxxxxxxxxxxXXxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxXXxxxxxxxxxxxxxxXxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
Figure 3.6
BGP-free Core
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxX
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxXXXxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXxxxxxxxxxxxxxxxxxxxxxxxXXxxXxxxxxxxxxxxxxxxxxxxxxxX
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxXXxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxXxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxXxxxxXXXxxxxxXXXXxXXxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxRSVP Full-mesh Network
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXxxxXxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxx
xxxxxxxxXXXXxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxx
xXXxXXxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxFor a
network with n routers, a full-mesh creates
n(n-1)
LSPs, because each router
must have an LSP to each other router. In a network with only 20 routers, this leads
to 380 LSPs. Grow the network to 100 routers and the LSP count is up to 9900, and
this best-case scenario is assuming two unidirectional LSPs between a given set of
routers and that no resiliency mechanism is used. For example, secondary LSPs
immediately double the total number of LSPs (as every LSP has a backup, secondary
LSP). Because LSP messaging is soft (think send it and forget it), there is no way
for a router to know if it has received all the messages sent by a peer and there is no
way for the sender to know if its intended target has received all of the messages it
sent. In a situation in which a transit router has thousands of LSPs and a link goes
down causing thousands of RSVP messages, it can become problematic if the sender
or receiver cannot keep up with the volume of messages. If this does happen,
head-end LSPs may continue sending packets into an LSP that is no longer up, which
ends up with dropped traffic. This, of course, gets resolved as soon as the IGP can
re-converge and RSVP can re-signal. However, if one of the goals of an RSVP
deployment was to improve resiliency, problems like these can be significant.
XxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxXXxxxxxxxxxxxXxXXXxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxXxxxXX
XXxXXXxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXX
XxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxXXXxxx
xxxxxxxxxxxxxxxxxxxIt receives an iBGP route from (can be an l3vpn route, VPLS route, or inet.0
route).
Has a lo0 address that resides in a specific address range.
NOTE Lab testing showed that in order for local router to spawn the RSVP auto-mesh LSPs, there
had to be a labeled route to the iBGP next-hop (the LSPs destination) in the inet.0 table. The
testing also showed that once the LSPs were up, the labeled route to the destination did not have
to be in inet.0 anymore. To create the labeled path in inet.0, we enabled the LDP protocol and
configured traffic-engineering bgp-igp-both-ribs under [protocols mpls], which created a labeled
path to the destination and added that destination to inet.0. After the auto-mesh LSPs established,
deactivating the LDP and traffic-engineering bgp-igp-both-ribs did not cause the auto-mesh LSPs to
be torn down. This was tested on an MX-80 router running Junos 10.3R1.9.Configure auto-mesh
under [routing-options dynamic-tunnels]:
ps@dalwhinnie> show configuration routing-options dynamic-tunnels
dt-default {
rsvp-te dt-default-1 {
label-switched-path-template {
default-template;
}
destination-networks {
10.200.86.0/24;
}
}
}
The label-switched-path-template in this example is the default-template; destina
tion-networks is the allowed address range for the LSP endpoints. Both configura
tions are required to be specified. This example creates an LSP to any router that
sends dalwhinnie an iBGP route and whose lo0 address falls within the 10.200.86/24
range.
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxps@dalwhinnie> show route table inet.3 protocol tunnel
inet.3: 2 destinations, 2 routes (2 active, 0 holddown, 0 hidden)
+ = Active Route, - = Last Active, * = Both
10.200.86.0/24
*[Tunnel/300] 01:13:13
Tunnel
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxXXXxxxxxxxxxxxxxxxxxxxxxxxxXxxxXXXxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxXxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxps@dalwhinnie> show route table inet.3 10.200.86.7 detail
inet.3: 2 destinations, 2 routes (2 active, 0 holddown, 0 hidden)
10.200.86.7/32 (1 entry, 1 announced)
State: <FlashAll>
*RSVP Preference: 7/3
Next hop type: Router, Next hop index: 663
Next-hop reference count: 10
Next hop: 192.168.86.6 via ge-0/0/2.0 weight 0x1, selected
Label-switched-path 10.200.86.7:dt-rsvp-dt-default
Label operation: Push 300000
State: <Active Int>
Local AS:
1
Age: 8:39
Metric: 2
Task: RSVP
Announcement bits (2): 1-Resolve tree 1 2-Resolve tree 3
AS path: I
ps@dalwhinnie> show route next-hop 10.200.86.7
inet.0: 22 destinations, 22 routes (21 active, 0 holddown, 1 hidden)
+ = Active Route, - = Last Active, * = Both
15.15.15.0/24
*[BGP/170] 00:59:38, localpref 100, from 10.200.86.7
AS path: I
> to 192.168.86.6 via ge-0/0/2.0, label-switched-path 10.200.86.7:dt-rsvp-dt-default
inet.3: 2 destinations, 2 routes (2 active, 0 holddown, 0 hidden)
mpls.0: 6 destinations, 6 routes (6 active, 0 holddown, 0 hidden)
bgp.l2vpn.0: 2 destinations, 2 routes (2 active, 0 holddown, 0 hidden)
+ = Active Route, - = Last Active, * = Both
xxxxxxxxxxxxxxxxxxxxxxx
*[BGP/170] 00:35:29, localpref 100, from 10.200.86.7
AS path: I
> to 192.168.86.6 via ge-0/0/2.0, label-switched-path 10.200.86.7:dt-rsvp-dt-default
oak.l2vpn.0: 2 destinations, 2 routes (2 active, 0 holddown, 0 hidden)
+ = Active Route, - = Last Active, * = Both
10.200.86.3:100:4:1/96
*[BGP/170] 00:09:22, localpref 100, from 10.200.86.7
AS path: I
> to 192.168.86.6 via ge-0/0/2.0, label-switched-path 10.200.86.7:dt-rsvp-dt-default
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxXxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxx
xxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxps@dalwhinnie> show configuration routing-options dynamictunnels
dt {
rsvp-te dt-1 {
label-switched-path-template {
dynamic-template;
}
destination-networks {
10.200.86.0/24;
}
}
}
ps@dalwhinnie> show configuration protocols mpls
traffic-engineering bgp-igp-both-ribs;
...
...
label-switched-path dynamic-template {
template;
link-protection;
}
interface ge-0/0/2.0;
interface ge-0/0/3.0;
ps@dalwhinnie> show mpls lsp ingress detail
Ingress LSP: 1 sessions
10.200.86.7
From: 10.200.86.4, State: Up, ActiveRoute: 1, LSPname: 10.200.86.7:dt-rsvp-dt
ActivePath: (primary)
Link protection desired
LSPtype: Dynamic Configured
LoadBalance: Random
Encoding type: Packet, Switching type: Packet, GPID: IPv4
*Primary
State: Up
Priorities: 7 0
SmartOptimizeTimer: 180
Computed ERO (S [L] denotes strict [loose] hops): (CSPF metric: 2)
192.168.86.6 S 192.168.86.10 S
Received RRO (ProtectionFlag 1=Available 2=InUse 4=B/W 8=Node 10=SoftPreempt 20=Node-ID):
10.200.86.2(flag=0x20) 192.168.86.6(Label=300048) 10.200.86.7(flag=0x20) 192.168.86.10(Label=3)
Total 1 displayed, Up 1, Down 0
XxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxXxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxx
xxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxx
XXXxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxXXXxxps@dalwhinnie> show configuration protocols mpls
traffic-engineering bgp-igp-both-ribs;
label-switched-path dalwhinnie-to-oban {
to 10.200.86.7;
link-protection;
}
LSPname
10.200.86.7:dt-rsvp-dt
dalwhinnie-to-oban
XXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxXxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxx
xxxxxxxxxxxxXXXxxxXxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx Hybrid LDP Edge and RSVP Core Network
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxx
xxxxxxXXXxxXxxxxxxxxXXXXxXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXX
xxxxxxxxxxxxxxXXXXxxxxxxxxxxXXXxxxxxxxxxxxxxxxXxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxXXXxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxXXXxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxXXXxxx
Figure 3.7
LDP Tunneling
XxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxX
XXxxxxxxxxxxxxxxxxxxxxxxxXXXXxXXXxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxXX
XxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxNotice the penultimate hop popping that occurs in Figure 3.8.
Taliskers penultimate
hop pops for the RSVP LSP from macduff to blair, sending just the LDP label to blair.
Blair, as the penultimate hop for the LDP LSP from lagavulin to oban, pops the LDP
label, sending just the IP packet to oban.
x
Figure 3.8
XxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxXXXxxxxxxxxxxxxxxxxx
xxxxxXxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx ps@macduff>
show configuration protocols mpls
label-switched-path macduff-to-blair {
to 10.200.86.1;
ldp-tunneling;
}
ps@macduff> show configuration protocols ldp
interface ge-0/0/2.0;
interface lo0.0;
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxNOTE
Both the macduff-to-blair and blair-to-macduff LSPs require ldptunneling to enable the bidirectional communication required for an LDP session. If the configuration
is not made on both sides, a session will be shown in show ldp neighbor command with no label
space ID and a hold time of 0 on the side with the configuration, as shown here:
Hold time
14
0
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx xxxxxxxx
xxxxxxxxxxxxxxxxxxxps@macduff> show ldp neighbor
Address
192.168.86.2
10.200.86.1
Interface
ge-0/0/2.0
lo0.0
Label space ID
10.200.86.7:0
10.200.86.1:0
Hold time
12
43
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXxxxxxXxxxxxxxxxxxxxxXXXxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxXXxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxx ps@lagavulin> show
route 10.200.86.3
inet.0: 16 destinations, 17 routes (16 active, 0 holddown, 0 hidden)
+ = Active Route, - = Last Active, * = Both
10.200.86.3/32
*[OSPF/10] 00:00:06, metric 4
> to 192.168.86.1 via ge-0/0/2.0
inet.3: 3 destinations, 3 routes (3 active, 0 holddown, 0 hidden)
+ = Active Route, - = Last Active, * = Both
10.200.86.3/32
*[LDP/9] 00:00:06, metric 1
> to 192.168.86.1 via ge-0/0/2.0, Push 104224
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xXXXXxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxx xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxps@lagavulin> show configuration protocols mpls
traffic-engineering bgp-igp;
interface ge-0/0/2.0;
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxps@lagavulin> show route 10.200.86.6
inet.0: 16 destinations, 20 routes (16 active, 0 holddown, 0 hidden)
+ = Active Route, - = Last Active, * = Both
10.200.86.6/32
*[LDP/9] 00:00:24, metric 1
> to 192.168.86.1 via ge-0/0/2.0, Push 104224
[OSPF/10] 00:00:24, metric 4
> to 192.168.86.1 via ge-0/0/2.0
NOTE Enabling the traffic-engineering bgp-igp knob causes the router to remove the route from the
inet.3 table, which might break certain MPLS VPN implementations. To work around this problem,
configure traffic-engineering bgp-ibgp-both-ribs under the [protocols mpls] stanza, which copies the route
from inet.3 to inet.0, as shown here:
ps@lagavulin> show route 10.200.86.6
inet.0: 16 destinations, 20 routes (16 active, 0 holddown, 0 hidden)
+ = Active Route, - = Last Active, * = Both
10.200.86.6/32
*[LDP/9] 00:00:05, metric 1
> to 192.168.86.1 via ge-0/0/2.0, Push 104224
[OSPF/10] 00:14:57, metric 4
> to 192.168.86.1 via ge-0/0/2.0
inet.3: 3 destinations, 3 routes (3 active, 0 holddown, 0 hidden)
+ = Active Route, - = Last Active, * = Both
10.200.86.6/32
*[LDP/9] 00:00:05, metric 1
> to 192.168.86.1 via ge-0/0/2.0, Push 104224
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxXX
XXxXXxXXXxxps@macduff> show route label 104224 detail
mpls.0: 11 destinations, 11 routes (11 active, 0 holddown, 0 hidden)
104224 (1 entry, 1 announced)
*LDP Preference: 9
Next hop type: Router, Next hop index: 477
Next-hop reference count: 2
Next hop: 192.168.86.13 via ge-0/0/1.0 weight 0x1, selected
Label-switched-path macduff-to-blair
Label operation: Swap 101440, Push 100512(top)
State: <Active Int>
Age: 15:56
Metric: 1
Task: LDP
Announcement bits (1): 0-KRT
AS path: I
Prefixes bound to route: 10.200.86.6/32
XxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxx ps@talisker> show route label
100512 detail
mpls.0: 5 destinations, 5 routes (5 active, 0 holddown, 0 hidden)
100512 (1 entry, 1 announced)
*RSVP Preference: 7
Next hop type: Router, Next hop index: 470
Next-hop reference count: 3
Next hop: 192.168.86.18 via fe-2/0/0.0 weight 0x1, selected
Label-switched-path macduff-to-blair
Label operation: Pop
State: <Active Int>
Age: 1:08:28 Metric: 1
Task: RSVP
Announcement bits (1): 0-KRT
AS path: I
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxXXXXxXXXxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxps@blair> show route label 101440 detail
mpls.0: 7 destinations, 7 routes (7 active, 0 holddown, 0 hidden)
101440 (1 entry, 1 announced)
*LDP Preference: 9
Next hop type: Router, Next hop index: 473
Next-hop reference count: 2
Next hop: 192.168.86.25 via ge-6/0/0.0, selected
Label operation: Pop
State: <Active Int>
Age: 32:25
Metric: 1
Task: LDP
Announcement bits (1): 0-KRT
AS path: I
Prefixes bound to route: 10.200.86.6/32
XxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxXXXXxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxXXXxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxMPLS Scaling
XXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXxxxxxxxxxxxxxxxxxxxxxxxxxXx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxXXXXxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxXxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxXXxX
XxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxXXxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxXXXxXXXXxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxXXXxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxx Hierarchical LSPs
XxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxx
xxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxNOTE
OSPF is required when implementing hierarchical LSPs.
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxXXXxxxxXXXxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxXXXxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxXXXXxxxxxXXXXxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
Figure 3.9
Hierarchical LSPs
xxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx ps@lagavulin> show configuration protocols
rsvp {
interface ge-0/0/1.0;
interface ge-0/0/2.0;
peer-interface peer-talisker;
}
mpls {
label-switched-path lagavulin-to-talisker {
to 10.200.86.4;
}
interface ge-0/0/1.0;
interface ge-0/0/2.0;
}
ospf {
traffic-engineering;
area 0.0.0.0 {
interface lo0.0 {
passive;
}
interface ge-0/0/1.0
interface ge-0/0/2.0;
peer-interface peer-talisker;
}
}
link-management {
te-link lagavulin-to-talisker-te {
local-address 192.168.87.1;
remote-address 192.168.87.2;
te-metric 1;
label-switched-path lagavulin-to-talisker;
}
peer peer-talisker {
address 10.200.86.4;
te-link lagavulin-to-talisker-te;
}
}
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxXXXXxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxXxxxxxxxxxxxxxxXXxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxXXXXxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxTIP If there are too many link-management peers and te-links to show at
one time, use the peer name peer name and te-link name te-link name arguments to limit the
output.
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx ps@lagavulin> show linkmanagement
Peer name: peer-talisker, System identifier: 55629
State: Up, Control address: 10.200.86.4
Hello interval: 150, Hello dead interval: 500
TE links:
lagavulin-to-talisker-te
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxx
xxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxx
xxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxXxxxxxxxxxxxxxxxxxxxxxXXXxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxx
xxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxXxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx ps@dalwhi
nnie> show mpls lsp name dalwhinnie-to-tormore detail
Ingress LSP: 1 sessions
10.200.86.9
From: 10.200.86.5, State: Up, ActiveRoute: 0, LSPname: dalwhinnie-to-tormore
ActivePath: (primary)
LoadBalance: Random
Encoding type: Packet, Switching type: Packet, GPID: IPv4
*Primary
State: Up
SmartOptimizeTimer: 180
Computed ERO (S [L] denotes strict [loose] hops): (CSPF metric: 60)
192.168.86.29 S 192.168.87.2 S 192.168.86.33 S
Received RRO (ProtectionFlag 1=Available 2=InUse 4=B/W 8=Node 10=SoftPreempt):
192.168.86.29 192.168.87.2 192.168.86.33
Total 1 displayed, Up 1, Down 0
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXX
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxps@dalwhinnie> show route 10.200.86.9 detail table inet.3
inet.3: 1 destinations, 1 routes (1 active, 0 holddown, 0 hidden)
10.200.86.9/32 (1 entry, 0 announced)
State: <FlashAll>
*RSVP Preference: 7
Next-hop reference count: 3
Next hop: 192.168.86.29 via ge-0/0/3.0 weight 0x1, selected
Label-switched-path dalwhinnie-to-tormore
Label operation: Push 300000
State: <Active Int>
Local AS:
1
Age: 7:28
Metric: 61
Task: RSVP
AS path: I
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx xx
xxxxxxxxxxxxxxxxxxps@lagavulin> show route label 300000 detail
mpls.0: 6 destinations, 6 routes (6 active, 0 holddown, 0 hidden)
300000 (1 entry, 1 announced)
*RSVP Preference: 7/1
Next hop type: Router, Next hop index: 526
Next-hop reference count: 3
Next hop: 192.168.86.1 via ge-0/0/2.0 weight 0x1, selected
Label-switched-path lagavulin-to-talisker
Label operation: Swap 299984, Push 299920(top)
State: <Active Int AckRequest>
Local AS:
1
Age: 7:45
Metric: 1
Task: RSVP
Announcement bits (1): 0-KRT
AS path: I
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxX
XXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx p
s@macduff> show mpls lsp
Ingress LSP: 0 sessions
Total 0 displayed, Up 0, Down 0
Egress LSP: 0 sessions
Total 0 displayed, Up 0, Down 0
Transit LSP: 2 sessions
To
From
State
10.200.86.4
10.200.86.7
10.200.86.7
10.200.86.4
Total 2 displayed, Up 2, Down
XxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxXXxxxxxxxxxxxxXxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxXxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxXXxxxxxxxxxxxxxxHierarchical RSVP Domains
XxxxxxxxxxxxxXXXXxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxXxx
xxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxXXxXXXxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxx
xxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxXXxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxXXXxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxXXXXxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxXxxXxxxxxx
xxxxxxxxxxXXxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxXxxxxxxxxxXxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxx
xxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxNOTE
The protocols ospf|isis traffic-engineering shortcuts and protocols mpls traffic-engineering bgp-igp-both-ribs are
both required for this design to work.
x
Figure 3.10
XxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxXxxxxxxxxxxxxxxxxxxxxxxxxxXXxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXx
xxxxxxxxxxxps@lagavulin> show route 4.2.2.1 detail
inet.0: 34 destinations, 45 routes (34 active, 0 holddown, 0 hidden)
4.2.2.0/24 (1 entry, 1 announced)
*BGP Preference: 170/-101
Next hop type: Indirect
Next-hop reference count: 3
Source: 10.200.86.3
Next hop type: Router, Next hop index: 465
Next hop: 192.168.86.1 via ge-0/0/2.0 weight 0x1, selected
Label-switched-path lagavulin-to-macduff
Protocol next hop: 10.200.86.3
Indirect next hop: 8a6d000 131070
State: <Active Int Ext>
Local AS:
1 Peer AS:
1
Age: 48:33
Metric2: 4
Task: BGP_1.10.200.86.3+51109
Announcement bits (2): 0-KRT 4-Resolve tree 2
AS path: I
Localpref: 100
Router ID: 10.200.86.3
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXxxxxXxXXXxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxps@lagavulin> show route 10.200.86.3 detail
inet.0: 16 destinations, 18 routes (16 active, 0 holddown, 0 hidden)
10.200.86.3/32 (1 entry, 1 announced)
*OSPF Preference: 10
Next hop type: Router, Next hop index: 462
Next-hop reference count: 24
Next hop: 192.168.86.1 via ge-0/0/2.0 weight 0x1, selected
Label-switched-path lagavulin-to-macduff
State: <Active Int>
Age: 13:03
Metric: 4
Area: 0.0.0.0
Task: OSPFv2
Announcement bits (1): 0-KRT
AS path: I
XxxxxxxxxxxxxxxxxxxxxXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxx ps@
macduff> show route 10.200.86.3 detail
inet.0: 18 destinations, 25 routes (18 active, 0 holddown, 0 hidden)
10.200.86.3/32 (1 entry, 1 announced)
*OSPF Preference: 10
Next hop type: Router, Next hop index: 472
Next-hop reference count: 10
Next hop: 192.168.86.13 via ge-0/0/1.0 weight 0x1, selected
Label-switched-path macduff-to-blair
Label operation: Push 100544
State: <Active Int>
Age: 10:19
Metric: 3
Area: 0.0.0.0
Task: OSPFv2
Announcement bits (1): 0-KRT
AS path: I
XxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxx ps@ma
cduff> show mpls lsp detail name macduff-to-blair | resolve
Ingress LSP: 5 sessions
blair
From: macduff, State: Up, ActiveRoute: 0, LSPname: macduff-to-blair
ActivePath: (primary)
LoadBalance: Random
Autobandwidth
AdjustTimer: 3600 secs
Max AvgBW util: 0bps, Bandwidth Adjustment in 886 second(s).
Overflow limit: 0, Overflow sample count: 0
Encoding type: Packet, Switching type: Packet, GPID: IPv4
*Primary
State: Up
SmartOptimizeTimer: 180
Computed ERO (S [L] denotes strict [loose] hops): (CSPF metric: 20)
talisker S blair S
Received RRO (ProtectionFlag 1=Available 2=InUse 4=B/W 8=Node 10=SoftPreempt):
192.168.86.13 192.168.86.18
Total 1 displayed, Up 1, Down 0
Egress LSP: 5 sessions
Total 0 displayed, Up 0, Down 0
Transit LSP: 4 sessions
Total 0 displayed, Up 0, Down 0
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxps@talisker> show route label 100544 detail
mpls.0: 5 destinations, 5 routes (5 active, 0 holddown, 0 hidden)
100544 (1 entry, 1 announced)
*RSVP Preference: 7
Next hop type: Router, Next hop index: 464
Next-hop reference count: 3
Next hop: 192.168.86.18 via fe-2/0/0.0 weight 0x1, selected
Label-switched-path macduff-to-blair
Label operation: Pop
State: <Active Int>
Age: 17:58
Metric: 1
Task: RSVP
Announcement bits (1): 0-KRT
AS path: I
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxXXxX
XXxxps@blair> show route 10.200.86.3 detail
inet.0: 18 destinations, 25 routes (18 active, 0 holddown, 0 hidden)
10.200.86.3/32 (2 entries, 1 announced)
State: <FlashAll>
*RSVP Preference: 7
Next hop type: Router, Next hop index: 475
Next-hop reference count: 6
Next hop: 192.168.86.25 via ge-6/0/0.0 weight 0x1, selected
Label-switched-path blair-to-oban
State: <Active Int>
Age: 12:18
Metric: 1
Task: RSVP
Announcement bits (2): 0-KRT 2-OSPFv2
AS path: I
XxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXX
XXxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXxxxxXxxxxxXxxxxXxXXXxxx
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx RSVP Refresh Reduction
XXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxXxxxxxxxx
XxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxReliable
messages: These messages add reliability to RSVP message exchanges by introducing a
MESSAGE_ID object to RSVP messages. If the ACK_Desired field is set on RSVP messages, the
receiver is to respond with a MESSAGE_ID_ACK message, which includes the MESSAGE_ID, allowing
the receiver to confirm receipt of the message.
:
.
, , , , , ,
.
Summary refresh messages: Summary refresh messages aggregate several Path and Resv
messages into a single update. MESSAGE_IDs are mapped to Path or Resv state, and a
MESSAGE_ID existing in a summary refresh message serves to update the associated Path or Resv
state.
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxx
xxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
XXXXxxxxxxxxxxxxps@oban> show rsvp session | count
Count: 7442 lines
ps@oban> show system uptime | match current
Current time: 2010-12-09 22:18:30 UTC
ps@oban> show rsvp statistics | match "^ Path |Sent.*Received"
Sent
Received
Sent
Received
Path
0
1
0
0
ps@oban> show system uptime | match current
Current time: 2010-12-09 22:20:29 UTC
ps@oban> show rsvp statistics | match "^ Path |Sent.*Received"
Sent
Received
Sent
Received
Path
3
27978
0
1269
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxps@oban> show configuration protocols rsvp
}
interface ge-0/0/2.0 {
aggregate;
XxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx ps@oban> show system uptime |
match current
Current time: 2010-12-09 22:40:31 UTC
ps@oban> show rsvp statistics | match "^ Path |Sent.*Received"
Sent
Received
Sent
Received
Path
0
0
0
0
ps@oban> show system uptime | match current
Current time: 2010-12-09 22:42:29 UTC
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxXXXXXXXxXXxxxxxXXXXXXXxXXxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx BGP Considerations
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxXXXxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxx
xxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxRoute-reflection in VPN Environments
XxxxxxxxxxxxxXXXxxxxxxxXXXXxXXXxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxXXxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxXXXxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxXXXXxxxxxxxxxxxxxxxXXxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxXxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxx
xxxxxxxxxxxxxxxxxxxXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxXxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxx
xxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxXXxxxxxxxxxxxxxxxx
xxxxxxxxxxxxXxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxx
Figure 3.11
XxxxxxxxxxxxxxxxxxxxxxxxxXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXxxxxxxxx
xxxxxxxxxxxxxxxxXXXxxxxxxxxXXXxxxxXxxxxxXXxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXxxxXx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXxxxxxxxxxxxxxxxxxxxx
xxxxxxxxXXXXxxxxxxxxxxXXXxxxxXXXXxxxps@blair> show route 10.200.86.3
inet.0: 18 destinations, 21 routes (18 active, 0 holddown, 0 hidden)
+ = Active Route, - = Last Active, * = Both
10.200.86.3/32
*[OSPF/10] 01:44:13, metric 1
> to 192.168.86.25 via 6/0/0.0
ps@blair> show route 10.200.86.7
inet.0: 18 destinations, 21 routes (18 active, 0 holddown, 0 hidden)
+ = Active Route, - = Last Active, * = Both
10.200.86.7/32
*[OSPF/10] 01:42:44, metric 3
to 192.168.86.49 via ge-0/0/2.0
> to 192.168.86.17 via ge-0/0/3.0
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxXXXXxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx Xxxxxxxxxxps@blair> show
route protocol bgp hidden detail
inet.0: 18 destinations, 21 routes (18 active, 0 holddown, 0 hidden)
__juniper_private2__.inet.0: 1 destinations, 1 routes (0 active, 0 holddown, 1 hidden)
bgp.l3vpn.0: 2 destinations, 2 routes (0 active, 0 holddown, 2 hidden)
1:1:1.1.1.0/24 (1 entry, 0 announced)
BGP Preference: 170/-101
Route Distinguisher: 1:1
Next hop type: Unusable
Next-hop reference count: 2
State: <Hidden Int Ext>
Local AS:
1 Peer AS:
1
Age: 1:18:09
Task: BGP_1.10.200.86.7+179
AS path: I
Communities: target:1:1
VPN Label: 16
Localpref: 100
Router ID: 10.200.86.7
1:2:2.2.2.0/24 (1 entry, 0 announced)
BGP Preference: 170/-101
Route Distinguisher: 1:2
Next hop type: Unusable
Next-hop reference count: 2
State: <Hidden Int Ext>
Local AS:
1 Peer AS:
1
Age: 1:18:13
Task: BGP_1.10.200.86.6+179
AS path: I
Communities: target:1:1
VPN Label: 16
Localpref: 100
Router ID: 10.200.86.3
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxXXxxxxxxxxxxps@blair> show route advertising-protocol bgp 10.200.86.3
ps@blair> show route advertising-protocol bgp 10.200.86.7
ps@blair>
XxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxXXXXxxxxxxxxxxxxxXXxxXxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxx ps@bla
ir> show route 10.200.86.3
inet.0: 18 destinations, 21 routes (18 active, 0 holddown, 0 hidden)
+ = Active Route, - = Last Active, * = Both
10.200.86.3/32
*[OSPF/10] 01:46:16, metric 1
> to 10.100.7.3 via ge-6/0/0.0
inet.3: 5 destinations, 5 routes (5 active, 0 holddown, 0 hidden)
+ = Active Route, - = Last Active, * = Both
10.200.86.3/32
*[LDP/9] 00:01:15, metric 1
> to 10.100.7.3 via ge-6/0/0.0
ps@blair> show route 10.200.86.7
inet.0: 18 destinations, 21 routes (18 active, 0 holddown, 0 hidden)
+ = Active Route, - = Last Active, * = Both
10.200.86.7/32
*[OSPF/10] 01:46:18, metric 3
to 192.168.86.49 via ge-0/0/2.0
> to 192.168.86.17 via ge-0/0/3.0
inet.3: 5 destinations, 5 routes (5 active, 0 holddown, 0 hidden)
+ = Active Route, - = Last Active, * = Both
10.200.86.7/32
*[LDP/9] 00:01:17, metric 1
> to 192.168.86.49 via ge-0/0/2.0, Push 103168
to 192.168.86.17 via ge-0/0/3.0, Push 100592
XxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXxxxxxxxxxxxxxx
xxxxxxxxxxps@blair> show route protocol bgp detail
inet.0: 18 destinations, 21 routes (18 active, 0 holddown, 0 hidden)
inet.3: 5 destinations, 5 routes (5 active, 0 holddown, 0 hidden)
__juniper_private2__.inet.0: 1 destinations, 1 routes (0 active, 0 holddown, 1 hidden)
mpls.0: 8 destinations, 8 routes (8 active, 0 holddown, 0 hidden)
bgp.l3vpn.0: 2 destinations, 2 routes (2 active, 0 holddown, 0 hidden)
1:1:1.1.1.0/24 (1 entry, 1 announced)
*BGP Preference: 170/-101
Route Distinguisher: 1:1
Next hop type: Indirect
Next-hop reference count: 1
Source: 10.200.86.7
Protocol next hop: 10.200.86.7
Push 16
Indirect next hop: 2 no-forward
State: <Active Int Ext>
Local AS:
1 Peer AS:
1
Age: 12:25
Metric2: 1
Task: BGP_1.10.200.86.7+56251
Announcement bits (1): 0-BGP RT Background
AS path: I
Communities: target:1:1
VPN Label: 16
Localpref: 100
Router ID: 10.200.86.7
1:2:2.2.2.0/24 (1 entry, 1 announced)
*BGP Preference: 170/-101
Route Distinguisher: 1:2
Next hop type: Indirect
Next-hop reference count: 1
Source: 10.200.86.3
Protocol next hop: 10.200.86.3
Push 16
Indirect next hop: 2 no-forward
State: <Active Int Ext>
Local AS:
1 Peer AS:
1
Age: 1:32:20 Metric2: 1
Task: BGP_1.10.200.86.6+179
Announcement bits (1): 0-BGP RT Background
AS path: I
Communities: target:1:1
VPN Label: 16
Localpref: 100
Router ID: 10.200.86.3
ps@blair> show route advertising-protocol bgp 10.200.86.7
bgp.l3vpn.0: 2 destinations, 2 routes (2 active, 0 holddown, 0 hidden)
Prefix
Nexthop
MED
Lclpref AS path
1:1:1.1.1.0/24
*
10.200.86.7
100
I
ps@blair> show route advertising-protocol bgp 10.200.86.3
bgp.l3vpn.0: 2 destinations, 2 routes (2 active, 0 holddown, 0 hidden)
Prefix
Nexthop
MED
Lclpref AS path
1:2:2.2.2.0/24
*
10.200.86.3
100
I
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxXxxXXXXxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
Figure 3.12
XxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxXXxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxAllowing VPN next-hop Resolution on Route-reflectors
NOTE This recommendation is specific to environments in which the route-reflector is either not in
the forwarding plane, or is a pure P router.
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxXX
xxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxX
XXXxxxxxxxxxxxxxxxxxxxXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxXXXxxxxxxxxxxxxxxxxxXXxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxx
xxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxps@blair> show bgp summary
Groups: 1 Peers: 2 Down peers: 0
Table
Tot Paths Act Paths Suppressed History Damp State Pending
inet.0
0
0
0
0
0
0
bgp.l3vpn.0
2
0
0
0
0
0
Peer
AS
InPkt
OutPkt OutQ Flaps Last Up/Dwn State|#Active/Received/Damped...
10.200.86.3
1
82
83
0
2
35:18 Establ
inet.0: 0/0/0
bgp.l3vpn.0: 0/1/0
10.200.86.7
1
80
81
0
10
34:36 Establ
inet.0: 0/0/0
bgp.l3vpn.0: 0/1/0
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxps@blair> show configuration routing-options
router-id 10.200.86.1;
autonomous-system 1;
resolution {
rib bgp.l3vpn.0 {
resolution-ribs inet.0;
}
}
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx ps@blair>
show bgp summary
Groups: 1 Peers: 2 Down peers: 0
Table
Tot Paths Act Paths Suppressed History Damp State Pending
inet.0
0
0
0
0
0
0
bgp.l3vpn.0
2
2
0
0
0
0
Peer
AS
InPkt
OutPkt OutQ Flaps Last Up/Dwn State|#Active/Received/Damped...
10.200.86.3
1
86
87
0
2
36:54 Establ
inet.0: 0/0/0
bgp.l3vpn.0: 1/1/0
10.200.86.7
1
84
85
0
10
36:12 Establ
inet.0: 0/0/0
bgp.l3vpn.0: 1/1/0
That was the simple approach. It is also possible to use a more complex design
utilizing rib-groups to share inet.0 routing information with inet.3, allowing VPN
route validation. However, before getting into the specifics, rib-groups in general
need further explanation, as they are one of the more confusing and frequently
misunderstood concepts in the Junos operating system.
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxNOTE Creating the rib-group requires a rib-group name, which can be any name
you wish, but descriptive names provide increased operational value.
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx ps@blair> show configuration routing-options
rib-groups {
inet.0-to-inet.3 {
import-rib [ inet.0 inet.3 ];
}
}
XXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxx xxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxps@blair> show configuration protocols ospf
rib-group inet.0-to-inet.3;
area 0.0.0.0 {
interface ge-0/0/1.0 {
interface-type p2p;
}
interface ge-0/0/2.0 {
interface-type p2p;
}
interface ge-0/0/3.0 {
interface-type p2p;
}
interface ge-6/0/0.0 {
interface-type p2p;
}
interface lo0.0;
}
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx ps@blair> show route table inet.3
inet.3: 12 destinations, 12 routes (12 active, 0 holddown, 0 hidden)
+ = Active Route, - = Last Active, * = Both
10.200.86.5/32
*[OSPF/10] 00:03:29, metric 1
> to 192.168.86.10 via ge-0/0/1.0
10.200.86.6/32
*[OSPF/10] 00:03:29, metric 1
> to 192.168.86.10 via ge-0/0/1.0
192.168.86.12/30
*[OSPF/10] 00:03:29, metric 3
> to 192.168.86.49 via ge-0/0/2.0
to 192.168.86.17 via ge-0/0/3.0
[]
XxxxxxxxxxxxXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXxxxxxxx
xxxxxps@blair> show bgp summary
Groups: 1 Peers: 2 Down peers: 0
Table
Tot Paths Act Paths Suppressed History Damp State Pending
inet.0
0
0
0
0
0
0
bgp.l3vpn.0
2
2
0
0
0
0
Peer
AS
InPkt
OutPkt OutQ Flaps Last Up/Dwn State|#Active/Received/Damped...
10.200.86.3
1
225
236
0
2
1:38:53 Establ
inet.0: 0/0/0
bgp.l3vpn.0: 1/1/0
10.200.86.7
1
225
234
0
10
1:38:11 Establ
inet.0: 0/0/0
bgp.l3vpn.0: 1/1/0
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxXx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxrouting-options {
rib inet.3 {
static {
route 0.0.0.0/0 discard;
}
}
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxps@blair> show configuration policy-options policy-statement Loopbacks-Only
term Loopbacks {
from {
route-filter 10.200.86.0/24 prefix-length-range /32-/32;
}
then accept;
}
term Reject-All-Else {
then reject;
}
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx ps@bl
air> show configuration routing-options
rib-groups {
inet.0-to-inet.3 {
import-rib [ inet.0 inet.3 ];
import-policy Loopbacks-Only;
}
}
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxXXxxxxxxxxxxxxxxxxxxxxxps@blair> show route table inet.3
inet.3: 5 destinations, 5 routes (5 active, 0 holddown, 0 hidden)
+ = Active Route, - = Last Active, * = Both
10.200.86.2/32
*[OSPF/10] 00:00:58, metric 1
> to 10.100.7.17 via ge-0/0/1.402
10.200.86.3/32
*[OSPF/10] 00:00:58, metric 1
> to 10.100.7.6 via ge-0/0/1.405
10.200.86.4/32
*[OSPF/10] 00:00:58, metric 1
> to 10.100.7.10 via ge-0/0/1.404
10.200.86.7/32
*[OSPF/10] 00:00:58, metric 3
to 10.100.7.17 via ge-0/0/1.402
> to 10.100.7.10 via ge-0/0/1.404
10.200.86.8/32
*[OSPF/10] 00:00:58, metric 2
to 10.100.7.17 via ge-0/0/1.402
> to 10.100.7.10 via ge-0/0/1.404
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxx
xxxxxxxxxps@blair> show bgp summary
Groups: 1 Peers: 2 Down peers: 0
Table
Tot Paths Act Paths Suppressed History Damp State Pending
inet.0
0
0
0
0
0
0
bgp.l3vpn.0
2
2
0
0
0
0
Peer
AS
InPkt
OutPkt OutQ Flaps Last Up/Dwn State|#Active/Received/Damped...
10.200.86.3
1
243
256
0
2
1:47:11 Establ
inet.0: 0/0/0
bgp.l3vpn.0: 1/1/0
10.200.86.7
1
244
255
0
10
1:46:29 Establ
inet.0: 0/0/0
bgp.l3vpn.0: 1/1/0
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxXXXxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxXXxxxxxxxxxxxxXxxxxxxxxxxx xxxxxxxx
xxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx BGP Route-target Family
XxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXxxxxxxxxxxxxxxxxxxxxxxxxxXxx
xxxxxxxxxxxxxxxxxxxxxXXxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxXxxxXxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxx xxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxXXxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxXXxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
Figure 3.13
XxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXxxx
xxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxXXxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXxxxxxxxxxxxxxxxxx ps@tormore> show
bgp summary
Groups: 1 Peers: 3 Down peers: 0
Table
Tot Paths Act Paths Suppressed History Damp State Pending
bgp.l3vpn.0
1
1
0
0
0
0
Peer
AS
InPkt
OutPkt OutQ Flaps Last Up/Dwn State|#Active/Rece
ived/Damped...
10.200.86.3
1
19
20
0
0
7:36 Establ
bgp.l3vpn.0: 0/0/0
10.200.86.5
1
18
20
0
0
7:30 Establ
bgp.l3vpn.0: 1/1/0
maple.inet.0: 1/1/0
10.200.86.7
1
20
21
0
0
7:42 Establ
bgp.l3vpn.0: 0/0/0
ps@tormore> show route advertising-protocol bgp 10.200.86.3
maple.inet.0: 3 destinations, 3 routes (3 active, 0 holddown, 0 hidden)
Prefix
Nexthop
MED
Lclpref AS path
* 5.5.5.0/24
Self
100
I
oban
dalwhinnie
lagavulin
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxXxxxxx
xxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxXXxxxxxxxxxxxxxxxxxxxxxXXxxxxxxxxxxxxxxxxxxxxXXXxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxps@tormore> show configuration protocols bgp
group ibgp {
type internal;
local-address 10.200.86.9;
family inet-vpn {
unicast;
}
family route-target;
neighbor 10.200.86.7;
neighbor 10.200.86.3;
neighbor 10.200.86.5;
}
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxps@tormore> show route table bgp.rtarget.0
bgp.rtarget.0: 2 destinations, 5 routes (2 active, 0 holddown, 0 hidden)
+ = Active Route, - = Last Active, * = Both
1:1:1/96
*[BGP/170] 00:01:58, localpref 100, from 10.200.86.3
AS path: I
> to 192.168.86.38 via ge-0/0/3.0
[BGP/170] 00:01:54, localpref 100, from 10.200.86.5
AS path: I
> to 192.168.86.38 via ge-0/0/3.0, Push 100496
to 192.168.86.34 via ge-0/0/2.0, Push 655505
[BGP/170] 00:02:03, localpref 100, from 10.200.86.7
AS path: I
*[RTarget/5] 00:02:15
Local
[BGP/170] 00:01:54, localpref 100, from 10.200.86.5
AS path: I
> to 192.168.86.38 via ge-0/0/3.0, Push 100496
to 192.168.86.34 via ge-0/0/2.0, Push 655505
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXxxx
xxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxXXxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxps@tormore> show route advertising-protocol bgp 10.200.86.3
oban
bgp.rtarget.0: 2 destinations, 5 routes (2 active, 0 holddown, 0 hidden)
Prefix
Nexthop
MED
Lclpref AS path
1:2:2/96
*
Self
100
I
ps@tormore> show route advertising-protocol bgp 10.200.86.5
maple.inet.0: 3 destinations, 3 routes (3 active, 0 holddown, 0 hidden)
Prefix
Nexthop
MED
Lclpref AS path
* 5.5.5.0/24
Self
100
I
bgp.rtarget.0: 2 destinations, 5 routes (2 active, 0 holddown, 0 hidden)
Prefix
Nexthop
MED
Lclpref AS path
1:2:2/96
*
Self
100
I
ps@tormore> show route advertising-protocol bgp 10.200.86.7
bgp.rtarget.0: 2 destinations, 5 routes (2 active, 0 holddown, 0 hidden)
Prefix
Nexthop
MED
Lclpref AS path
1:2:2/96
*
Self
100
I
dalwhinnie
lagavulin
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xXXXxxxxxxxxxxxxxxxVPLS
XXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxXXX
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxXxXXxxXXXxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxXXXxxxxxxxxxxxxxxxxXXXXxxxxxxxxxXxxxxxxxxxxxxxx P2MP LSPs
XxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxXxxXXXxxxXxxxxxxxxx
xxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxx
xxxxxxxxxXxXxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxXxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxx
xxxxxxxxxxxxxxxxxxxxxxxxxxP2MP LSPs solve the problem by implementing an LSP that is rooted
at the source
PE, but branches out to all receiver PEs within a VPLS instance, allowing common
links in different paths to carry only a single copy of the packet. The packet repli
cates only at branch points. Its very similar to IP multicast forwarding and its
important to understand that P2MP LSPs only carry BUM traffic; P2P LSPs carry
traffic destined for known MAC addresses and this is unicast traffic. Figures 3.14 and
3.15 illustrate the difference between P2P and P2MP forwarding. The first shows the
packet flows for BUM traffic in a P2P environment, while the second shows the same
flows with P2MP LSPs in use.
Figure 3.14
Figure 3.15
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXxXXXXxxxxxxxxxXXxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxXXXx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXxxxxxxxxxXXXXxxxxxxxxxXxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxXxXxXXXxxxxxxxxxxxxxxXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxXxXxXXXxxXxxxxXxXXxXXXxxxxxxxxxxxxxxXXxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxXXxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxXXxxXxXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxx
xxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxXXxXXXxxxxxxXXXXxxxxxxxxxxx
xxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxps@dalwhinnie> show configuration routing-instances oak
instance-type vpls;
interface ge-1/0/0.0;
route-distinguisher 10.200.86.1:100;
provider-tunnel {
rsvp-te {
label-switched-path-template {
default-template;
}
}
}
vrf-target target:300:200;
protocols {
vpls {
site-range 5;
no-tunnel-services;
site oak-ce1 {
site-identifier 1;
interface ge-1/0/0.0;
}
}
}
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxXxXXxXXXxxxxxxxxxxxxxxxxxxxxxxxXXxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxXxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxXXxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxXxXXxXXXxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxps@dalwhinnie> show
mpls lsp ingress
Ingress LSP: 3 sessions
To
From
State Rt P
10.200.86.3
10.200.86.1
Up
10.200.86.3
10.200.86.1
Up
10.200.86.5
10.200.86.1
Up
10.200.86.5
10.200.86.1
Up
Total 4 displayed, Up 4, Down 0
ActivePath
0*
0*
0*
0*
LSPname
dalwhinnie-to-macduff
10.200.86.3:10.200.86.1:100:vpls:oak
dalwhinnie-to-lagavulin
10.200.86.5:10.200.86.1:100:vpls:oak
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxXxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx ps@dalwhinnie> show mpls lsp
detail name 10.200.86.3:10.200.86.1:100:vpls:oak
Ingress LSP: 3 sessions
10.200.86.3
From: 10.200.86.1, State: Up, ActiveRoute: 0, LSPname: 10.200.86.3:10.200.86.1:100:vpls:oak
ActivePath: (primary)
P2MP name: 10.200.86.1:100:vpls:oak
PathDomain: Inter-domain
LSPtype: Dynamic Configured
LoadBalance: Random
Encoding type: Packet, Switching type: Packet, GPID: IPv4
*Primary
State: Up
Priorities: 7 0
SmartOptimizeTimer: 180
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx ps@dalwhinnie
> show configuration protocols mpls label-switched-path P2MP-template
template;
optimize-timer 35;
p2mp;
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXx
xxxxxxxxxxxxxxxxxxxxxxps@dalwhinnie> show configuration routing-instances oak
instance-type vpls;
interface ge-1/0/0.0;
route-distinguisher 10.200.86.1:100;
provider-tunnel {
rsvp-te {
label-switched-path-template {
P2MP-template;
}
}
}
vrf-target target:300:200;
protocols {
vpls {
site-range 6;
no-tunnel-services;
site vpls1-ce1 {
site-identifier 1;
interface ge-1/0/0.0;
}
}
}
XxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
ps@dalwhinnie> show mpls lsp detail name 10.200.86.3:10.200.86.1:100:vpls:oak
Ingress LSP: 3 sessions
10.200.86.3
From: 10.200.86.1, State: Up, ActiveRoute: 0, LSPname: 10.200.86.3:10.200.86.1:100:vpls:oak
ActivePath: (primary)
P2MP name: 10.200.86.1:100:vpls:oak
LSPtype: Dynamic Configured
LoadBalance: Random
Encoding type: Packet, Switching type: Packet, GPID: IPv4
*Primary
State: Up
Priorities: 7 0
OptimizeTimer: 35
SmartOptimizeTimer: 180
XxxxxxxxxxxxxxxxxxxxxxxxxxXxXXxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxXxXXXxxXxxxxxxxxxxxxxXXXxxxxxxxxx
xxxxFiltering BUM Traffic
XxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxXXxxxxXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxps@dalwhinnie> show configuration firewall
family vpls {
filter OakVplsBumFilter {
term LimitBroadcast {
from {
traffic-type broadcast;
}
then {
policer 50M-Policer;
accept;
}
}
term LimitMulticast {
from {
traffic-type multicast;
}
then {
policer 50M-Policer;
accept;
}
}
term LimitUnknownUnicast {
from {
traffic-type unknown-unicast;
}
then {
policer 50M-Policer;
accept;
}
}
term ExplicitPermit {
then accept;
}
}
}
policer 50M-Policer {
filter-specific;
if-exceeding {
bandwidth-limit 50m;
burst-size-limit 10m;
}
then discard;
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx ps@dalwhinnie> show configuration routinginstances oak
instance-type vpls;
interface ge-1/0/0.0;
route-distinguisher 10.200.86.1:100;
provider-tunnel {
rsvp-te {
label-switched-path-template {
default-template;
}
}
}
vrf-target target:300:200;
forwarding-options {
family vpls {
filter {
input OakVplsBumFilter;
}
}
}
Summary
XXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxX
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxx
Chapter 4: MPLS Deployment Examples
145
144
A Basic
Network. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .144
A Moderate Network. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
150
A Moderate Network Evolved. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
163
A Complex Network. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
180
Summary. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
.199
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxXXXXxX
XXxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx A Basic Network
IGP: OSPF
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxXxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx xxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxXxxxXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxXXXxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxx
xxxxxxXxxxXXxxxxxxxxxxxxxxxxxxxxxxxxXXXxXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxX
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXxxxxxXxxXxxxxxxxxxxxxxxXXxxxxxXxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxXxxxxxxxxxXxxxXxxxxxx Dalwhinnie (PE)
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxXXxxxxxxxxxxXxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxXXXxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxJunos Style
system {
host-name dalwhinnie;
root-authentication {
encrypted-password "$1$yCV3hpZD$EWpPM8TW8exo0r/6v.Yfk."; ## SECRET-DATA
}
login {
user ps {
uid 2003;
class super-user;
authentication {
encrypted-password "$1$9iVZGMcI$Bz5/GWXsO32k1s2a0iEo70"; ## SECRET-DATA
}
}
}
services {
ssh;
}
syslog {
user * {
any emergency;
}
file messages {
any notice;
authorization info;
}
file interactive-commands {
interactive-commands any;
}
}
}
interfaces {
ge-0/0/2 {
unit 0 {
description "Connection to glenlivet ge-0/0/2";
family inet {
address 192.168.86.6/30;
}
family mpls;
}
}
ge-0/0/3 {
unit 0 {
description "Connection to lagavulin ge-0/0/3";
family inet {
address 192.168.86.30/30;
}
family mpls;
}
}
lo0 {
unit 0 {
family inet {
address 10.200.86.5/32;
}
}
}
}
routing-options {
router-id 10.200.86.5;
autonomous-system 1;
}
protocols {
bgp {
group ibgp {
type internal;
local-address 10.200.86.5;
family inet {
unicast;
}
family inet-vpn {
unicast;
}
family l2vpn {
signaling;
}
neighbor 10.200.86.7;
neighbor 10.200.86.9;
neighbor 10.200.86.3;
}
}
ospf {
area 0.0.0.0 {
interface lo0.0;
interface ge-0/2/0.0;
interface ge-0/3/0.0;
}
}
ldp {
interface ge-0/2/0.0;
interface ge-0/3/0.0;
}
}
Set Style
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
Mortlach (P)
XxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxXX
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxXXX
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxJunos Style
system {
host-name mortlach;
root-authentication {
encrypted-password "$1$yCV3hpZD$EWpPM8TW8exo0r/6v.Yfk."; ## SECRET-DATA
}
login {
user ps {
uid 2005;
class super-user;
authentication {
encrypted-password "$1$20Y5E3.P$KCIi/yaB9hJ4Z4xy1XIAS1"; ## SECRET-DATA
}
}
}
services {
ssh;
}
syslog {
user * {
any emergency;
}
host 192.168.11.135 {
any info;
}
file messages {
any notice;
authorization info;
}
file interactive-commands {
interactive-commands any;
}
}
}
interfaces {
fe-0/0/1 {
unit 0 {
description "Connection to glenlivet ge-0/0/3";
family inet {
address 192.168.86.45/30;
}
family mpls;
}
}
fe-2/0/0 {
unit 0 {
description "Connection to blair ge-0/0/2";
family inet {
address 192.168.86.49/30;
}
family mpls;
}
}
e1-1/0/0 {
unit 0 {
description "Connection to talisker e1-1/0/0";
family inet {
address 192.168.86.22/30;
}
family mpls;
}
}
fe-2/0/1 {
unit 0 {
description "Connection to macduff ge-0/0/3";
family inet {
address 192.168.86.41/30;
}
family mpls;
}
}
lo0 {
unit 0 {
family inet {
address 10.200.86.2/32 {
primary;
}
}
}
}
}
routing-options {
router-id 10.200.86.2;
}
protocols {
ospf {
area 0.0.0.0 {
interface lo0.0;
interface fe-0/0/1.0;
interface e1-1/0/0.0;
interface fe-2/0/0.0;
interface fe-2/0/1.0;
}
}
ldp {
interface fe-0/0/1.0;
interface e1-1/0/0.0;
interface fe-2/0/0.0;
interface fe-2/0/1.0;
}
}
Set Style
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
A Moderate Network
IGP: IS-IS
IGP Scaling: None
Label distribution protocol: RSVP
BGP: Full edge mesh, BGP-free core
Additional requirements: Administrative group and static ERO based traffic engineering
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXxXXxxxxxxxxXX
XXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
Xxxxxxxxxxxx
Figure 4.2
The two dashed links in Figure 4.2 indicate a 100-megabit circuit (all of the other
circuits are 1 gigabit). Tormore sinks a lot of traffic, spiking to over 500 megabits
each from dalwhinnie and lagavulin, and as such, neither of these LSPs can traverse
the 100-megabit links. Also note that they cannot be allowed to traverse the same
link (except in failure mode). These LSPs will be configured with secondary LSPs to
protect against failure of any of the links in the primary explicit path. While these
secondary LSPs may cause an overutilization, the network is not rich enough to
provide a fully-redundant alternate path. The lagavulin to oban LSP frequently
transmits at up to 150 megabits and as a result, this LSP cannot traverse the
100-megabit links. Because this LSP, plus either of the static ERO LSPs (totaling 650
megabits), can share any of the 1-gigabit links, all you need to guard against is that
this LSP does not traverse the 100-megabit links a good use of administrative
groups.
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxXxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxXXXxxxxxxxxxxxxxXXxXXxxxxxx
xxxxXXxXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxDalwhinnie (PE)
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxJunos Style
system {
host-name dalwhinnie;
root-authentication {
encrypted-password "$1$yCV3hpZD$EWpPM8TW8exo0r/6v.Yfk."; ## SECRET-DATA
}
login {
user ps {
uid 2003;
class super-user;
authentication {
encrypted-password "$1$9iVZGMcI$Bz5/GWXsO32k1s2a0iEo70"; ## SECRET-DATA
}
}
}
services {
ssh;
}
syslog {
user * {
any emergency;
}
file messages {
any notice;
authorization info;
}
file interactive-commands {
interactive-commands any;
}
}
}
interfaces {
ge-0/0/2 {
unit 0 {
description "Connection to glenlivet ge-0/0/2";
family inet {
address 192.168.86.6/30;
}
family mpls;
}
}
ge-0/0/3 {
unit 0 {
description "Connection to lagavulin ge-0/0/3";
family inet {
address 192.168.86.30/30;
}
family mpls;
}
}
lo0 {
unit 0 {
family inet {
address 10.200.86.5/32;
}
family iso {
address 49.0001.1000.0000.0001.00;
}
}
}
}
routing-options {
router-id 10.200.86.5;
autonomous-system 1;
}
protocols {
rsvp {
interface ge-0/0/2.0;
interface ge-0/0/2.0;
}
mpls {
admin-groups {
blue 0;
red 1;
}
label-switched-path dalwhinnie-to-oban {
to 10.200.86.3;
}
label-switched-path dalwhinnie-to-lagavulin {
to 10.200.86.7;
}
label-switched-path dalwhinnie-to-tormore-primary {
to 10.200.86.9;
metric 100;
admin-group exclude [ blue red ];
}
label-switched-path dalwhinnie-to-tormore-secondary {
to 10.200.86.9;
metric 200;
}
interface ge-0/0/2.0;
interface ge-0/0/3.0;
}
bgp {
group ibgp {
type internal;
local-address 10.200.86.5;
family inet {
unicast;
}
family inet-vpn {
unicast;
}
family l2vpn {
signaling;
}
neighbor 10.200.86.7;
neighbor 10.200.86.9;
neighbor 10.200.86.3;
}
}
isis {
level 1 disable;
level 2 wide-metrics-only;
interface ge-0/0/2.0 {
level 1 disable;
}
interface ge-0/0/3.0 {
level 1 disable;
}
interface lo0.0 {
level 1 disable;
}
}
}
Set Style
set
set
set
set
set
set
set
set
system
system
system
system
system
system
system
system
host-name dalwhinnie
root-authentication encrypted-password "$1$yCV3hpZD$EWpPM8TW8exo0r/6v.Yfk."
login user ps uid 2003
login user ps class super-user
login user ps authentication encrypted-password "$1$9iVZGMcI$Bz5/GWXsO32k1s2a0iEo70"
services ssh
syslog user * any emergency
syslog file messages any notice
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
Lagavulin (PE)
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxXXXxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxJunos Style
system {
host-name lagavulin;
root-authentication {
encrypted-password "$1$O4d8X3vs$WPM4Gpe6Fy86YhU7CpvPe0"; ## SECRET-DATA
}
login {
user ps {
uid 2005;
class super-user;
authentication {
encrypted-password "$1$20Y5E3.P$KCIi/yaB9hJ4Z4xy1XIAS1"; ## SECRET-DATA
}
}
}
services {
ssh;
}
syslog {
user * {
any emergency;
}
file messages {
any notice;
authorization info;
}
file interactive-commands {
interactive-commands any;
}
}
}
interfaces {
ge-0/0/2 {
unit 0 {
description "Connection to macduff ge-0/0/2";
family inet {
address 192.168.86.2/30;
}
family iso;
family mpls;
}
}
ge-0/0/3 {
unit 0 {
description "Connection to dalwhinnie ge-0/0/3";
family inet {
address 192.168.86.29/30;
}
family iso;
family mpls;
}
}
lo0 {
unit 0 {
family inet {
address 10.200.86.7/32 {
primary;
}
}
family iso {
address 49.0001.1001.0000.0001.00;
}
}
}
}
routing-options {
router-id 10.200.86.7;
autonomous-system 1;
}
protocols {
rsvp {
interface all;
interface ge-0/0/2.0;
interface ge-0/0/3.0;
}
mpls {
admin-groups {
blue 0;
red 1;
}
label-switched-path lagavulin-to-dalwhinnie {
to 10.200.86.5;
}
label-switched-path lagavulin-to-tormore-primary {
to 10.200.86.9;
admin-group exclude blue;
}
label-switched-path lagavulin-to-tormore-secondary {
to 10.200.86.9;
metric 200;
}
label-switched-path lagavulin-to-oban {
to 10.200.86.3;
primary to-oban-primary;
secondary to-oban-secondary {
standby;
}
}
path to-oban-primary {
10.100.7.21 loose;
}
path to-oban-secondary;
interface ge-0/0/2.0;
interface ge-0/0/3.0;
}
bgp {
group ibgp {
type internal;
local-address 10.200.86.7;
family inet {
unicast;
}
family inet-vpn {
unicast;
}
family l2vpn {
signaling;
}
neighbor 10.200.86.5;
neighbor 10.200.86.3;
neighbor 10.200.86.9;
}
}
isis {
level 1 disable;
level 2 wide-metrics-only;
interface ge-0/0/2.0 {
level 1 disable;
}
interface ge-0/0/3.0 {
level 1 disable;
}
interface lo0.0 {
level 1 disable;
}
}
}
Set Style
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
Glenlivet (P)
XxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxx Junos Style
system {
host-name glenlivet;
root-authentication {
encrypted-password "$1$O4d8X3vs$WPM4Gpe6Fy86YhU7CpvPe0"; ## SECRET-DATA
}
login {
user ps {
uid 2005;
class super-user;
authentication {
encrypted-password "$1$20Y5E3.P$KCIi/yaB9hJ4Z4xy1XIAS1"; ## SECRET-DATA
}
}
}
services {
ssh;
}
syslog {
user * {
any emergency;
}
file messages {
any notice;
authorization info;
}
file interactive-commands {
interactive-commands any;
}
}
}
interfaces {
ge-0/0/1 {
unit 0 {
description "Connection to blair ge-0/0/1";
family inet {
address 192.168.86.10/30;
}
family iso;
family mpls;
}
}
ge-0/0/2 {
unit 0 {
description "Connection to dalwhinnie ge-0/0/2";
family inet {
address 192.168.86.5/30;
}
family iso;
family mpls;
}
}
ge-0/0/3 {
unit 0 {
description "Connection to mortlach fe-0/0/1";
family inet {
address 192.168.86.46/30;
}
family iso;
family mpls;
}
}
lo0 {
unit 0 {
family inet {
address 10.200.86.6/32;
}
family iso {
address 49.0001.1000.0000.0002.00;
}
}
}
}
routing-options {
router-id 10.200.86.6;
}
protocols {
rsvp {
interface ge-0/0/1.0;
interface ge-0/0/2.0;
interface ge-0/0/3.0;
}
mpls {
admin-groups {
blue 0;
red 1;
}
interface ge-0/0/1.0 {
admin-group blue;
}
interface ge-0/0/2.0;
interface ge-0/0/3.0;
}
isis {
level 1 disable;
level 2 wide-metrics-only;
interface ge-0/0/1.0 {
level 1 disable;
}
interface ge-0/0/2.0 {
level 1 disable;
}
interface ge-0/0/3.0 {
level 1 disable;
}
interface lo0.0 {
level 1 disable;
}
Set Style
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
Macduff (P)
XxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXX
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxJunos Style
system {
host-name macduff;
root-authentication {
encrypted-password "$1$yCV3hpZD$EWpPM8TW8exo0r/6v.Yfk."; ## SECRET-DATA
}
login {
user ps {
uid 2005;
class super-user;
authentication {
encrypted-password "$1$20Y5E3.P$KCIi/yaB9hJ4Z4xy1XIAS1"; ## SECRET-DATA
}
}
}
services {
ssh;
}
syslog {
user * {
any emergency;
}
file messages {
any notice;
authorization info;
}
file interactive-commands {
interactive-commands any;
}
}
}
interfaces {
ge-0/0/1 {
unit 0 {
description "Connection to talisker fe-0/0/1";
family inet {
address 192.168.86.14/30;
}
family iso;
family mpls;
}
}
ge-0/0/2 {
unit 0 {
description "Connection to lagavulin ge-0/0/2";
family inet {
address 192.168.86.1/30;
}
family iso;
family mpls;
}
}
ge-0/0/3 {
unit 0 {
description "Connection to mortlach fe-2/0/1";
family inet {
address 192.168.86.42/30;
}
family iso;
family mpls;
}
}
lo0 {
unit 0 {
family inet {
address 10.200.86.8/32 {
primary;
}
}
family iso {
address 49.0001.1003.0000.0001.00;
}
}
}
}
routing-options {
router-id 10.200.86.8;
}
protocols {
rsvp {
interface all;
interface ge-0/0/1.0;
interface ge-0/0/2.0;
interface ge-0/0/3.0;
}
mpls {
admin-groups {
blue 0;
red 1;
}
interface ge-0/0/1.0 {
admin-group red;
}
interface ge-0/0/2.0;
interface ge-0/0/3.0;
}
isis {
level 1 disable;
level 2 wide-metrics-only;
interface ge-0/0/1.0 {
level 1 disable;
}
interface ge-0/0/2.0 {
level 1 disable;
}
interface ge-0/0/3.0 {
level 1 disable;
}
interface lo0.0 {
level 1 disable;
}
Set Style
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
Dalwhinnie (PE)
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXxXXxxxxxxxxxxxxxxxxxxxxxxxxXxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxXXxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxJunos Style
system {
host-name dalwhinnie;
root-authentication {
encrypted-password "$1$yCV3hpZD$EWpPM8TW8exo0r/6v.Yfk."; ## SECRET-DATA
}
login {
user ps {
uid 2003;
class super-user;
authentication {
encrypted-password "$1$9iVZGMcI$Bz5/GWXsO32k1s2a0iEo70"; ## SECRET-DATA
}
}
}
services {
ssh;
}
syslog {
user * {
any emergency;
}
file messages {
any notice;
authorization info;
}
file interactive-commands {
interactive-commands any;
}
}
}
interfaces {
ge-0/0/2 {
unit 0 {
description "Connection to glenlivet ge-0/0/2";
family inet {
address 192.168.86.6/30;
}
family mpls;
}
}
ge-0/0/3 {
unit 0 {
description "Connection to lagavulin ge-0/0/3";
family inet {
address 192.168.86.30/30;
}
family mpls;
}
}
lo0 {
unit 0 {
family inet {
address 10.200.86.5/32;
}
family iso {
address 49.0001.0102.0008.6005.00;
}
}
}
}
routing-options {
router-id 10.200.86.5;
autonomous-system 1;
}
protocols {
bgp {
group ibgp {
type internal;
local-address 10.200.86.5;
neighbor 10.200.86.10;
neighbor 10.200.86.11;
}
}
isis {
level 1 wide-metrics-only;
level 2 disable;
interface ge-0/.500 {
level 2 disable;
}
interface ge-0/0/2.0 {
level 2 disable;
}
interface ge-0/0/3.0 {
level 2 disable;
}
}
ldp {
interface ge-0/0/2.0;
interface ge-0/0/3.0;
}
Set Style
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
Glenlivet (P)
The P routers are where things start getting more interesting. The P router IS-IS
configuration allows for Level 2 routes to be leaked into Level 1. This is necessary
for the PEs to install the IS-IS routes and associated LDP labels, otherwise, they
would only have the default route installed based on the attached bit from their
L1-L2 routers (their upstream P routers). Additionally, under the Junos [protocols
mpls] stanza, a statistics file has been configured and auto-bandwidth data collec
tion has been enabled. These statistics are gathered every 300 seconds by default,
but other values can be configured. Finally, each LSP has been configured with
ldp-tunneling as well as auto-bandwidth with an adjustment-interval of 3600
seconds (one hour). These statements instruct the router to exchange LDP labels with
the router on the remote side of the LSP (ldp-tunneling), and also to reserve band
width based on the average bandwidth utilization of the LSP over the last 3600
seconds. When that timer expires, the LSP is re-signaled with an updated bandwidth
reservation.
Junos Style
system {
host-name glenlivet;
root-authentication {
encrypted-password "$1$O4d8X3vs$WPM4Gpe6Fy86YhU7CpvPe0"; ## SECRET-DATA
}
login {
user ps {
uid 2005;
class super-user;
authentication {
encrypted-password "$1$20Y5E3.P$KCIi/yaB9hJ4Z4xy1XIAS1"; ## SECRET-DATA
}
}
}
services {
ssh;
}
syslog {
user * {
any emergency;
}
file messages {
any notice;
authorization info;
}
file interactive-commands {
interactive-commands any;
}
}
}
interfaces {
ge-0/0/1 {
unit 0 {
description "Connection to blair ge-0/0/1";
family inet {
address 192.168.86.10/30;
}
family iso;
family mpls;
}
}
ge-0/0/2 {
unit 0 {
description "Connection to dalwhinnie ge-0/0/2";
family inet {
address 192.168.86.5/30;
}
family iso;
family mpls;
}
}
ge-0/0/3 {
unit 0 {
description "Connection to mortlach fe-0/0/1";
family inet {
address 192.168.86.46/30;
}
family iso;
family mpls;
}
}
lo0 {
unit 0 {
family inet {
address 10.200.86.6/32;
}
family iso {
address 49.0001.0102.0008.6006.00;
}
}
}
}
routing-options {
router-id 10.200.86.6;
}
protocols {
rsvp {
interface ge-0/0/1.0;
interface ge-0/0/3.0;
}
mpls {
statistics {
file mpls-stats;
auto-bandwidth;
}
label-switched-path glenlivet-to-mortlach {
to 10.200.86.2;
ldp-tunneling;
auto-bandwidth {
adjust-interval 3600;
}
}
label-switched-path glenlivet-to-talisker {
to 10.200.86.4;
ldp-tunneling;
auto-bandwidth {
adjust-interval 3600;
}
}
label-switched-path glenlivet-to-macduff {
to 10.200.86.8;
ldp-tunneling;
auto-bandwidth {
adjust-interval 3600;
}
}
label-switched-path glenlivet-to-blair {
to 10.200.86.1;
ldp-tunneling;
auto-bandwidth {
adjust-interval 3600;
}
}
interface ge-0/0/1.0;
interface ge-0/0/3.0;
}
isis {
export PE-Loopbacks-to-Level-1;
level 2 wide-metrics-only;
level 1 wide-metrics-only;
interface ge-0/0/1.0 {
level 1 disable;
}
interface ge-0/0/2.0 {
level 2 disable;
}
interface ge-0/0/3.0 {
level 1 disable;
}
interface lo0.0 {
level 1 disable;
}
}
ldp {
interface ge-0/0/2.0;
interface lo0.0;
}
}
policy-options {
policy-statement PE-Loopbacks-to-Level-1 {
term Accept-Loopbacks {
from {
protocol isis;
route-filter 10.200.86.0/24 prefix-length-range /32-/32;
}
then accept;
}
term Accept-Direct {
from protocol direct;
then accept;
}
term Reject-All-Else {
then reject;
}
}
}
xxSet Style
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
Oban (PE)
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxJunos Style
system {
host-name oban;
root-authentication {
encrypted-password "$1$yCV3hpZD$EWpPM8TW8exo0r/6v.Yfk."; ## SECRET-DATA
}
login {
user ps {
uid 2005;
class super-user;
authentication {
encrypted-password "$1$20Y5E3.P$KCIi/yaB9hJ4Z4xy1XIAS1"; ## SECRET-DATA
}
}
}
services {
ssh;
}
syslog {
user * {
any emergency;
}
file messages {
any notice;
authorization info;
}
file interactive-commands {
interactive-commands any;
}
}
}
interfaces {
ge-0/0/2 {
unit 0 {
description "Connection to blair ge-6/0/0";
family inet {
address 192.168.86.25/30;
}
family iso;
family mpls;
}
ge-0/0/3 {
unit 0 {
description "Connection to tormore ge-0/0/3";
family inet {
address 192.168.86.38/30;
}
family iso;
family mpls;
}
}
lo0 {
unit 0 {
family inet {
address 10.200.86.3/32;
}
family iso {
address 49.0002.0102.0008.6003.00;
}
}
}
}
routing-options {
router-id 10.200.86.3;
autonomous-system 1;
}
protocols {
bgp {
group ibgp {
type internal;
local-address 10.200.86.3;
neighbor 10.200.86.10;
neighbor 10.200.86.11;
}
}
isis {
level 2 disable;
level 1 wide-metrics-only;
interface ge-0/0/2.0 {
level 2 disable;
}
interface ge-0/0/3.0 {
level 2 disable;
}
interface lo0.0 {
level 2 disable;
}
}
ldp {
interface ge-0/0/2.0;
interface ge-0/0/3.0;
}
}
Set Style
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
Blair (P)
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxXXxXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxJunos Style
system {
host-name blair;
root-authentication {
encrypted-password "$1$yCV3hpZD$EWpPM8TW8exo0r/6v.Yfk."; ## SECRET-DATA
}
login {
user ps {
uid 2005;
class super-user;
authentication {
encrypted-password "$1$20Y5E3.P$KCIi/yaB9hJ4Z4xy1XIAS1"; ## SECRET-DATA
}
}
}
services {
ssh;
}
syslog {
user * {
any emergency;
}
file messages {
any notice;
authorization info;
}
file interactive-commands {
interactive-commands any;
}
}
}
interfaces {
ge-0/0/0 {
unit 0 {
description "Connection to aberlour ge-0/0/0";
family inet {
address 192.168.86.53/30;
}
family iso;
family mpls;
}
}
ge-0/0/1 {
unit 0 {
description "Connection to glenlivet ge-0/0/1";
family inet {
address 192.168.86.9/30;
}
family iso;
family mpls;
}
}
ge-0/0/2 {
unit 0 {
description "Connection to mortlach fe-2/0/0";
family inet {
address 192.168.86.50/30;
}
family iso;
family mpls;
}
}
ge-0/0/3 {
unit 0 {
description "Connection to talisker fe-2/0/0";
family inet {
address 192.168.86.18/30;
}
family iso;
family mpls;
}
}
ge-6/0/0 {
unit 0 {
description "Connection to oban ge-0/0/2";
family inet {
address 192.168.86.26/30;
}
family iso;
family mpls;
}
}
lo0 {
unit 0 {
family inet {
address 10.200.86.1/32 {
primary;
}
}
family iso {
address 49.0002.0102.0008.6001.00;
}
}
}
}
routing-options {
router-id 10.200.86.1;
autonomous-system 1;
}
protocols {
rsvp {
interface ge-0/0/1.0;
interface ge-0/0/2.0;
interface ge-0/0/3.0;
}
mpls {
statistics {
file mpls-stats;
auto-bandwidth;
}
label-switched-path blair-to-glenlivet {
to 10.200.86.6;
ldp-tunneling;
auto-bandwidth {
adjust-interval 3600;
}
}
label-switched-path blair-to-mortlach {
to 10.200.86.2;
ldp-tunneling;
auto-bandwidth {
adjust-interval 3600;
}
}
label-switched-path blair-to-talisker {
to 10.200.86.4;
ldp-tunneling;
auto-bandwidth {
adjust-interval 3600;
}
}
label-switched-path blair-to-macduff {
to 10.200.86.8;
ldp-tunneling;
auto-bandwidth {
adjust-interval 3600;
}
}
interface ge-0/0/1.0;
interface ge-0/0/2.0;
interface ge-0/0/3.0;
}
isis {
export PE-Loopbacks-to-Level-1;
level 2 wide-metrics-only;
level 1 wide-metrics-only;
interface ge-0/0/0.0 {
level 2 disable;
}
interface ge-0/0/1.0 {
level 1 disable;
}
interface ge-0/0/2.0 {
level 1 disable;
}
interface ge-0/0/3.0 {
level 1 disable;
}
interface ge-6/0/0.0 {
level 2 disable;
}
interface lo0.0 {
level 1 disable;
}
}
ldp {
interface ge-6/0/0.0;
interface lo0.0;
}
}
policy-options {
policy-statement PE-Loopbacks-to-Level-1 {
term Accept-Loopbacks {
from {
protocol isis;
route-filter 10.200.86.0/24 prefix-length-range /32-/32;
}
then accept;
}
term Accept-Direct {
from protocol direct;
then accept;
}
term Reject-All-Else {
then reject;
}
}
}
Set Style
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
Aberlour (RR)
The route-reflector configuration is very simple. It is configured with IS-IS on its
connection to blair and BGP sessions to its route-reflector clients (group rr-clients), as
well as a BGP session to the other route-reflector (laphroaig). The configuration cited
here provides a redundant mechanism for BGP route distribution. For more redun
dancy, a second connection could be added to each route-reflector, but the dual
route-reflector design does remove an important single point of failure.
Junos Style
system {
host-name aberlour;
root-authentication {
encrypted-password "$1$O4d8X3vs$WPM4Gpe6Fy86YhU7CpvPe0"; ## SECRET-DATA
}
login {
user ps {
uid 2005;
class super-user;
authentication {
encrypted-password "$1$20Y5E3.P$KCIi/yaB9hJ4Z4xy1XIAS1"; ## SECRET-DATA
}
}
}
services {
ssh;
}
syslog {
user * {
any emergency;
}
file messages {
any notice;
authorization info;
}
file interactive-commands {
interactive-commands any;
}
}
}
interfaces {
ge-0/0/0 {
unit 0 {
description "Connection to blair ge-0/0/0";
family inet {
address 192.168.86.54/30;
}
family iso;
}
}
lo0 {
unit 0 {
family inet {
address 10.200.86.10/32;
}
family iso {
address 49.0002.0102.0008.6010.00;
}
}
}
}
routing-options {
router-id 10.200.86.10;
autonomous-system 1;
}
protocols {
bgp {
group rr-clients {
type internal;
local-address 10.200.86.10;
cluster 10.200.86.10;
neighbor 10.200.86.3;
neighbor 10.200.86.5;
neighbor 10.200.86.7;
neighbor 10.200.86.9;
}
group ibgp {
type internal;
local-address 10.200.86.10;
neighbor 10.200.86.11;
}
}
isis {
level 1 disable;
level 2 wide-metrics-only;
interface ge-0/0/0 {
level 1 disable;
}
interface lo0.0 {
level 1 disable;
}
}
Set Style
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
A Complex Network
IGP: OSPF
IGP Scaling: Single area
Label distribution protocol: Hierarchical LSPs
RSVP Scaling: Refresh-reductionBGP: Route-reflection
Growth expectation: Moderate growth
Additional requirements: Fast resiliency, efficient use of bandwidth, support of MPLS VPN services
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxXXXXxXXXxxxxxxxxxxxXxxxxxxxXXXxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxXXXXxXXxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxXxxxxxXXXXxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxx xxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxx
Figure 4.4
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxXxxxxXXXxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxDalwhinnie (PE)
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxx
xxxxxxxxxxxxXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxXXXxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxXxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxX
XXXxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxXXxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxXxxxxxxxXXXxxx Junos Style
system {
host-name dalwhinnie;
root-authentication {
encrypted-password "$1$yCV3hpZD$EWpPM8TW8exo0r/6v.Yfk."; ## SECRET-DATA
}
login {
user ps {
uid 2002;
class super-user;
authentication {
encrypted-password "$1$Vlgdcorz$TRO4TJKkijW62WJtol2EP1"; ## SECRET-DATA
}
}
}
services {
ssh;
}
syslog {
user * {
any emergency;
}
file messages {
any notice;
authorization info;
}
file interactive-commands {
interactive-commands any;
}
}
}
interfaces {
ge-0/0/2 {
unit 0 {
description "Connection to glenlivet ge-0/0/2";
family inet {
address 192.168.86.6/30;
}
family mpls;
}
}
ge-0/0/3 {
unit 0 {
description "Connection to lagavulin ge-0/0/3";
family inet {
address 192.168.86.30/30;
}
family mpls;
}
}
lo0 {
unit 0 {
family inet {
address 10.200.86.5/32;
}
}
}
}
routing-options {
router-id 10.200.86.5;
autonomous-system 1;
}
protocols {
rsvp {
interface ge-0/0/2.0 {
aggregate;
link-protection;
}
interface ge-0/0/3.0 {
aggregate;
link-protection;
}
}
mpls {
statistics {
file mpls-stats.txt;
auto-bandwidth;
}
label-switched-path dalwhinnie-to-oban {
to 10.200.86.3;
most-fill;
link-protection;
auto-bandwidth;
}
label-switched-path dalwhinnie-to-lagavulin {
to 10.200.86.7;
most-fill;
link-protection;
auto-bandwidth;
}
label-switched-path dalwhinnie-to-tormore {
to 10.200.86.9;
most-fill;
link-protection;
auto-bandwidth;
}
interface ge-0/0/2.0;
interface ge-0/0/3.0;
}
bgp {
group ibgp {
type internal;
local-address 10.200.86.5;
family inet {
unicast;
}
family inet-vpn {
unicast;
}
family l2vpn {
signaling;
}
neighbor 10.200.86.10;
neighbor 10.200.86.11;
}
}
ospf {
traffic-engineering;
area 0.0.0.0 {
interface lo0.0;
interface ge-0/0/2.0;
interface ge-0/0/3.0;
}
}
}
Set Style
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
Glenlivet (P)
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
XXXXxxxxxxxxxxxxxxxxxXxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxx xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxX
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxXxxx xxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxx
xxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx Junos Style
system {
host-name glenlivet;
root-authentication {
encrypted-password "$1$RJD1JaT1$.SGbFfpwPCS3yc5gqy3Qw."; ## SECRET-DATA
}
login {
user ps {
uid 2000;
class super-user;
authentication {
encrypted-password "$1$VUMxdqLz$hRi6WeofV5MNmn0vKESmV."; ## SECRET-DATA
}
}
}
services {
ssh;
}
syslog {
user * {
any emergency;
}
file messages {
any notice;
authorization info;
}
}
}
interfaces {
ge-0/0/1 {
unit 0 {
description "Connection to blair ge-0/0/1";
family inet {
address 192.168.86.10/30;
}
family iso;
family mpls;
}
}
ge-0/0/2 {
unit 0 {
description "Connection to dalwhinnie ge-0/0/2";
family inet {
address 192.168.86.5/30;
}
family iso;
family mpls;
}
}
ge-0/0/3 {
unit 0 {
description "Connection to mortlach fe-0/0/1";
family inet {
address 192.168.86.46/30;
}
family iso;
family mpls;
}
}
lo0 {
unit 0 {
family inet {
address 10.200.86.7/32;
}
}
}
}
routing-options {
router-id 10.200.86.7;
autonomous-system 1;
}
protocols {
rsvp {
interface ge-0/0/1.0 {
aggregate;
link-protection;
}
interface ge-0/0/2.0 {
aggregate;
link-protection;
aggregate;
}
interface ge-0/0/3.0 {
link-protection;
}
peer-interface peer-talisker;
peer-interface peer-mortlach;
peer-interface peer-macduff;
peer-interface peer-blair;
}
mpls {
statistics {
file mpls-stats.txt;
}
label-switched-path glenlivet-to-talisker {
to 10.200.86.4;
most-fill;
link-protection;
}
label-switched-path glenlivet-to-mortlach {
to 10.200.86.2;
most-fill;
link-protection;
}
label-switched-path glenlivet-to-blair {
to 10.200.86.1;
most-fill;
link-protection;
}
label-switched-path glenlivet-to-macduff {
to 10.200.86.8;
most-fill;
link-protection;
}
interface ge-0/0/1.0;
interface ge-0/0/2.0;
interface ge-0/0/2.0;
}
ospf {
traffic-engineering;
area 0.0.0.0 {
interface lo0.0 {
passive;
}
interface ge-0/0/1.0;
interface ge-0/0/2.0;
interface ge-0/0/3.0;
peer-interface
peer-interface
peer-interface
peer-interface
peer-talisker;
peer-mortlach;
peer-blair;
peer-macduff;
}
}
link-management {
te-link glenlivet-to-talisker-te {
local-address 192.168.87.2;
remote-address 192.168.87.1;
label-switched-path glenlivet-to-talisker;
}
te-link glenlivet-to-mortlach-te {
local-address 192.168.87.5;
remote-address 192.168.87.6;
te-metric 1;
label-switched-path glenlivet-to-mortlach;
}
te-link glenlivet-to-blair-te {
local-address 192.168.87.9;
remote-address 192.168.87.10;
te-metric 1;
label-switched-path glenlivet-to-blair;
}
te-link glenlivet-to-macduff-te {
local-address 192.168.87.13;
remote-address 192.168.87.14;
te-metric 1;
label-switched-path glenlivet-to-macduff;
}
peer peer-talisker {
address 10.200.86.4;
te-link glenlivet-to-talisker-te;
}
peer peer-mortlach {
address 10.200.86.2;
te-link glenlivet-to-mortlach-te;
}
peer peer-blair {
address 10.200.86.1;
te-link glenlivet-to-blair-te;
}
peer peer-macduff {
address 10.200.86.8;
te-link glenlivet-to-macduff-te;
}
}
}
xSet Style
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set protocols
set protocols
set protocols
set protocols
set protocols
set protocols
set protocols
set protocols
set protocols
set protocols
set protocols
set protocols
set protocols
set protocols
set protocols
set protocols
set protocols
set protocols
set protocols
set protocols
set protocols
set protocols
set protocols
set protocols
set protocols
set protocols
set protocols
set protocols
set protocols
set protocols
set protocols
set protocols
set protocols
set protocols
set protocols
set protocols
set protocols
set protocols
set protocols
set protocols
talisker-te
set protocols
set protocols
set protocols
set protocols
set protocols
set protocols
peer
peer
peer
peer
peer
peer
Talisker (P)
XxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx Junos Style
system {
host-name talisker;
root-authentication {
encrypted-password "$1$RJD1JaT1$.SGbFfpwPCS3yc5gqy3Qw."; ## SECRET-DATA
}
login {
user ps {
uid 2000;
class super-user;
authentication {
encrypted-password "$1$grlc52X7$RF98wUcuOF.b2FiZZKKLC1"; ## SECRET-DATA
}
}
}
services {
ssh;
}
syslog {
user * {
any emergency;
}
file messages {
any notice;
authorization info;
}
}
}
interfaces {
fe-0/0/1 {
description "Connection to macduff ge-0/0/1";
unit 0 {
family inet {
address 192.168.86.13/30;
}
family mpls;
}
}
e1-1/0/0 {
description "Connection to mortlach e1-0/0/0";
unit 0 {
family inet {
address 192.168.86.21/30;
}
family mpls;
}
}
fe-2/0/0 {
description "Connection to blair ge-0/0/3";
unit 0 {
family inet {
address 192.168.86.17/30;
}
family mpls;
}
}
fe-2/0/1 {
description "Connection to tormore ge-0/0/2";
unit 0 {
family inet {
address 192.168.86.34/30;
}
family mpls;
}
}
lo0 {
unit 0 {
family inet {
address 10.200.86.4/32;
}
}
}
}
routing-options {
router-id 10.200.86.4;
autonomous-system 1;
}
protocols {
rsvp {
interface fe-0/0/1.0 {
aggregate;
link-protection;
}
interface e1-1/0/0.0 {
aggregate;
link-protection;
}
interface fe-2/0/0.0 {
aggregate;
link-protection;
}
interface fe-2/0/1.0 {
aggregate;
link-protection;
}
peer-interface peer-glenlivet;
peer-interface peer-mortlach;
peer-interface peer-blair;
peer-interface peer-macduff;
}
mpls {
label-switched-path talisker-to-glenlivet {
to 10.200.86.7;
most-fill;
link-protection;
}
label-switched-path talisker-to-mortlach {
to 10.200.86.2;
most-fill;
link-protection;
}
label-switched-path talisker-to-blair {
to 10.200.86.1;
most-fill;
link-protection;
}
label-switched-path talisker-to-macduff {
to 10.200.86.8;
most-fill;
link-protection;
}
interface
interface
interface
interface
fe-0/0/1.0;
e1-1/0/0.0;
fe-2/0/0.0;
fe-2/0/1.0;
}
ospf {
traffic-engineering;
area 0.0.0.0 {
interface lo0.0 {
passive;
}
interface fe-0/0/1.0;
interface e1-1/0/0.0;
interface fe-2/0/0.0;
interface fe-2/0/1.0;
peer-interface peer-glenlivet;
peer-interface peer-mortlach;
peer-interface peer-blair;
peer-interface peer-macduff;
}
}
link-management {
te-link talisker-to-glenlivet-te {
local-address 192.168.87.1;
remote-address 192.168.87.2;
te-metric 1;
label-switched-path talisker-to-glenlivet;
}
te-link talisker-to-mortlach-te {
local-address 192.168.87.5;
remote-address 192.168.87.6;
te-metric 1;
label-switched-path talisker-to-mortlach;
}
te-link talisker-to-blair-te {
local-address 192.168.87.9;
remote-address 192.168.87.10;
te-metric 1;
label-switched-path talisker-to-blair;
}
te-link talisker-to-macduff-te {
local-address 192.168.87.13;
remote-address 192.168.87.14;
te-metric 1;
label-switched-path talisker-to-macduff;
}
peer peer-glenlivet {
address 10.200.86.7;
te-link talisker-to-glenlivet-te;
}
peer peer-mortlach {
address 10.200.86.2;
te-link talisker-to-mortlach-te;
}
peer peer-blair {
address 10.200.86.1;
te-link talisker-to-blair-te;
}
peer peer-macduff {
address 10.200.86.8;
te-link talisker-to-macduff-te;
}
}
}
Set Style
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
Tormore (PE)
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxJunos Style
system {
host-name tormore;
root-authentication {
encrypted-password "$1$yCV3hpZD$EWpPM8TW8exo0r/6v.Yfk."; ## SECRET-DATA
}
login {
user ps {
uid 2002;
class super-user;
authentication {
encrypted-password "$1$Vlgdcorz$TRO4TJKkijW62WJtol2EP1"; ## SECRET-DATA
}
}
}
services {
ssh;
}
syslog {
user * {
any emergency;
}
file messages {
any notice;
authorization info;
}
file interactive-commands {
interactive-commands any;
}
}
}
interfaces {
ge-0/0/2 {
description "Connection to talisker ge-2/0/1";
unit 0 {
family inet {
address 192.168.86.33/30;
}
family mpls;
}
}
ge-0/0/3 {
description "Connection to oban ge-0/0/3";
unit 0 {
family inet {
address 192.168.86.37/30;
}
family mpls;
}
}
lo0 {
unit 0 {
family inet {
address 10.200.86.9/32;
}
}
}
}
routing-options {
router-id 10.200.86.9;
autonomous-system 1;
}
protocols {
rsvp {
interface ge-0/0/2.0 {
aggregate;
link-protection;
}
interface ge-0/0/3.0 {
aggregate;
link-protection;
}
}
mpls {
statistics {
file mpls-stats.txt;
}
label-switched-path tormore-to-oban {
to 10.200.86.3;
most-fill;
link-protection;
auto-bandwidth;
}
label-switched-path tormore-to-dalwhinnie {
to 10.200.86.5;
most-fill;
link-protection;
auto-bandwidth;
}
label-switched-path tormore-to-lagavulin {
to 10.200.86.7;
most-fill;
link-protection;
auto-bandwidth;
}
interface ge-0/0/2.0;
interface ge-0/0/3.0;
}
bgp {
group ibgp {
type internal;
local-address 10.200.86.9;
family inet {
unicast;
}
family inet-vpn {
unicast;
}
family l2vpn {
signaling;
}
neighbor 10.200.86.10;
neighbor 10.200.86.11;
}
}
ospf {
traffic-engineering;
area 0.0.0.0 {
interface lo0.0;
interface ge-0/0/2.0;
interface ge-0/0/3.0;
}
}
Set Style
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
Aberlour (RR)
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxXXxxxxxxxxxx Junos Style
system {
host-name aberlour;
root-authentication {
encrypted-password "$1$yCV3hpZD$EWpPM8TW8exo0r/6v.Yfk."; ## SECRET-DATA
}
login {
user ps {
uid 2002;
class super-user;
authentication {
encrypted-password "$1$Vlgdcorz$TRO4TJKkijW62WJtol2EP1"; ## SECRET-DATA
}
}
}
services {
ssh;
}
syslog {
user * {
any emergency;
}
file messages {
any notice;
authorization info;
}
file interactive-commands {
interactive-commands any;
}
}
}
interfaces {
ge-0/0/0 {
description "Connection to blair ge-0/0/0";
unit 0 {
family inet {
address 192.168.86.54/30;
}
}
}
lo0 {
unit 0 {
family inet {
address 10.200.86.10/32;
}
}
}
}
routing-options {
router-id 10.200.86.10;
autonomous-system 1;
resolution {
rib bgp.l3vpn.0 {
resolution-ribs inet.0;
}
}
}
protocols {
bgp {
group rr-clients {
type internal;
local-address 10.200.86.10;
family inet {
unicast;
}
family inet-vpn {
unicast;
}
family l2vpn {
signaling;
}
cluster 10.200.86.10;
neighbor 10.200.86.5;
neighbor 10.200.86.7;
neighbor 10.200.86.3;
neighbor 10.200.86.9;
}
group ibgp {
type internal;
local-address 10.200.86.10;
family inet {
unicast;
}
family inet-vpn {
unicast;
}
family l2vpn {
signaling;
}
neighbor 10.200.86.11;
}
}
ospf {
area 0.0.0.0 {
interface ge-0/0/0.0;
interface lo0.0;
}
}
Set Style
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
set
Summary
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxXxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxTIP
If you visit www.juniper.net/dayone,
and then follow the path to this books download page, youll find a free Copy and Paste edition of
this book. Its rich-text format allows the file to be opened in various text editors for direct
placement of the Junos configurations.
Appendices
203
202
This Week: Deploying MPLS
XxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxXXxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxx regress@dalwhinnie> show configuration
routing-instances oak
instance-type vpls;
vlan-id none;
interface ge-1/0/0.550;
routing-interface irb.100;
route-distinguisher 10.200.86.1:100;
vrf-target target:300:200;
protocols {
vpls {
site-range 5;
no-tunnel-services;
site ce4 {
site-identifier 4;
interface ge-1/0/0.550;
}
}
}
regress@dalwhinnie> show configuration interfaces
ge-1/0/0 {
vlan-tagging;
speed 100m;
encapsulation vlan-vpls;
unit 550 {
encapsulation vlan-vpls;
vlan-id 550;
family vpls;
}
}
...
...
irb {
unit 100 {
family inet {
address 192.168.90.100/24;
}
}
}
lo0 {
unit 0 {
family inet {
address 127.0.0.1/32;
address 10.200.86.1/32;
}
}
}
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxXXxxxxxxxxxxxxxxxxxxxxxxxxxXXxxxXXxxXxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxXxxXxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXxxXxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxXxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxXXx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXxxxxxxxxxxxxxxxxxxxx
xxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXxxxXXxxxxxxxxxxxxxxxxxx
xXxxxxxxxXXxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxXxxxXXxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxNOTE In
this MX example, the vlan-stack height is normalized to zero (vlan-id none). To normalize to a stack
height value of one, the vlan-id value needs to be set to a nonzero value. The vlan-tags
configuration provides the same functionality as vlan-id with the only difference being that vlantags requires two vlan values (inner and outer) and so normalizes the vlan-stack height to two.
BEST PRACTICE
While its necessary to normalize to the same vlan-stack height for a
common VPLS instance, it is not necessarily required that each PE have the same vlan values
configured in the vlan-stack for the given VPLS instance on an MX Series router. It is, however, a
best practice to do so. Additionally, vlan stack values do not have to be unique on a per-VPLS
instance basis two unique VPLS instances can have the same vlan-id/vlan-tags values configured.
Thats because the vlan-id values in the core are not used to distinguish or separate traffic; they
are primarily used to carry 802.1p class-of-service markings.
XxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxXXxxxxxxxxXXxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
Figure A.2
Vlan-Normalization Illustration
XxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXxxxxxxxxxxxxx
xxxxxxxxxxxXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXxxxXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxXXxxxXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXxxxXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxXXxxxxxxxxxxxxxxXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxTry It Yourself: Map Vlan-stack Operations
If the VPLS instance in figure A.2 is configured for vlan-tags inner 1 outer 2, what are the vlan-tag
operations for the packet upon entry to PE1? What are the vlan-tag operations upon egress from
PE2, PE3, and PE4? Post your answers on the J-Net page for this book at www.juniper.net/dayone.
xXxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxNOTE
The VLAN normalization behavior
inherent to the MX-Series architecture is sometimes referred to as implicit VLAN translation and is
sometimes used by Service Providers to achieve complex VLAN translation schemes with very
minimal and straightforward configuration.
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxXxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxXxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxXXXXxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxXXxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxXXXXxxxxxxXxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxXXXXxxxxxxxxxxxXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxx
xxxxxxxxxxxxxxXXXXxXxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxXXXXxxxxXxXXXxxxxxxxxxxxNOTE An important point that needs to be made
about a permanent irb interface in a VPLS instance is that the network PE routers become aware of
the CE routers address space, due to the presence of the irb interface Layer 3 address in the
master routing instance. It is necessary, then, for the CE routers to have and use their designated
public IP space for their CE addressing scheme.
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx regress@dalwhinni
e> show route 192.168.90.5
inet.0: 20 destinations, 20 routes (19 active, 0 holddown, 1 hidden)
+ = Active Route, - = Last Active, * = Both
192.168.90.0/24 *[Direct/0] 3d 00:16:18
> via irb.100
regress@dalwhinnie> ping 192.168.90.5
PING 192.168.90.5 (192.168.90.5): 56 data bytes
64 bytes from 192.168.90.5: icmp_seq=0 ttl=64 time=0.984 ms
64 bytes from 192.168.90.5: icmp_seq=1 ttl=64 time=0.933 ms
64 bytes from 192.168.90.5: icmp_seq=2 ttl=64 time=0.899 ms
64 bytes from 192.168.90.5: icmp_seq=3 ttl=64 time=0.931 ms
64 bytes from 192.168.90.5: icmp_seq=4 ttl=64 time=0.905 ms
^C
--- 192.168.90.5 ping statistics --5 packets transmitted, 5 packets received, 0% packet loss
round-trip min/avg/max/stddev = 0.899/0.930/0.984/0.030 ms
XxxxxxxxxxxxxxxxxxxxxXXxxxxxxxxxXXXXxxxxxxxxxxxxxxxXxxxxxxxxxxxxXXXXxxxxxxxxxxXXxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
XXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxXXxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxregress@ce4> ping 192.168.86.1
PING 192.168.86.1 (192.168.86.1): 56 data bytes
64 bytes from 192.168.86.1: icmp_seq=0 ttl=64 time=0.816 ms
64 bytes from 192.168.86.1: icmp_seq=1 ttl=64 time=0.767 ms
64 bytes from 192.168.86.1: icmp_seq=2 ttl=64 time=0.810 ms
64 bytes from 192.168.86.1: icmp_seq=3 ttl=64 time=0.802 ms
^C
--- 192.168.86.1 ping statistics --4 packets transmitted, 4 packets received, 0% packet loss
round-trip min/avg/max/stddev = 0.767/0.799/0.816/0.019 ms
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxx[edit interfaces irb]
regress@dalwhinnie# show
unit 100 {
family inet {
address 192.168.90.100/24;
}
}
[edit interfaces irb]
regress@dalwhinnie# set unit 100 family inet filter input vpls-internet-access
[edit interfaces irb]
regress@dalwhinnie# show
unit 100 {
family inet {
filter {
input vpls-internet-access;
}
address 192.168.90.100/24;
}
}
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxregress@dalwhinnie> show configuration firewall family inet filter vpls-internet-access
term 10 {
from {
destination-prefix-list {
internal-routes;
}
}
then {
count vpls-internal-attempt;
discard;
}
}
term 20 {
then accept;
}
regress@dalwhinnie> show configuration policy-options
prefix-list internal-routes {
192.168.86.0/24;
}
...
...
...
regress@dalwhinnie>
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxregress@ce4> ping 192.168.86.1
PING 192.168.86.1 (192.168.86.1): 56 data bytes
^C
--- 192.168.86.1 ping statistics --191 packets transmitted, 0 packets received, 100% packet loss
regress@ce4>
XxxXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx regress@dalwhinnie>
show firewall filter vpls-internet-access
Filter: vpls-internet-access
Counters:
Name
Bytes
vpls-internal-attempt
14868
Packets
177
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxXxxxxxxXxxxx
Figure A.3
XxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxXXxxxxxxxxxxxxxxxx
xxxxregress@ce4> ping 10.220.90.1
PING 10.220.90.1 (10.220.90.1): 56 data bytes
64 bytes from 10.220.90.1: icmp_seq=0 ttl=63 time=1.002 ms
64 bytes from 10.220.90.1: icmp_seq=1 ttl=63 time=0.984 ms
64 bytes from 10.220.90.1: icmp_seq=2 ttl=63 time=0.984 ms
^C
--- 10.220.90.1 ping statistics --3 packets transmitted, 3 packets received, 0% packet loss
round-trip min/avg/max/stddev = 0.984/0.990/1.002/0.008 ms
regress@ce4>
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXxxxxxxXXxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxregress@ce3> ping 10.220.90.1
PING 10.220.90.1 (10.220.90.1): 56 data bytes
64 bytes from 10.220.90.1: icmp_seq=0 ttl=63 time=1.228 ms
64 bytes from 10.220.90.1: icmp_seq=1 ttl=63 time=30.964 ms
64 bytes from 10.220.90.1: icmp_seq=2 ttl=63 time=1.185 ms
64 bytes from 10.220.90.1: icmp_seq=3 ttl=63 time=1.245 ms
^C
--- 10.220.90.1 ping statistics --4 packets transmitted, 4 packets received, 0% packet loss
round-trip min/avg/max/stddev = 1.185/8.655/30.964/12.880 ms
regress@ce1> ping 10.220.90.1
PING 10.220.90.1 (10.220.90.1): 56 data bytes
64 bytes from 10.220.90.1: icmp_seq=0 ttl=63
64 bytes from 10.220.90.1: icmp_seq=1 ttl=63
64 bytes from 10.220.90.1: icmp_seq=2 ttl=63
64 bytes from 10.220.90.1: icmp_seq=3 ttl=63
time=1.207
time=1.172
time=1.171
time=1.178
ms
ms
ms
ms
^C
--- 10.220.90.1 ping statistics --4 packets transmitted, 4 packets received, 0% packet loss
round-trip min/avg/max/stddev = 1.171/1.182/1.207/0.015 ms
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxXxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXx
xxxxXXxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxXXXxx regress@dalwhinnie> show route
forwarding-table vpn oak
...
...
...
Routing table: oak.vpls
VPLS:
Destination
Type RtRef Next hop
Type Index NhRef Netif
default
perm
0
dscd 608
1
00:05:85:f4:f0:5d/48 user
0
indr 1048574
6
192.168.86.2 Push 262244, Push 100016(top) 573 2 ge-1/0/2.0
00:05:85:f4:f0:5e/48 user
0
indr 1048574
6
192.168.86.2 Push 262244, Push 100016(top) 573 2 ge-1/0/2.0
lsi.1049104
intf
0
indr 1048574
6
192.168.86.2 Push 262244, Push 100016(top) 573 2 ge-1/0/2.0
00:17:cb:05:44:5d/48 user
0
ucst 630
5 ge-1/0/0.550
0x30003/51
user
0
comp 631
2
ge-1/0/0.550
intf
0
ucst 630
5 ge-1/0/0.550
0x30001/51
user
0
comp 623
2
0x30002/51
user
0
comp 618
2
regress@dalwhinnie> ping vpls instance oak destination-mac 00:05:85:f4:f0:5e source-ip 192.168.86.1
! -> oban:oak:ge-1/0/6.700
! -> oban:oak:ge-1/0/6.700
! -> oban:oak:ge-1/0/6.700
! -> oban:oak:ge-1/0/6.700
! -> oban:oak:ge-1/0/6.700
--- vpls ping statistics --5 packets transmitted, 5 packets received, 0% packet loss
regress@dalwhinnie> ping 192.168.90.10
PING 192.168.90.10 (192.168.90.10): 56 data bytes
64 bytes from 192.168.90.10: icmp_seq=0 ttl=64 time=0.890 ms
64 bytes from 192.168.90.10: icmp_seq=1 ttl=64 time=0.843 ms
64 bytes from 192.168.90.10: icmp_seq=2 ttl=64 time=0.859 ms
64 bytes from 192.168.90.10: icmp_seq=3 ttl=64 time=0.815 ms
64 bytes from 192.168.90.10: icmp_seq=4 ttl=64 time=0.848 ms
^C
regress@dalwhinnie> show arp | match 192.168.90.10
00:05:85:f4:f0:5e 192.168.90.10 192.168.90.10
lsi.1049104
none
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxSummary
XXXXxxxxxxxxXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXxxxxxxxxxx Dalwhinnie
regress@dalwhinnie> show configuration interfaces
ge-1/0/0 {
vlan-tagging;
speed 100m;
encapsulation vlan-vpls;
unit 550 {
encapsulation vlan-vpls;
vlan-id 550;
family vpls;
}
}
ge-1/0/2 {
speed 100m;
unit 0 {
family inet {
address 192.168.86.1/30;
}
family mpls;
}
}
ge-1/0/4 {
speed 100m;
unit 0 {
family inet {
address 192.168.86.5/30;
}
family mpls;
}
}
ge-1/0/6 {
speed 100m;
unit 0 {
family inet {
address 192.168.120.1/30;
}
}
}
irb {
unit 100 {
family inet {
filter {
input vpls-internet-access;
}
address 192.168.90.100/24;
}
}
}
lo0 {
unit 0 {
family inet {
address 127.0.0.1/32;
address 10.200.86.1/32;
}
}
}
regress@dalwhinnie> show configuration protocols
rsvp {
interface ge-1/0/2.0;
interface ge-1/0/4.0;
}
mpls {
interface ge-1/0/4.0;
interface ge-1/0/2.0;
}
bgp {
family inet {
any;
}
family l2vpn {
signaling;
}
group internal {
type internal;
local-address 10.200.86.1;
export next-hop-self;
neighbor 10.200.86.3;
neighbor 10.200.86.4;
}
group external {
export [ export-internal oak-vpls-routes ];
peer-as 65432;
neighbor 192.168.120.2;
}
}
ospf {
traffic-engineering;
area 0.0.0.0 {
interface lo0.0 {
passive;
}
interface ge-1/0/4.0;
interface ge-1/0/2.0;
}
}
ldp {
interface ge-1/0/2.0;
interface ge-1/0/4.0;
}
regress@dalwhinnie> show configuration routing-instances
oak {
instance-type vpls;
vlan-id none;
interface ge-1/0/0.550;
routing-interface irb.100;
route-distinguisher 10.200.86.1:100;
vrf-target target:300:200;
protocols {
vpls {
site-range 5;
no-tunnel-services;
site ce4 {
site-identifier 4;
interface ge-1/0/0.550;
}
}
}
}
regress@dalwhinnie> show configuration policy-options
prefix-list internal-routes {
192.168.86.0/24;
}
policy-statement export-internal {
from {
prefix-list internal-routes;
}
then accept;
}
policy-statement next-hop-self {
from protocol bgp;
then {
next-hop self;
accept;
}
}
policy-statement oak-vpls-routes {
term 10 {
from {
route-filter 192.168.90.0/24 orlonger;
}
then accept;
}
}
regress@dalwhinnie> show configuration firewall
family inet {
filter vpls-internet-access {
term 10 {
from {
destination-prefix-list {
internal-routes;
}
}
then {
count vpls-internal-attempt;
discard;
}
}
term 20 {
then accept;
}
}
}
regress@dalwhinnie> show version
Hostname: dalwhinnie
Model: mx80-48t
JUNOS Base OS boot [10.3R1.9]
Oban
regress@oban> show configuration interfaces
ge-1/0/0 {
speed 100m;
encapsulation ethernet-vpls;
unit 0 {
family vpls;
}
}
ge-1/0/2 {
speed 100m;
unit 0 {
family inet {
address 192.168.86.14/30;
}
family mpls;
}
}
ge-1/0/4 {
speed 100m;
unit 0 {
family inet {
address 192.168.86.10/30;
}
family mpls;
}
}
ge-1/0/6 {
vlan-tagging;
speed 100m;
encapsulation vlan-vpls;
unit 700 {
encapsulation vlan-vpls;
vlan-id 700;
family vpls;
}
}
lo0 {
unit 0 {
family inet {
address 127.0.0.1/32;
address 10.200.86.3/32;
}
}
}
regress@oban> show configuration protocols
rsvp {
interface ge-1/0/4.0;
interface ge-1/0/2.0;
}
mpls {
interface ge-1/0/4.0;
interface ge-1/0/2.0;
}
bgp {
family inet {
any;
}
family l2vpn {
signaling;
}
group internal {
type internal;
local-address 10.200.86.3;
neighbor 10.200.86.1;
}
}
ospf {
traffic-engineering;
area 0.0.0.0 {
interface lo0.0 {
passive;
}
interface ge-1/0/4.0;
interface ge-1/0/2.0;
}
}
ldp {
interface ge-1/0/2.0;
interface ge-1/0/4.0;
}
regress@oban> show configuration routing-instances
oak {
instance-type vpls;
vlan-id none;
interface ge-1/0/0.0;
interface ge-1/0/6.700;
route-distinguisher 10.200.86.3:100;
vrf-target target:300:200;
protocols {
vpls {
site-range 5;
no-tunnel-services;
site ce1 {
site-identifier 1;
interface ge-1/0/0.0;
}
site ce3 {
site-identifier 3;
interface ge-1/0/6.700;
}
}
}
}
regress@oban# run show version
Hostname: oban
Model: mx80-48t
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxXXXXxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxXXXXxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxXxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxXxxxXxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxx
xxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxAn Automation Example
XxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxThe Commit Script
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
1.
Determines if the test-interval defined in the script lies within the valid range 602592000
seconds inclusive.
2.
For each interface configured in OSPF with apply-macro of monitor-link-latency, the commit
script checks to see if that interface has a /30 or /31 network mask. If so, it:
a. Determines the IP address for the remote side of the /30 or /31 OSPF link.
b. Configures an RPM probe with a target address of the links remote side (probe name is
ospf-metric-probe-<logical-interface>).
3.
If an interface is removed from OSPF, and/or has the apply-macro of monitor-link-latency
removed, the commit script deletes that interfaces solution RPM probes from the configuration.
4.
Configures a generated event (under the event-options hierarchy) that occurs at the
defined test-interval once per testing period.
5.
Configures an event-options policy that triggers upon the generated event and runs this
solutions event script.
6.
Notifies the user at the CLI and in the logs of any changes it makes to the configuration.
7. If the commit scripts $test-interval variable has been modified, the commit script creates a new
generated event with that interval, modifies the event-options policy to trigger upon that event,
and modifies the RPM probes for each OSPF interface to send an RPM probe at an interval closest to
(test-interval)/15 seconds.
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxXXXxxxxxxxxxxxx
xxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxx
xxxThe Event Script
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx1.
Reads the RPM probe data only for the RPM probes whose names contain the regex ospfmetric-probe- and finds the average probe latency for the most recently completed test.
2.
Determines a proposed metric for each interface based on its most recent probe latency:
metric = (average delay in microsec) /1000 * 10, rounded to nearest integer. In other words,
10*(average delay in msec) rounded to nearest integer.
3.
4.
Determines if the new metric is within a specified variance of the existing metric.
a. If variance is set to 40%, if the new metric is within 40% of the existing metric, the
interfaces metric is not changed.
b. Only if the new metric is more than 40% of the existing metric will that specific
interfaces metric be changed.
5.
6.
Changes the metric for each interface if the new metric is outside the allowed variance.
7.
The event script makes configuration changes via an exclusive commit, so if the
configuration database is already modified, when the script tries to lock the database, the scripts
configuration lock will fail and it will log a message describing the reason for the configuration lock
fail.
b. Logs the probe results for each monitored OSPF interface.
c. If no changes are made to the OSPF metrics, the script logs a message to that effect.
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx1. $variance is a decimal value for the
percentage of variance that an interfaces RPM probes can tolerate before the event script will
modify its OSPF metric. The script is set to provide a metric of 10 for each ms of round trip latency.
For example, when $variance = 0.4 (40%), if an interfaces metric is 500 and the most recent probe
results show an average of 65,000 microseconds (us), the script will not modify the OSPF metric
(65,000us = 65 ms = 650 metric; 30% variance). If a new set of results comes in showing a 75,000
us average (50% difference), then the script modifies the OSPF metric to 750.
2. $script-name is the name of this event-script and is used to identify this scripts messages in the
system logs.
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxApplying the Automation Solution
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx ps@lagavulin> show configuration
protocols ospf
traffic-engineering {
shortcuts;
}
area 0.0.0.0 {
interface ge-0/0/2.0 {
interface-type p2p;
}
interface ge-0/0/3.0 {
interface-type p2p;
}
interface lo0.0;
}
ps@lagavulin> show interfaces terse | match ge-0/0 | match inet
ge-0/0/0.0
up up inet
172.19.112.200/27
ge-0/0/1.201
up up inet
192.168.66.1/30
ge-0/0/1.400
up up inet
192.168.90.17/30
ge-0/0/2.0
up up inet
192.168.86.2/30
ge-0/0/3.0
up up inet
192.168.86.29/30
ps@lagavulin> show configuration services rpm
ps@lagavulin> show configuration event-options
ps@lagavulin>
XxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxx
xxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxps@lagavulin> edit
Entering configuration mode
[edit]
ps@lagavulin# set system scripts commit file create-ospf-probes-and-evt-optns-cmt-script.slax
[edit]
ps@lagavulin# set event-options event-script file read-ospf-probes-evt-script.slax
[edit]
ps@lagavulin# edit protocols ospf
[edit protocols ospf]
ps@lagavulin# show
traffic-engineering {
shortcuts;
}
area 0.0.0.0 {
interface ge-0/0/2.0 {
interface-type p2p;
}
interface ge-0/0/3.0 {
interface-type p2p;
}
interface lo0.0;
}
[edit protocols ospf]
ps@lagavulin# set area 0 interface ge-0/0/2.0 apply-macro monitor-link-latency
[edit protocols ospf]
ps@lagavulin# set area 0 interface ge-0/0/3.0 apply-macro monitor-link-latency
[edit protocols ospf]
ps@lagavulin# show
traffic-engineering {
shortcuts;
}
area 0.0.0.0 {
interface ge-0/0/2.0 {
apply-macro monitor-link-latency;
interface-type p2p;
}
interface ge-0/0/3.0 {
apply-macro monitor-link-latency;
interface-type p2p;
}
interface lo0.0;
}
[edit protocols ospf]
ps@lagavulin# commit
warning: commit script create-ospf-probes-and-evt-optns-cmt-script.slax adding event-options generated-event 600-seconds
to configuration to trigger OSPF RPM probe monitoring
warning: commit script create-ospf-probes-and-evt-optns-cmt-script.slax adding event-options policy 'monitor-ospf-interfaceprobes' to configuration to trigger OSPF RPM probe monitoring event-script.
warning: commit script create-ospf-probes-and-evt-optns-cmt-script.slax
adding rpm probe ospf-metric-probe-ge-0/0/2.0 in response to interface
ge-0/0/2.0 being in ospf, having a /30 or /31 netmask, and having an applymacro of 'monitor-link-latency'
warning: commit script create-ospf-probes-and-evt-optns-cmt-script.slax adding rpm probe ospf-metric-probe-ge-0/0/3.0 in
response to interface ge-0/0/3.0 being in ospf, having a /30 or /31 netmask, and having an apply-macro of 'monitor-linklatency'
commit complete
[edit protocols ospf]
ps@lagavulin# top show services rpm
probe ospf-metric-probe-ge-0/0/2.0 {
test 192.168.86.1 {
probe-type icmp-ping;
target address 192.168.86.1;
probe-count 15;
probe-interval 40;
test-interval 10;
}
}
probe ospf-metric-probe-ge-0/0/3.0 {
test 192.168.86.30 {
probe-type icmp-ping;
target address 192.168.86.30;
probe-count 15;
probe-interval 40;
test-interval 10;
}
}
[edit protocols ospf]
ps@lagavulin# top show event-options
generate-event {
600-seconds time-interval 600;
}
policy monitor-ospf-interface-probes {
events 600-seconds;
then {
event-script read-ospf-probes-evt-script.slax;
}
}
event-script {
file read-ospf-probes-evt-script.slax;
}
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxNOTE The apply-macro configuration is a hidden
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxx
xxxxxxxx[edit protocols ospf]
ps@dalwhinnie# top show services rpm
probe ospf-metric-probe-ge-0/0/2.0 {
test 192.168.86.5 {
probe-type icmp-ping;
target address 192.168.86.5;
probe-count 15;
probe-interval 40;
test-interval 10;
}
}
[edit protocols ospf]
ps@dalwhinnie# show
traffic-engineering {
shortcuts;
}
area 0.0.0.0 {
interface ge-0/0/2.0 {
apply-macro monitor-link-latency;
interface-type p2p;
metric 21;
}
interface ge-0/0/3.0 {
metric 19;
}
interface lo0.0;
}
[edit protocols ospf]
ps@dalwhinnie# set area 0 interface ge-0/0/3.0 apply-macro monitor-link-latency
[edit protocols ospf]
ps@dalwhinnie# commit
warning: commit script create-ospf-probes-and-evt-optns-cmt-script.slax adding rpm probe ospf-metric-probe-ge-0/0/3.0 in
response to interface ge-0/0/3.0 being in ospf, having a /30 or /31 netmask, and having an apply-macro of 'monitor-linklatency'
commit complete
[edit protocols ospf]
ps@dalwhinnie# show
traffic-engineering {
shortcuts;
}
area 0.0.0.0 {
interface ge-0/0/2.0 {
apply-macro monitor-link-latency;
interface-type p2p;
metric 21;
}
interface ge-0/0/3.0 {
apply-macro monitor-link-latency;
metric 19;
}
interface lo0.0;
}
[edit protocols ospf]
ps@dalwhinnie# top show services rpm
probe ospf-metric-probe-ge-0/0/2.0 {
test 192.168.86.5 {
probe-type icmp-ping;
target address 192.168.86.5;
probe-count 15;
probe-interval 40;
test-interval 10;
}
}
probe ospf-metric-probe-ge-0/0/3.0 {
test 192.168.86.29 {
probe-type icmp-ping;
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
Feb 10 05:48:01 lagavulin cscript: $avg-delay for interface ge-0/0/2.0 = 2173 usec; this msg generaged by read-ospf-probesevt-script.slax
Feb 10 05:48:01 lagavulin cscript: event-script read-ospf-probes-evt-script.slax changing ospf interface ge-0/0/2.0 metric from
to 22 based on rpm probe data.
Feb 10 05:48:01 lagavulin cscript: $avg-delay for interface ge-0/0/3.0 = 2297 usec; this msg generaged by read-ospf-probesevt-script.slax
Feb 10 05:48:01 lagavulin cscript: event-script read-ospf-probes-evt-script.slax changing ospf interface ge-0/0/3.0 metric from
to 23 based on rpm probe data.
Feb 10 05:48:10 lagavulin cscript: configuration change to modify ospf metric values successful. this msg generated by readospf-probes-evt-script.slax
Feb 10 05:58:01 lagavulin cscript: $avg-delay for interface ge-0/0/2.0 = 2300 usec; this msg generaged by read-ospf-probesevt-script.slax
Feb 10 05:58:01 lagavulin cscript: $avg-delay for interface ge-0/0/3.0 = 1938 usec; this msg generaged by read-ospf-probesevt-script.slax
Feb 10 05:58:01 lagavulin cscript: this message generated by read-ospf-probes-evt-script.slax: ospf probe results show no
change in link latency outside the allowed variance of 40%.
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx Feb 10 06:28:01 lagavulin cscript: $avg-delay for interface
Scripts
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxTIP If you visit www.juniper.net/dayone, and then follow the path to this books
download page, youll find a free Copy and Paste edition of this book. Its rich-text format allows the
file to be opened in various text editors for easy copying and pasting of the books configurations.
create-ospf-probes-and-evt-optns-cmt-script.slax
version 1.0;
ns junos = "http://xml.juniper.net/junos/*/junos";
ns xnm = "http://xml.juniper.net/xnm/1.1/xnm";
ns jcs = "http://xml.juniper.net/junos/commit-scripts/1.0";
import "../import/junos.xsl";
/* YOU MUST ACCEPT THE TERMS OF THIS DISCLAIMER TO USE THIS SOFTWARE.
*
* JUNIPER IS WILLING TO MAKE THE INCLUDED SCRIPTING SOFTWARE AVAILABLE TO YOU ONLY UPON THE CONDITION THAT
YOU * ACCEPT ALL OF THE TERMS CONTAINED IN THIS DISCLAIMER. PLEASE READ THE TERMS AND CONDITIONS OF THIS
DISCLAIMER * CAREFULLY.
* THE SOFTWARE CONTAINED IN THIS FILE IS PROVIDED "AS IS." JUNIPER MAKES NO WARRANTIES OF ANY KIND WHATSOEVER
* WITH RESPECT TO SOFTWARE. ALL EXPRESS OR IMPLIED CONDITIONS, REPRESENTATIONS AND WARRANTIES, INCLUDING
ANY
* WARRANTY OF NON-INFRINGEMENT OR WARRANTY OF MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE, ARE
HEREBY
* DISCLAIMED AND EXCLUDED TO THE EXTENT ALLOWED BY APPLICABLE LAW.
*
* IN NO EVENT WILL JUNIPER BE LIABLE FOR ANY LOST REVENUE, PROFIT OR DATA, OR FOR DIRECT, SPECIAL, INDIRECT,
* CONSEQUENTIAL, INCIDENTAL OR PUNITIVE DAMAGES HOWEVER CAUSED AND REGARDLESS OF THE THEORY OF LIABILITY
ARISING
* OUT OF THE USE OF OR INABILITY TO USE THE SOFTWARE, EVEN IF JUNIPER HAS BEEN ADVISED OF THE POSSIBILITY OF
* SUCH DAMAGES. */
/* an explanation of this scripts functionality lies at the bottom of this file
*/
*/
/****************************************************************/
/* these first 3 variables are all that need to be modified if
*/
/* the user wishes to modify the script parameters;
/* any other mods require a good working knowledge of junos
*/
/* automation
*/
/****************************************************************/
*/
*/
*/
*/
*/
*/
match configuration {
/* task 0 - determine if $test-interval is valid
*/
if ($test-interval < 60 or $test-interval > 2592000) {
var $test-interval-message = "the commit script " _ $cmt-script-name _ " test interval must be be in range
60..2592000 seconds inclusive; the configured test-interval is " _ $test-interval;
<xnm:error> {
<xsl:message terminate="yes"> $test-interval-message;
}
}
*/
/* <xnm:warning> {
*
<message> {
*
expr "num-probes = " _ $num-probes;
*
}
*} */
call create-probes-events($num-probes, $dest-ip, $configuration = ., $ospf-interfaces);
}
/********************************************************************************/
/* this template determines which interfaces are configured in OSPF and builds
*/
/* an element containing all of the interface names configured in OSPF
*/
/********************************************************************************/
template ospf-interfaces($configuration) {
for-each ($configuration/protocols/ospf/area/interface[apply-macro/name == "monitor-link-latency"]) {
var $physical-int = substring-before(name, "\.");
var $logical-int = substring-after(name, "\.");
/* if the int is configured in OSPF with the apply-macro
*/
/* and has a /30 or /31 mask, add the interface to the element*/
if ($configuration/interfaces/interface[name == $physical-int]/unit[name == $logicalint]/family/inet/address[contains(name, "\/30") or contains(name, "\/31")]) {
copy-of name;
}
}
}
/********************************************************************************************/
/* this template determines the destination ip address for the needed RPM probes and places */
/* those values within an element that stores each value as text in a <dest-ip> node
*/
/********************************************************************************************/
template dest-ip($ospf-interfaces, $configuration) {
for-each ($ospf-interfaces/name) {
var $physical-int = substring-before(., "\.");
var $logical-int = substring-after(., "\.");
for-each ($configuration/interfaces/interface[name == $physical-int]/unit[name == $logicalint]/family/inet/address[contains(name, "\/30") or contains(name, "\/31")]/name) {
var $parsed-address := jcs:parse-ip(.);
var $host-ip = $parsed-address[1]; /* takes the first element of the parse IP, which is the address
*/
/* separate the address into its component octets
*/
var $first-octet = substring-before($host-ip, "\.");
var $second-octet = substring-before(substring-after($host-ip, "\."), "\.");
var $third-octet = substring-before(substring-after(substring-after($host-ip, "\."), "\."), "\.");
var $last-octet = substring-after(substring-after(substring-after($host-ip, "\."), "\."), "\.");
/* determine the destination IP address, derived from the host address
*/
var $last-octet-dest-ip = {
if($parsed-address[3] = 30) {
if(($last-octet)mod(4) == 1) {
expr $last-octet + 1;
} else if (($last-octet)mod(4) == 2) {
expr $last-octet - 1;
} else {
expr "9999"; /* dummy value showing that address is ineligible */
}
} else if ($parsed-address[3] = 31){
if(($last-octet)mod(2) == 0) {
expr $last-octet + 1;
} else if (($last-octet)mod(2) == 1) {
expr $last-octet - 1;
} else {
expr "9999"; /* dummy value showing that address is ineligible */
}
}
}
/****************************************************************************************/
/* this template creates the change elements that configure the necessary event-options
/* policy and generated events if they are not already present; it also creates the RPM */
/* probes for the ospf interfaces if they are not present. it will delete any
/* configured rpm probes for ospf interfaces that have since been removed from ospf
/****************************************************************************************/
template create-probes-events($num-probes, $dest-ip, $configuration, $ospf-interfaces) {
/* event-name is the name of the generated event that will trigger the event-script
var $event-name = $test-interval _ "-seconds";
/* this is the actual change element
var $change := {
*/
*/
*/
*/
*/
info
*/
<event-options> {
<generate-event> {
<name> $event-name;
<time-interval> $test-interval;
}
}
<name> "monitor-ospf-interface-probes";
}
<policy> {
<name> "monitor-ospf-interface-probes";
<events> $event-name;
<then> {
<event-script> {
<name> $event-script-name;
}
}
}
}
*/
/* this section adds necessary probes to the config change element if they dont exist */
/* or if the needed rpm probes have been manually modified in a way that would break
/* the solution, this section corrects those manual config errors
*/
for-each($ospf-interfaces/name) {
var $probe-name = "ospf-metric-probe-" _ .;
/* determine the numbered position of current 'name' element within $ospf-interfaces node
/* this is the position of the current ospf int name within the $ospf-interfaces array
*/
var $position = position();
/* the test-name will be the probes destination IP address
var $test-name = $dest-ip/dest-ip[$position];
*/
*/
}
}
<probe> {
<name> $probe-name;
<test> {
<name> $test-name;
<probe-type> "icmp-ping";
<target> {
<address> $test-name;
}
<probe-count> 15;
<probe-interval> $probe-interval;
<test-interval> 10;
}
}
/* if there is a probe configured for the ospf int but is has incorrect configs */
if (($configuration/services/rpm/probe[name == $probe-name]/test[name != $test-name or
target/address != $test-name or probe-interval != $probe-interval]) or ($configuration/services/rpm/probe[name == $probename]/test[not(name) or not(probe-type) or not(probe-count) or not(probe-interval) or not(test-interval)])) {
<services> {
<rpm> {
<probe delete="delete"> {
<name> $probe-name;
}
<probe> {
<name> $probe-name;
<test> {
<name> $test-name;
<probe-type> "icmp-ping";
<target> {
<address> $test-name;
}
<probe-count> 15;
<probe-interval> $probe-interval;
<test-interval> 10;
}
}
}
}
}
}
/* this section deletes probes for interfaces that are not in OSPF anymore
*/
for-each($configuration/services/rpm/probe[contains(name, "ospf-metric-probe-")]) {
var $int = substring-after(name, "ospf-metric-probe-");
if(not(contains($ospf-interfaces, $int))) {
var $probe-name = name;
<services> {
<rpm> {
<probe delete="delete"> {
<name> $probe-name;
}
}
}
}
}
}
/* these next 4 loops use the same for-each & if/then logic as above to send status
/* output to CLI and to the logs; these could not be part of the above statements
/* or theyd have created undesirable nodes in the change element
*/
*/
*/
*/
*/
*/
*/
}
/************************************************/
/* this template puts $status-msg in the log
*/
/************************************************/
template log-status-msg($status-msg) {
expr jcs:syslog(5, $status-msg);
}
/* This automation solution sends a series of 15 RPM probes out over a defined testing period, ranging from 60
* to 2592000 seconds, inclusive. One time per testing period, the event-script checks the results of the latest
* completed set of probe results and reads the average probe latency. If an interface probes average latency is
* greater than the allowed variance, then the script modifies that OSPF interfaces metric. This solution
* consists of two separate scripts a commit script and an event script.
*
* In general, the commit script keeps the device configuration in line. The commit script performs initial
* configuration of this solution (the user only need configure the commit and event scripts) and then ensures
* that there is not an accidental configuration change that breaks it. The commit script does the following upon
* each commit:
* 1)
Determines if the test-interval defined in the script lies within the valid range 60..2592000 seconds
* inclusive
* 2)
For each interface configured in OSPF with an apply-macro set to value 'monitor-link-latency, the
* commit script checks to see if that interface has a /30 or /31 network mask. This solution only runs
* on ospf interfaces with the apply-macro value 'monitor-link-latency'
* 3)
Determines the IP address for the remote side of the /30 or /31 OSPF link
* 4)
Configures an RPM probe with a target address of the links remote side (probe name is
* ospf-metric-probe-<logical-interface>)
* 5)
If an interface is removed from OSPF, the commit script deletes that interfaces solution RPM probes
* from the configuration
* 6)
Configures a generated event (under the event-options hierarchy) that occurs at the defined test
* interval once per testing period
* 7)
Configures an event-options policy that triggers upon the generated event and runs this solutions event
* script
* 8)
Notifies the user at the CLI and in the logs of any changes it makes to the configuration
* 9)
If the commit scripts $test-interval variable has been modified, the commit script creates a new
* generated event with that interval, modifies the event-options policy to trigger upon that event, and modifies
* the RPM probes for each OSPF interface to send an RPM probe at an interval close to (test-interval)/15 seconds
*
*
* The commit script has three variables that can be modified by the user. The most important one is the
* $test-interval variable. Modifying this value allows the user to change the length of the test interval. This
* value is the length of the test interval, in seconds. Since 15 RPM probes for each OSPF interface probe are
* sent in a given test interval, modifying this value causes the commit script to modify the probe-interval for
* each probe whose name contains the regex 'ospf-metric-probe-. Changing this value also causes a new
* event-options generated event with the same value and a modification of the event-options policy
* 'monitor-ospf-interface-probes' to trigger on the corresponding generated event. In other words, if the user
* changes this variable, the script will automatically make all the necessary changes to the solution the user
* need not make any further changes.
* The other two variables, $cmt-script-name and $event-script-name are the names of this commit script and the
* name of the corresponding event script, respectively. The $event-script-name variable is used to ensure that
* the event-options policy that runs the event script actually is configured for the correct event script. The
* $cmt-script-name variable is the name of this commit script and is used to identify this scripts output in
* the systems logs.
*
* any actions taken by the commit script are logged and also noted at the CLI upon commit
* ----------------------------------------------------------------------------------------------*
*The event-script portion of this solution is activated by an event-options policy configured by the commit
* script. The event script performs the following tasks
* 1)
Reads the RPM probe data only for the RPM probes whose names contain the regex ospf-metric-probe- and
* finds the average probe latency for the most recently completed test
* 2)
Determines a proposed metric for each interface based on its most recent probe latency (metric =
* (average delay in microsec)/1000 * 10, rounded to nearest integer. In other words, 10*(average delay in msec)
* rounded to nearest integer)
* 3)
Reads the current metric for each OSPF interface
* 4)
Determines if the new metric is within a specified variance of the existing metric.
* a.
If variance is set to 40% (0.40), if the new metric is within 40% of the existing metric, the
* interfaces metric is not changed
* b.
Only if the new metric is more than 40% of the existing metric will that specific interfaces metric be
* changed
* 5)
Determines the area for each OSPF interface
* 6)
Changes the metric for each interface if the new metric is outside the allowed variance
* 7)
Each time the event script runs, it notifies the user via logs if it is making any changes and what
* those changes are. If no changes are made, the script logs a message to that effect
*
*
* The event script has three variables that can be modified by the user, $variance,$event-script-name, and
* $metric-up-on-loss.
*
a) $variance is a decimal value for the percentage of variance that an interfaces RPM probes can tolerate
* before the event script will modify its OSPF metric. The script is set to provide a metric of 10
for each ms
* of round trip latency. For example, when $variance = 0.4 (40%), if an interfaces metric is 500 and the most
*
*
*
*
*
*
*
*
*
*
*
recent probe results show an average of 65,000 microseconds (us), the script will not modify the OSPF metric
(65,000us = 65 ms = 650 metric; 30% variance). If a new set of results comes in showing a 75,000 us average
(50% difference), then the script modifies the OSPF metric to 750.
b) $script-name is the name of this event-script and is used to identify this scripts messages in the
system logs.
c) $metric-up-on-loss, when set to a value of 1, will metric up the appropriate OSPF interface to 50,000
if any of its RPM probes are lost on the most recent time-interval. If $metric-up-on-loss is set to any
value other than 1, then the interface metric is determined from the available RPM probe data for that
interface.
any actions taken by the event-script are logged /*
read-ospf-probes-evt-script.slax
version 1.0;
ns
ns
ns
ns
junos = "http://xml.juniper.net/junos/*/junos";
xnm = "http://xml.juniper.net/xnm/1.1/xnm";
jcs = "http://xml.juniper.net/junos/commit-scripts/1.0";
ext = "http://xmlsoft.org/XSLT/namespace";
ns math = "http://exslt.org/math";
import "../import/junos.xsl";
/* YOU MUST ACCEPT THE TERMS OF THIS DISCLAIMER TO USE THIS SOFTWARE.
*
* JUNIPER IS WILLING TO MAKE THE INCLUDED SCRIPTING SOFTWARE AVAILABLE TO YOU ONLY UPON THE CONDITION THAT
YOU * ACCEPT ALL OF THE TERMS CONTAINED IN THIS DISCLAIMER. PLEASE READ THE TERMS AND CONDITIONS OF THIS
DISCLAIMER * CAREFULLY.
* THE SOFTWARE CONTAINED IN THIS FILE IS PROVIDED "AS IS." JUNIPER MAKES NO WARRANTIES OF ANY KIND WHATSOEVER
* WITH RESPECT TO SOFTWARE. ALL EXPRESS OR IMPLIED CONDITIONS, REPRESENTATIONS AND WARRANTIES, INCLUDING
ANY
* WARRANTY OF NON-INFRINGEMENT OR WARRANTY OF MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE, ARE
HEREBY
* DISCLAIMED AND EXCLUDED TO THE EXTENT ALLOWED BY APPLICABLE LAW.
*
* IN NO EVENT WILL JUNIPER BE LIABLE FOR ANY LOST REVENUE, PROFIT OR DATA, OR FOR DIRECT, SPECIAL, INDIRECT,
* CONSEQUENTIAL, INCIDENTAL OR PUNITIVE DAMAGES HOWEVER CAUSED AND REGARDLESS OF THE THEORY OF LIABILITY
ARISING
* OUT OF THE USE OF OR INABILITY TO USE THE SOFTWARE, EVEN IF JUNIPER HAS BEEN ADVISED OF THE POSSIBILITY OF
* SUCH DAMAGES. */
/* an explanation of this scripts functionality lies at the bottom of this file
/* created by Tim Fiola, Juniper Networks Professional Services
*/
*/
/****************************************************************/
/* these first 3 variables are all that need to be modified if
*/
/* the user wishes to modify the script parameters;
/* any other mods require a good working knowledge of junos
*/
/* automation
*/
/****************************************************************/
*/
/* $event-script-name is the script name that appears in the logs with this scripts
*/
/* messages this name will appear in log messages created by this script so that the */
/* user can determine which script is generating a specific log message
*/
var $event-script-name = "read-ospf-probes-evt-script.slax";
/* the variance describes the % threshold that will trigger a modification of the
*/
/* ospf interface metric; if the new metric differs from the current metric by more
*/
/* than this percentage, the ospf interface will get configured with the new metric
*/
var $variance = 0.40; /* if the metric difference is greater than this %, modify the metric
/* if this is = 1, then if there is a probe loss on the interface the metric will be
/* changed to 50000. if it is anything other than 1, then the script will use the probe
/* data to determine the metric. if there is no probe loss, this value is not used
var $metric-up-on-loss = 1;
*/
*/
*/
*/
*/
*/
if(not($connection)) {
var $log-msg-connection = $event-script-name _ " event-script unable to open connection to
mgd";
*/
}
}
/************************************************************************************************/
/* this template reads the rpm probe history and, based on the results, creates any necessary */
/* change elements for modifying the OSPF interface metric
*/
/************************************************************************************************/
template config-ospf-probe-data($probe-results) {
var $change := {
<configuration> {
<protocols> {
<ospf> {
probe-")]) {
/* check for probe/packet loss
*/
var $probes-sent = probe-last-test-results/probe-test-genericresults/probes-sent;
results/probe-responses;
*/
*/
if(not(probe-last-test-results)) {
var $status-msg = "event-script " _ $event-scriptname _ " did not change ospf interface " _ $int _ " metric because a complete RPM probe data set is not available.";
call log-status-msg($status-msg);
} else { /* the average delay info does exist
*/
<area> {
<name> $int-area;
<interface> {
<name> $int;
<metric> $new-metric;
}
var $status-msg = "event-script " _
$event-script-name _ " changing ospf interface " _ $int _ " metric from " _ $current-metric _ " to " _ $new-metric _ " based on
rpm probe data.";
call log-status-msg($status-msg);
}
}
}
}
}
/* this is an empty change element used to determine if any changes need to be made
var $no-change := {
<configuration> {
<protocols> {
<ospf> {
<area> {
}
<area> {
}
<area> {
}
<area> {
}
}
}
}
}
*/
*/
*/
*/
/* debug output
*/
copy-of $change;
/* make the configuration change
*/
var $config-change-results := {
call jcs:load-configuration($connection, $configuration = $change);
}
/* debug output
*/
copy-of $config-change-results;
if($config-change-results//self::xnm:error) {
var $error-msg = "configuration change failed for reason " _ $config-change-results _ "; could not configure
RPM probes. this msg generated by " _ $event-script-name;
call log-status-msg($status-msg = $error-msg);
<output> $error-msg;
copy-of $change; /* for debug purposes
*/
} else {
var $success-msg = "configuration change to modify ospf metric values successful. this msg generated by
" _ $event-script-name;
call log-status-msg($status-msg = $success-msg);
<output> $success-msg;
copy-of $change; /* for debug purposes
*/
}
}
/************************************************/
/* this template puts $status-msg in the log
*/
/************************************************/
template log-status-msg($status-msg) {
expr jcs:syslog(5, $status-msg);
}
/* EXPLANATION OF HOW THIS SOLUTION WORKS
*/
/* This automation solution sends a series of 15 RPM probes out over a defined testing period, ranging from 60
* to 2592000 seconds, inclusive. One time per testing period, the event-script checks the results of the latest
* completed set of probe results and reads the average probe latency. If an interface probes average latency is
* greater than the allowed variance, then the script modifies that OSPF interfaces metric. This solution
* consists of two separate scripts a commit script and an event script.
*
* In general, the commit script keeps the device configuration in line. The commit script performs initial
* configuration of this solution (the user only need configure the commit and event scripts) and then ensures
* that there is not an accidental configuration change that breaks it. The commit script does the following upon
* each commit:
* 1)
Determines if the test-interval defined in the script lies within the valid range 60..2592000 seconds
* inclusive
* 2)
For each interface configured in OSPF with an apply-macro set to value 'monitor-link-latency, the
* commit script checks to see if that interface has a /30 or /31 network mask. This solution only runs
* on ospf interfaces with the apply-macro value 'monitor-link-latency'
* 3)
Determines the IP address for the remote side of the /30 or /31 OSPF link
* 4)
Configures an RPM probe with a target address of the links remote side (probe name is
* ospf-metric-probe-<logical-interface>)
* 5)
If an interface is removed from OSPF, the commit script deletes that interfaces solution RPM probes
* from the configuration
* 6)
Configures a generated event (under the event-options hierarchy) that occurs at the defined test
* interval once per testing period
* 7)
Configures an event-options policy that triggers upon the generated event and runs this solutions event
* script
* 8)
Notifies the user at the CLI and in the logs of any changes it makes to the configuration
* 9)
If the commit scripts $test-interval variable has been modified, the commit script creates a new
* generated event with that interval, modifies the event-options policy to trigger upon that event, and modifies
* the RPM probes for each OSPF interface to send an RPM probe at an interval close to (test-interval)/15 seconds
*
*
* The commit script has three variables that can be modified by the user. The most important one is the
* $test-interval variable. Modifying this value allows the user to change the length of the test interval. This
* value is the length of the test interval, in seconds. Since 15 RPM probes for each OSPF interface probe are
* sent in a given test interval, modifying this value causes the commit script to modify the probe-interval for
* each probe whose name contains the regex 'ospf-metric-probe-. Changing this value also causes a new
* event-options generated event with the same value and a modification of the event-options policy
* 'monitor-ospf-interface-probes' to trigger on the corresponding generated event. In other words, if the user
* changes this variable, the script will automatically make all the necessary changes to the solution the user
* need not make any further changes.
* The other two variables, $cmt-script-name and $event-script-name are the names of this commit script and the
* name of the corresponding event script, respectively. The $event-script-name variable is used to ensure that
* the event-options policy that runs the event script actually is configured for the correct event script. The
* $cmt-script-name variable is the name of this commit script and is used to identify this scripts output in
* the systems logs.
*
* any actions taken by the commit script are logged and also noted at the CLI upon commit
* ----------------------------------------------------------------------------------------------*
*The event-script portion of this solution is activated by an event-options policy configured by the commit
* script. The event script performs the following tasks
* 1)
Reads the RPM probe data only for the RPM probes whose names contain the regex ospf-metric-probe- and
*
*
*
*
*
*
*
*
*
*
*
*
*
*
*
*
*
*
*
*
*
*
*
*
*
*
*
*
*
*
*
*
finds the average probe latency for the most recently completed test
2)
Determines a proposed metric for each interface based on its most recent probe latency (metric =
(average delay in microsec)/1000 * 10, rounded to nearest integer. In other words, 10*(average delay in msec)
rounded to nearest integer)
3)
Reads the current metric for each OSPF interface
4)
Determines if the new metric is within a specified variance of the existing metric.
a.
If variance is set to 40% (0.40), if the new metric is within 40% of the existing metric, the
interfaces metric is not changed
b.
Only if the new metric is more than 40% of the existing metric will that specific interfaces metric be
changed
5)
Determines the area for each OSPF interface
6)
Changes the metric for each interface if the new metric is outside the allowed variance
7)
Each time the event script runs, it notifies the user via logs if it is making any changes and what
those changes are. If no changes are made, the script logs a message to that effect
The event script has three variables that can be modified by the user, $variance,$event-script-name, and
$metric-up-on-loss.
a) $variance is a decimal value for the percentage of variance that an interfaces RPM probes can tolerate
before the event script will modify its OSPF metric. The script is set to provide a metric of 10 for each ms
of round trip latency. For example, when $variance = 0.4 (40%), if an interfaces metric is 500 and the most
recent probe results show an average of 65,000 microseconds (us), the script will not modify the OSPF metric
(65,000us = 65 ms = 650 metric; 30% variance). If a new set of results comes in showing a 75,000 us average
(50% difference), then the script modifies the OSPF metric to 750.
b) $script-name is the name of this event-script and is used to identify this scripts messages in the
system logs.
c) $metric-up-on-loss, when set to a value of 1, will metric up the appropriate OSPF interface to 50,000
if any of its RPM probes are lost on the most recent time-interval. If $metric-up-on-loss is set to any
value other than 1, then the interface metric is determined from the available RPM probe data for that
interface.
any actions taken by the event-script are logged /*
XxxxXxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXxxxxxxxxxXxxxxxxxxxxxx
xxxxxxxxxxxxxxxxXxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxx
xxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxXxxxxxxxxxXxxxxxxxxxxxxxxxXxxxxxxXx
xxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxXxxxxxxxxxXxxxxxxxxxxxxXxxxxxxxxXXxxxxxxxxxxxxxxxx
xxXxxxxxxXxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxhttp://www.juniper.net/books
XxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxXxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxXxxxxxxxXxxxxxxxxxxxxxxxXxxxXxxxxxxxxxXxxxxxx
XxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxXXXXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxhttp://forums.juniper.net/jnet
XxxxXxxxxxxxxxxxxxxxxxXxXxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx www.juniper.net/techpubs/
XxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxXXXXxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxx www.juniper.net/training/fasttr
ack
Xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxXxxxXxxxxxxxXxxxxxxxXxxxxxxxxxXxxxxxxxxxxxxxXxxxxxxxxXXXXXxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxXxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
xxxxxxxxxxxxxxxxxxxxxxxxxxJunos Automation References
http://www.juniper.net/dayone
XxxxxxxxxxXxxxXxxxxxxxxxxxxxxxxxxxxxxXxxxxxXxxxxxxxxxxXxxxxxxx http://www.juniper.net/us/en
/training/elearning/junos_scripting.html
XxxxxxxxxxxxxxxxxxxxxxxxxxxxxxXxxxxxxxxxxxxxxxxx http://www.juniper.net/us/en/community/junos/
script-automation/#overview
XxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx http://forums.junip
er.net/t5/Junos-Automation-Scripting/bd-p/junos-automation
XxxxXxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx