AI agents for network deployment, configuration and monitoring
Overall agentic worflow consisted of 4 agents. First one was tasked to get the installation steps from https://learn.srlinux.dev/get-started/lab/ website. Second agent executed those steps. Third agent came up with relevant node configs based on network topology and finally the last agent executed those and verified end to end connectivity.
For this use-case, entire topology was deployed on a pre-built Debian 12 UTM VM (as a sandbox environment). This was deliberatly chosen as it comes with all relevant packages like containerlab and docker packages pre-installed. Containerlab helps spin up various container based networking topologies with ease. Following topology was chosen which consisted of linux containers and Nokia's SR Linux containers: Client1 - - Leaf1 - - Spine1 - - Leaf2 - - Client2 Where Client1 and Client2 are linux containers and Leaf1 and Leaf2 are IXR-D2L and Spine1 is IXR-D5 types of SR Linux containers.
-
Document Specialist Agent goes to and extracts following steps from the containerlab quickstart guide (https://learn.srlinux.dev/get-started/lab/): "1. Extract installation steps" "2. Identify topology deployment steps" "3. Find node connection instructions" "Present in a clear, sequential format"
-
Linux Configuration Agent executes the steps given by Document Specialist Agent and deploys containerlab and topology: Client1 - - Leaf1 - - Spine1 - - Leaf2 - - Client2.
-
Network Configuration Specialist agent the understand the topology and comes up with the right ip allocation scheme, interface and routing configs.
-
Senior Network Administrator agent then executes these configs and verifies end to end connectivity.
Instructions to run1
- Create a conda env in order to run and install all dependencies.
conda create ai-agents python=3.12 conda activate ai-agents
- Install following requirements:
pip install crewai
pip install requests
pip install paramiko
pip install netmiko
- Enter the right api key for open ai and anthropic in the relevant code cells.
- Install the Debian 12 UTM VM mentioned in (for macos) : https://containerlab.dev/install/. This is the VM on which containers get deployed.
- Run all the cells in the notebook.
Footnotes
-
NOTE : Be patient while running this code book it takes a little over 10 mins to complete. One challenge is that run times varies with every run and sometimes it can take even longer. Also claude-3-5-sonnet usage can get expensive real quick, so be careful :). ↩