Discover community programmability with the DevNet XRd Sandbox
XRd is a containerized model of IOS-XR the place you possibly can experiment with platform–impartial options and deploy them to any on-premises or cloud infrastructure. offering all the advantages of utilizing containers in community operations.
XRd comes with all of the programmability facets from IOS-XR, together with Telemetry and YANG fashions, which makes it ideally suited for builders and community engineers.
The XRd sandbox gives a wonderful alternative to get began with XRd and discover community programmability.
XRd is available in two variants: XRd Management Plane and XRd vRouter. XRd Control Plane is ideally suited for compute use circumstances like Digital Route Reflectors (vRR) or Path Compute Aspect (PCE). vRouter is designed to ahead site visitors effectively and may also deal with management airplane computations.
The XRd Sandbox makes use of the XRd Control Plane, which is ideally suited for exploration and experimentation purposes.
XRd requires particular kernel settings on the host to work correctly. The sandbox is already configured with these settings.
There are a number of methods to deploy XRd, together with utilizing Terraform, Helm or Packer. Nonetheless, we used docker compose for the sandbox as a result of it’s easy and straightforward to handle.
Topology
For this sandbox, we based mostly on the pattern segment-routing topology from the xrd-tools GitHub repository. We used a customized compose format referred to as XR-YAML, and the total setup will likely be deployed in a single digital machine (VM) utilizing Docker Compose.
Modifications
A few modifications had been wanted to make the topology work. First, we updared the IP addressing for the administration community to match the out there sources in the sandbox.
Second, we used the macvlan Docker driver so every XRd container had its personal IP handle as an alternative of sharing the IP handle with the host VM.
See the XRd Sandbox GitHub repository for particulars and to discover the config recordsdata used to create the sandbox.
Deploy
The lab gives all the things you want; you’ll solely must create the compose file that will likely be utilized by Docker Compose. This file is created utilizing the xr-compose script from xrd-tools.
Subsequent, replace the compose file (created by xr-compose) to level to the suitable container interface that will likely be created by the macvlan driver.
The sandbox directions embody the entire checklist of obligatory instructions.
To start out experimenting, search for the XRd sandbox on the Cisco sandfield web page.
Launch a reservation and comply with the directions. Use the instructions to create and begin the topology.
The XRd sandbox is ideal to get conversant in XRd, tips on how to work with it, and to play with native community protocols (e.g., ISIS, OSPF, BGP, MPLS, SR) or to discover programmable use circumstances with YANG, NETCONF and GNMI.
When creating the sandbox, we ran right into a problem. We immediately misplaced the SSH connection to the VM when docker compose was creating the topology.
It turned out that the hyperlinks between XRd containers had been created utilizing docker bridge, which picked an IP section utilized by the sandbox infrastructure, successfully blackholing the site visitors. To repair it, we needed to configure a default handle pool to make use of an unused IP section.
After making use of this configuration, the difficulty was resolved.
Listed below are some sources that will help you get began with XRd:
Extra labs can be found on the listing “~/xrd-tools/samples/xr_compose_topos” within the Sandbox.
Need to get extra content material about XRd? Attain out to me on LinkedIn. I’m completely satisfied to listen to your concepts.
Share: