BGP Application Peer and programmable RIB¶
The OpenDaylight BGP implementation also supports routes injection via Application Peer. Such peer has its own programmable RIB, which can be modified by user. This concept allows user to originate new routes and advertise them to all connected peers.
Application Peer configuration¶
Following configuration sample show a way to configure the Application Peer:
URL: /rests/data/openconfig-network-instance:network-instances/network-instance=global-bgp/openconfig-network-instance:protocols/protocol=openconfig-policy-types:BGP/bgp-example/bgp/neighbors
Method: POST
Content-Type: application/xml
Request Body:
1<neighbor xmlns="urn:opendaylight:params:xml:ns:yang:bgp:openconfig-extensions">
2 <neighbor-address>10.25.1.9</neighbor-address>
3 <config>
4 <peer-group>application-peers</peer-group>
5 </config>
6</neighbor>
@line 2: IP address is uniquely identifying Application Peer and its programmable RIB. Address is also used in local BGP speaker decision process.
@line 4: Indicates that peer is associated with application-peers group. It serves to distinguish Application Peer’s from regular neighbors.
Content-Type: application/json
Request Body:
1{
2 "neighbor": [
3 {
4 "neighbor-address": "10.25.1.9",
5 "config": {
6 "peer-group": "application-peers"
7 }
8 }
9 ]
10}
@line 4: IP address is uniquely identifying Application Peer and its programmable RIB. Address is also used in local BGP speaker decision process.
@line 6: Indicates that peer is associated with application-peers group. It serves to distinguish Application Peer’s from regular neighbors.
The Application Peer presence can be verified via REST:
URL: /rests/data/bgp-rib:bgp-rib/rib=bgp-example/peer=bgp%3A%2F%2F10.25.1.9?content=nonconfig
Method: GET
Response Body:
1<peer xmlns="urn:opendaylight:params:xml:ns:yang:bgp-rib">
2 <peer-id>bgp://10.25.1.9</peer-id>
3 <peer-role>internal</peer-role>
4 <adj-rib-in>
5 <tables>
6 <afi xmlns:x="urn:opendaylight:params:xml:ns:yang:bgp-types">x:ipv4-address-family</afi>
7 <safi xmlns:x="urn:opendaylight:params:xml:ns:yang:bgp-types">x:unicast-subsequent-address-family</safi>
8 <ipv4-routes xmlns="urn:opendaylight:params:xml:ns:yang:bgp-inet"></ipv4-routes>
9 <attributes>
10 <uptodate>false</uptodate>
11 </attributes>
12 </tables>
13 </adj-rib-in>
14 <effective-rib-in>
15 <tables>
16 <afi xmlns:x="urn:opendaylight:params:xml:ns:yang:bgp-types">x:ipv4-address-family</afi>
17 <safi xmlns:x="urn:opendaylight:params:xml:ns:yang:bgp-types">x:unicast-subsequent-address-family</safi>
18 <ipv4-routes xmlns="urn:opendaylight:params:xml:ns:yang:bgp-inet"></ipv4-routes>
19 <attributes></attributes>
20 </tables>
21 </effective-rib-in>
22</peer>
@line 3: Peer role for Application Peer is internal.
@line 8: Adj-RIB-In is empty, as no routes were originated yet.
Response Body:
1{
2 "peer": [
3 {
4 "peer-id": "bgp://10.25.1.9",
5 "peer-role": "internal",
6 "adj-rib-in": {
7 "tables": [
8 {
9 "afi": "bgp-types:ipv4-address-family",
10 "safi": "bgp-types:unicast-subsequent-address-family",
11 "attributes": {
12 "uptodate": false
13 }
14 }
15 ]
16 },
17 "effective-rib-in": {
18 "tables": [
19 {
20 "afi": "bgp-types:ipv4-address-family",
21 "safi": "bgp-types:unicast-subsequent-address-family"
22 }
23 ]
24 }
25 }
26 ]
27}
@line 5: Peer role for Application Peer is internal.
@line 12: Adj-RIB-In is empty, as no routes were originated yet.
Note
There is no Adj-RIB-Out for Application Peer.
Programmable RIB¶
Next example shows how to inject a route into the programmable RIB.
URL: /rests/data/bgp-rib:application-rib/10.25.1.9/tables=bgp-types:ipv4-address-family,bgp-types:unicast-subsequent-address-family/bgp-inet:ipv4-routes
Method: POST
Content-Type: application/xml
Request Body:
<ipv4-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-inet">
<path-id>0</path-id>
<prefix>10.0.0.11/32</prefix>
<attributes>
<origin>
<value>igp</value>
</origin>
<local-pref>
<pref>100</pref>
</local-pref>
<ipv4-next-hop>
<global>10.11.1.1</global>
</ipv4-next-hop>
</attributes>
</ipv4-route>
Content-Type: application/json
Request Body:
{
"bgp-inet:ipv4-route": [
{
"path-id": 0,
"prefix": "10.0.0.11/32",
"attributes": {
"origin": {
"value": "igp"
},
"local-pref": {
"pref": 100
},
"ipv4-next-hop": {
"global": "10.11.1.1"
}
}
}
]
}
Now the injected route appears in Application Peer’s RIBs and in local speaker’s Loc-RIB:
URL: /rests/data/bgp-rib:bgp-rib/rib=bgp-example/peer=bgp%3A%2F%2F10.25.1.9?content=nonconfig
Method: GET
Response Body:
1<peer xmlns="urn:opendaylight:params:xml:ns:yang:bgp-rib">
2 <peer-id>bgp://10.25.1.9</peer-id>
3 <peer-role>internal</peer-role>
4 <adj-rib-in>
5 <tables>
6 <afi xmlns:x="urn:opendaylight:params:xml:ns:yang:bgp-types">x:ipv4-address-family</afi>
7 <safi xmlns:x="urn:opendaylight:params:xml:ns:yang:bgp-types">x:unicast-subsequent-address-family</safi>
8 <ipv4-routes xmlns="urn:opendaylight:params:xml:ns:yang:bgp-inet">
9 <ipv4-route>
10 <path-id>0</path-id>
11 <prefix>10.0.0.11/32</prefix>
12 <attributes>
13 <origin>
14 <value>igp</value>
15 </origin>
16 <local-pref>
17 <pref>100</pref>
18 </local-pref>
19 <ipv4-next-hop>
20 <global>10.11.1.1</global>
21 </ipv4-next-hop>
22 </attributes>
23 </ipv4-route>
24 </ipv4-routes>
25 <attributes>
26 <uptodate>false</uptodate>
27 </attributes>
28 </tables>
29 </adj-rib-in>
30 <effective-rib-in>
31 <tables>
32 <afi xmlns:x="urn:opendaylight:params:xml:ns:yang:bgp-types">x:ipv4-address-family</afi>
33 <safi xmlns:x="urn:opendaylight:params:xml:ns:yang:bgp-types">x:unicast-subsequent-address-family</safi>
34 <ipv4-routes xmlns="urn:opendaylight:params:xml:ns:yang:bgp-inet">
35 <ipv4-route>
36 <path-id>0</path-id>
37 <prefix>10.0.0.11/32</prefix>
38 <attributes>
39 <origin>
40 <value>igp</value>
41 </origin>
42 <local-pref>
43 <pref>100</pref>
44 </local-pref>
45 <ipv4-next-hop>
46 <global>10.11.1.1</global>
47 </ipv4-next-hop>
48 </attributes>
49 </ipv4-route>
50 </ipv4-routes>
51 <attributes></attributes>
52 </tables>
53 </effective-rib-in>
54</peer>
@line 9: Injected route is present in Application Peer’s Adj-RIB-In and Effective-RIB-In.
Response Body:
1{
2 "peer": [
3 {
4 "peer-id": "bgp://10.25.1.9",
5 "peer-role": "internal",
6 "adj-rib-in": {
7 "tables": [
8 {
9 "afi": "bgp-types:ipv4-address-family",
10 "safi": "bgp-types:unicast-subsequent-address-family",
11 "bgp-inet:ipv4-routes":{
12 "ipv4-route": [
13 {
14 "path-id": 0,
15 "prefix": "10.0.0.11/32",
16 "attributes": {
17 "origin": {
18 "value": "igp"
19 },
20 "local-pref": {
21 "pref": 100
22 },
23 "ipv4-next-hop": {
24 "global": "10.11.1.1"
25 }
26 }
27 }
28 ]
29 },
30 "attributes": {
31 "uptodate": false
32 }
33 }
34 ]
35 },
36 "effective-rib-in": {
37 "tables": [
38 {
39 "afi": "bgp-types:ipv4-address-family",
40 "safi": "bgp-types:unicast-subsequent-address-family",
41 "bgp-inet:ipv4-routes":{
42 "ipv4-route": [
43 {
44 "path-id": 0,
45 "prefix": "10.0.0.11/32",
46 "attributes": {
47 "origin": {
48 "value": "igp"
49 },
50 "local-pref": {
51 "pref": 100
52 },
53 "ipv4-next-hop": {
54 "global": "10.11.1.1"
55 }
56 }
57 }
58 ]
59 }
60 }
61 ]
62 }
63 }
64 ]
65}
@line 12: Injected route is present in Application Peer’s Adj-RIB-In and Effective-RIB-In.
URL: /rests/data/bgp-rib:bgp-rib/rib/bgp-example/loc-rib/tables/bgp-types:ipv4-address-family/bgp-types:unicast-subsequent-address-family/ipv4-routes?content=nonconfig
Method: GET
Response Body:
1<ipv4-routes xmlns="urn:opendaylight:params:xml:ns:yang:bgp-inet">
2 <ipv4-route>
3 <path-id>0</path-id>
4 <prefix>10.0.0.10/32</prefix>
5 <attributes>
6 <origin>
7 <value>igp</value>
8 </origin>
9 <local-pref>
10 <pref>100</pref>
11 </local-pref>
12 <ipv4-next-hop>
13 <global>10.11.1.1</global>
14 </ipv4-next-hop>
15 </attributes>
16 </ipv4-route>
17 <ipv4-route>
18 <path-id>0</path-id>
19 <prefix>10.0.0.10/32</prefix>
20 <attributes>
21 <origin>
22 <value>igp</value>
23 </origin>
24 <local-pref>
25 <pref>100</pref>
26 </local-pref>
27 <ipv4-next-hop>
28 <global>10.10.1.1</global>
29 </ipv4-next-hop>
30 </attributes>
31 </ipv4-route>
32</ipv4-routes>
@line 2: The injected route is now present in Loc-RIB along with a route (destination 10.0.0.10/32) advertised by remote peer.
Response Body:
1{
2 "bgp-inet:ipv4-routes":{
3 "ipv4-route": [
4 {
5 "path-id": 0,
6 "prefix": "10.0.0.10/32",
7 "attributes": {
8 "origin": {
9 "value": "igp"
10 },
11 "local-pref": {
12 "pref": 100
13 },
14 "ipv4-next-hop": {
15 "global": "10.11.1.1"
16 }
17 }
18 },
19 {
20 "path-id": 0,
21 "prefix": "10.0.0.10/32",
22 "attributes": {
23 "origin": {
24 "value": "igp"
25 },
26 "local-pref": {
27 "pref": 100
28 },
29 "ipv4-next-hop": {
30 "global": "10.11.1.1"
31 }
32 }
33 }
34 ]
35 }
36}
@line 3: The injected route is now present in Loc-RIB along with a route (destination 10.0.0.10/32) advertised by remote peer.
This route is also advertised to the remote peer (192.0.2.1), hence route appears in its Adj-RIB-Out:
URL: /rests/data/bgp-rib:bgp-rib/rib/bgp-example/peer/bgp:%2F%2F192.0.2.1/adj-rib-out/tables/bgp-types:ipv4-address-family/bgp-types:unicast-subsequent-address-family/bgp-inet:ipv4-routes?content=nonconfig
Method: GET
Response Body:
<ipv4-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-inet">
<path-id>0</path-id>
<prefix>10.0.0.11/32</prefix>
<attributes>
<origin>
<value>igp</value>
</origin>
<local-pref>
<pref>100</pref>
</local-pref>
<ipv4-next-hop>
<global>10.11.1.1</global>
</ipv4-next-hop>
</attributes>
</ipv4-route>
Response Body:
{
"bgp-inet:ipv4-route": [
{
"path-id": 0,
"prefix": "10.0.0.11/32",
"attributes": {
"origin": {
"value": "igp"
},
"local-pref": {
"pref": 100
},
"ipv4-next-hop": {
"global": "10.11.1.1"
}
}
}
]
}
The injected route can be modified (i.e. different path attribute):
URL: /rests/data/bgp-rib:application-rib/10.25.1.9/tables/bgp-types:ipv4-address-family/bgp-types:unicast-subsequent-address-family/bgp-inet:ipv4-routes/ipv4-route/10.0.0.11%2F32/0
Method: PUT
Content-Type: application/xml
Request Body:
<ipv4-route xmlns="urn:opendaylight:params:xml:ns:yang:bgp-inet">
<path-id>0</path-id>
<prefix>10.0.0.11/32</prefix>
<attributes>
<origin>
<value>igp</value>
</origin>
<local-pref>
<pref>50</pref>
</local-pref>
<ipv4-next-hop>
<global>10.11.1.2</global>
</ipv4-next-hop>
</attributes>
</ipv4-route>
Content-Type: application/json
Request Body:
{
"bgp-inet:ipv4-route": [
{
"path-id": 0,
"prefix": "10.0.0.11/32",
"attributes": {
"origin": {
"value": "igp"
},
"local-pref": {
"pref": 50
},
"ipv4-next-hop": {
"global": "10.11.1.1"
}
}
}
]
}
The route can be removed from programmable RIB in a following way:
URL: /rests/data/bgp-rib:application-rib/10.25.1.9/tables/bgp-types:ipv4-address-family/bgp-types:unicast-subsequent-address-family/bgp-inet:ipv4-routes/ipv4-route/10.0.0.11%2F32/0
Method: DELETE
Also it is possible to remove all routes from a particular table at once:
URL: /rests/data/bgp-rib:application-rib/10.25.1.9/tables/bgp-types:ipv4-address-family/bgp-types:unicast-subsequent-address-family/bgp-inet:ipv4-routes
Method: DELETE
Consequently, route disappears from programmable RIB, Application Peer’s RIBs, Loc-RIB and peer’s Adj-RIB-Out (UPDATE message with prefix withdrawal is send).
Note
Routes stored in programmable RIB are persisted on OpendDaylight shutdown and restored after the re-start.