Skip to content

Latest commit

 

History

History
218 lines (140 loc) · 10.5 KB

Tasks.md

File metadata and controls

218 lines (140 loc) · 10.5 KB

Tasks

Task solving tips

(Re-)Start from scratch

Whenever you feel like something got broken, remember that you can always restart the lab and start from scratch.

sudo clab destroy
sudo clab deploy

If you run the lab on macOS with lima you can use lima wrapper to execute commands on the VM:

lima ./launch.sh

Test end-to-end connectivity

To make sure all the IP addresses defined in the lab are reachable from each node use ping_all.sh script. The script pings all lab's IPs and outputs . on success and x on failure.

You can run it on each Lab's node to ensure end-to-end connectivity.

docker ps --filter "label=containerlab" --quiet | xargs -Icid docker exec cid /ping_all.sh

The main branch has a fully operational topology: all servers and routers can ping each other, all links are up, and all BGP sessions are established. If there are any issues, it's likely that Containerlab failed to bring something up. In such cases, check the Containerlab deployment output for details.

Avoid easy ways

Use your Linux CLI knowledge. Avoid looking into bgp.clab.yaml or routers configuration files unless instructed by the task. Instead, leverage your expertise with tools and router's CLI shells: e.g. ip, ss, ping, traceroute, iptables, sysctl, birdc, vtysh, etc.

It might be tempting to examine the configuration files to uncover the details, but doing so won't enhance your learning experience. Especially for troubleshooting, identifying the issue in advance takes away the challenge and satisfaction of diagnosing it independently.

Add tools of your choice

If you find a tool or a package you get used to is missing - feel free to install it. The easiest way to install a package globally is to update base section of the Dockerfile, rebuild docker images and redeploy the topology on containerlab.

If you run the lab on macOS with lima you can use lima wrapper to execute commands on the VM:

lima ./launch.sh --rebuild

Topology diagram is your best friend

Keep referring to the Topology Diagram whenever you are configuring or troubleshooting anything.

Details

Apply systematic approach

  • Understand the task objectives
  • Verify the basics: link status, ip connectivity
  • Check BGP neighbours status, advertised and received routes, bgp attributes, policies
  • Use logs and debugging tools
  • Document your process

RTFM!

Explore man pages and look for online documentation on broader topics.

Some resources for starters:

See Cheatsheet page for most important linux / routers CLI commands.

Have fun!

Solving BGP configuration and troubleshooting challenges can feel like solving a complex puzzle — so why not enjoy the process? Here’s how you can make it fun and rewarding:

1. Treat It Like a Game 🎮

  • Your mission: Establish connections, overcome obstacles, and achieve a fully functional network.
  • Your tools: Commands, configuration files, and creative problem-solving.
  • Celebrate small victories, like getting a BGP session to Established or successfully blocking unwanted prefixes!

2. Embrace the Detective Role 🕵️‍♂️

Troubleshooting is like being a network detective.

  • Look for clues: Logs, session states, and route tables.
  • Solve the mystery: Why is that pesky prefix not showing up?
  • Enjoy the “Aha!” moments when you uncover the root cause of an issue.

3. Experiment Freely 🧪

Labs are the perfect sandbox for experimentation.

  • Try out new commands or configurations without fear of breaking anything permanently.
  • Create “what-if” scenarios to explore different BGP behaviors.
  • You’ll learn so much more by playing around than by just sticking to the script!

4. Appreciate the Real-World Relevance 🌍

Every challenge you solve is preparing you for real-world scenarios.

  • Imagine you’re solving issues for a global ISP or a large enterprise.
  • Take pride in building networks that could one day power critical services!

Configuration Tasks

The tasks can be completed in any order.

Task 1

Peering partners have reported concerns about excessive prefix announcements. Ensure no prefixes longer than /24 for IPv4 and /48 for IPv6 are advertised from both Data Centers. Maintain uninterrupted connectivity during this process. You may only modify the configuration of router1.dc1 and router1.dc2.

Task 2

The Security team has raised concerns about BGP advertisements containing private Autonomous System Numbers (ASNs) in the range 64512 to 65534 within the AS PATH. Exclude these ASNs from all advertised routes. Configuration changes are restricted to router1.dc1 and router1.dc2.

Task 3

Currently, requests from AS 102 customers are distributed between two Data Centers. Configure routing so that Data Center #2 handles all requests to the network 2.2.2.0/24 from AS 102. Ensure that requests from AS 101 customers to the same network continue to be partially served by Data Center #1. Note: Modifications to transit provider configurations are not allowed.

Task 4

As a network engineer in AS 102, configure routing so that all traffic destined for 1.1.1.0/24 prefers the peering partner AS 103. If AS 103 becomes unavailable, ensure AS 101 acts as a backup route. Configuration changes are restricted to routers within AS 102.

Task 5

Data Center #2 is experiencing high traffic. Configure server3.dc2 to handle all incoming traffic directed toward the DC-local anycast range 222.22.1.0/24 originating from outside this DC. You are only allowed to modify the configuration of server3.dc2.

Task 6

The Security team has identified potential risks within the Data Center #1 DC-local anycast network 111.11.1.0/24. Ensure this network is inaccessible from outside the DC while maintaining internal connectivity. Note: Creating new firewall rules is prohibited.

Task 7

You are part of network traffic engineer team for Data Center #1. The planning team requested routing adjustments to optimize traffic distribution. Configure routing so that traffic destined for 1.1.1.0/24 enters the servers via router2.dc1, while traffic destined for 2.2.2.0/24 is directed through router3.dc1.

Troubleshooting Tasks

You need to switch to tshoot branch:

sudo containerlab destroy
git checkout tshoot
sudo containerlab deploy

After this, DO NOT look into bgp.clab.yaml and Bird or FRR configuration files, you will spoil all fun. Several configuration problems were deliberately introduced in tshoot branch. After you figure out the issue, fix it using CLI commands or by updating configuration files. Do not just compare configurations to spot problems. Use FRR/Bird and Linux CLI commands as much as possible. Issues are not necessarily in Bird or FRR configuration. Order of tasks is not important. Have fun troubleshooting!

Task 1

Identify and fix the issue stopping server1.dc2 from processing anycast requests

Task 2

Customers in AS 102 are having trouble accessing the web service at IPv4 address 1.1.1.1, while the service works perfectly over IPv6 at fc00:aa::. Investigate the cause of the issue with IPv4 connectivity, identify the problem, and implement a fix. Use ping from eyeball.as102 to confirm your solution.

Task 3

HTTP requests from server3.dc1 to the DC-level anycast address 111.11.2.2 are consistently routed to the same server, causing overload. Investigate the cause of this behavior and resolve the issue.

Task 4

Identify and resolve the issue preventing server2.dc2 from handling any anycast requests.

Task 5

server2.dc2 is not receiving any anycast traffic for IPv6 address fc00:aa::. Investigate the cause and fix the issue to restore proper traffic flow.

Task 6

server3.dc2 cannot access the DC-level anycast service at fc00:22:2::. Identify the cause of the problem and implement a solution to restore connectivity.

Task 7

Customer requests from AS 101 to the anycast address 2.2.2.2 are always routed to Data Center #2 through AS 102, even when Data Center #1 is closer. Investigate the routing behavior and implement a solution to ensure traffic is directed to the nearest data center.

Task 8

Customer requests from AS 103 to the anycast address 1.1.1.1 are consistently routed to Data Center #1 via AS 102, despite the proximity of Data Center #2. Investigate the routing behavior and implement a solution to ensure traffic is directed to the nearest data center.