/awesome-network-automation

Curated Awesome list about Network Automation

OtherNOASSERTION

Awesome Network Automation Awesome

Network Automation is cross between two disciplines of Infrastructure Networks and Programming, this list was created to as a one-stop shop to find the information.

Contents

Community

  • Ansible Google Groups - Welcome to Ansible's mailing list / forum!
  • IRC Ansible - Ansible IRC Channels
  • Network to Code Slack - NTC Slack is the home/pseudo-home to many popular repo's (NAPALM/netmiko/netbox/nsot) and over 3000 members around Network Automation.
  • Salt Formulas - The SaltStack formulas working group.
  • Salt Networks - The goal of this group is to have a central place to communicate goals about network device automation with SaltStack.
  • Salt Users - The official forum of the Salt community.

Events / Meetup

  • AWS Reinvent - AWS re:Invent Central is designed to facilitate connections between sponsors and attendees.
  • Ansible Fest - AnsibleFest is a day-long conference bringing together Ansible users, developers and industry partners to share best practices, case studies and Ansible news.
  • Ansible NYC Meetup - Local NYC Ansible user meetup.
  • London Network Automation Meetup - Community of network engineers, who have interest in the new buzz of network automation.
  • NANOG - North American Network Operators' Group with fair share of automation presentations/discussions.
  • Network to Coders Meetup - Maybe this can pressure NTC to finally setup an event for the 140+ NTC meetup members.
  • SaltStack NYC Meetup - Local NYC SatlStack user meetup.
  • Tech Field Day - Field Day events bring together innovative IT product vendors and independent thought leaders to share information and opinions in a presentation and discussion format.
  • SaltConf - 4 days event including two days of SaltStack customer case studies and SaltStack technical deep dives.

Training

  • IP Space - On ipSpace.net you'll find numerous courses, webinars, and videos covering SDN, network automation, cloud computing, virtualization technologies, IPv6 and VPNs.
  • Network to Code - Network Automation Training including Python, Ansible, DevOps, and much more.
  • Mircea Ulinic - Learn more about cross-vendor event-driven network automation and orchestration.
  • Python for Network Engineers - You will learn skills that make you better at network automation and that improve your capability to use programming to scale your work.
  • GNS3 Academy - Instructor David Bombal - Number of courses, but offer an inexpensive set of intros to Ansible for Network Engineers and Python for Network Engineers.

Presentations

Blogs

Programming Topics

Structured Data

YAML

JSON

  • Getting Started and Basics
  • Examples
  • Advanced and Tools

XML

  • Getting Started and Basics
  • Examples
  • Advanced and Tools

YANG

  • Getting Started and Basics
  • Examples
  • Advanced and Tools

Jinja2

API

RestConf

  • Getting Started and Basics
  • Examples
  • Advanced and Tools

NETCONF

  • Getting Started and Basics
  • Examples
  • Advanced and Tools

Python

Go

  • Getting Started and Basics
  • Examples
  • Advanced and Tools

Vendor API Docs

Open Source Projects

Ansible

Chef

  • Getting Started and Basics
  • Examples
  • Advanced and Tools

Puppet

  • Getting Started and Basics
  • Examples
  • Advanced and Tools

Salt

StackStorm

  • StackStorm Repository - StackStorm (aka "IFTTT for Ops") is event-driven automation commonly used for auto-remediation, security responses, facilitated troubleshooting, complex deployments, and more. Includes rules engine, workflow, 1800+ integrations, native ChatOps and so forth.
  • StackStorm Installer -
  • StackStorm Youtube - Various intro, marketing, interviews, and technical product talks.
  • Stackstorm Docs - Latest Version Documentation.
  • StackStorm Intro on Software Gone Wild - SGW team talk with StackStorm (including Matt Oswalt) to discuss StackStorm.

Products

  • Netshot - Network Configuration and Compliance Management Software.
  • NSOT - Network Source of Truth (NSoT) a source of truth database and repository for tracking inventory and metadata of network entities to ease management and automation of network infrastructure.
  • Nuts - Network Unit Testing System automates tests in the network similar to unit tests.
  • pyNMS - pyNMS is a vendor-agnostic Network Management System for network visualization, inventory and graphical automation.
  • Rundeck - Job scheduler and runbook (and Ansible playbook) automation.
  • ToDD - ToDD is an extensible framework for providing natively distributed testing on demand.
  • Trigger - Trigger is a robust network automation toolkit written in Python that was designed for interfacing with network devices and managing network configuration and security policy.

Library

  • Apstra's Aeon-ZTPS - Aeon-ZTPS is a universal Zero-Touch-Provisioning server for data center infrastructure systems at b. Currently supports the bootstraping of Arista EOS, Cisco NX-OS, and Cumulus Linux.
  • Capirca - Multi-platform ACL generation system; can output Juniper/IOS/etc ACLs from the same policy.
  • ciscoconfparse - Parse, Audit, Query, Build, and Modify Cisco IOS-style configurations.
  • Condoor - This is a python module providing access to Cisco devices over Telnet and SSH.
  • EasySNMP - Easy to use and very fast SNMP library that uses Net-SNMP.
  • JINJA2 - Jinja2 is a full featured template engine for Python.
  • Napalm - NAPALM (Network Automation and Programmability Abstraction Layer with Multivendor support) is a Python library that implements a set of functions to interact with different router vendor devices using a unified API.
  • netaddr - Network address manipulation that supports a number of techniques (supernetting and subnetting).
  • Netmiko - Multi-vendor library to simplify Paramiko SSH connections to network devices.
  • TextFSM - Python module for parsing semi-structured text into python tables.

Non-Core Ansible Modules

Pre-written Salt States (Formulas)

  • napalm-install-formula - Salt formula to simplify the installation of the necessary packages and system dependencies for NAPALM.
  • napalm-ntp-formula - Formula to manage the NTP configuration on network devices, following the OpenConfig system YANG model.

Vendor Abstraction Library

  • clicrud - Brocade specific (MLX/VDX/ICX/CER/CES) CLI driver (Telnet & SSH).
  • f5-common-python - Python SDK for configuration and monitoring of F5 BIG-IP devices via the iControl REST API.
  • infoblox - Python library for Infoblox.
  • pandevice - Python library for Palo Alto.
  • pyeapi - Python library for Arista EOS.
  • pyfg - Python library for Fortinet.
  • pyiosxr - Python library for Cisco IOSXR.
  • pynxos - Python library for Cisco NXOS.
  • py-junos-exnc - Python library for Junos automation.

Tools

  • BGP-Dashboard - BGP Dashboard and Monitoring Web Application.
  • Drawthe.net - Draw network diagrams described in YAML files.
  • napalm-logs - Cross-vendor normalisation for network syslog messages, following the OpenConfig and IETF YANG models.
  • Net-Config - Automation framework for network devices.
  • NetCopa - Network device configuration parser ("industry standard" -> YAML converter).
  • NetSpark-Scripts - Netmiko-based scripts to assist the Network Administrators and Engineers of the world!
  • NetTools - Simple network python scripts.
  • Network-CI - Proof of Concept of CI/CD methodology applied to traditional non-SDN network topologies.
  • NetGrph - Network graph modeling database.

Hypervisor's

  • Docker
  • ESX
  • Kubernetes
  • Marathon
  • OpenStack
  • oVirt
  • Vagrant
  • VirtualBox

Backups

  • Cidr - Cidr Is not as Dumb as Rancid.
  • Gerty - Universal framework for device management automation. Eventually a replacement for RANCID... and much more.
  • Jazigo - Jazigo is a tool written in Go for retrieving configuration for multiple devices, similar to rancid, fetchconfig, oxidized, Sweet.
  • Oxidized - Oxidized is a network device configuration backup tool. It's a RANCID replacement!
  • RANCID - RANCID monitors a router's (or more generally a device's) configuration, including software and hardware (cards, serial numbers, etc) and uses CVS (Concurrent Version System), Subversion or Git to maintain history of changes.
  • Sweet - Network device configuration backups and change alerts for the 21st century - inspired by RANCID!
  • Unimus - Configuration backup with an easy to use Web GUI. From nothing to backing-up 1000 routers in 15 minutes.

IPAM

  • bluecat - BlueCat provides network intelligence and insight into the relationship between devices, users and IP addresses that can be put into action to improve security and ensure reliable, always-on business connectivity.
  • Device42 - Automatically maintain an up-to-date inventory of your physical, virtual, and cloud servers and containers, network components, software, services, applications, and their inter-relationships and inter-dependencies. Integrations, REST APIs and webhooks to automate your workflows with a modern CMDB as a single source of truth. Comes with powerful Data Center Infrastructure Management, IP Address Management and Application Mappings. Mostly leverages SNMP or vendor provided APIs that are well adopted/documented.
  • haci - HaCi is an IP Address / Network Administration (IPAM) Tool with IPv6 support.
  • infoblox - Industry leader in DNS, DHCP, and IP address management, the category known as DDI.
  • netbox - NetBox is an IP address management (IPAM) and data center infrastructure management (DCIM) tool.
  • nipap - nipap is a sleek, intuitive and powerful IP address management system built to handle large amounts of IP addresses.
  • NSoT - Network Source of Truth is an open source IPAM and network inventory database.
  • phpipam - phpipam is an open-source web IP address management application (IPAM). Its goal is to provide light, modern and useful IP address management.
  • TeemIP - TeemIp is an open source, WEB based, IP Adress Management (IPAM) tool that provides comprehensive IP Management capabilities. It allows you to manage your IPv4 and IPv6 spaces through a simple and powerful user interface: track user requests, discover and allocate IPs, manage your IP plan and your subnet space in accordance with best in class IP Management practices.

Configuration Management

  • Solarwinds - Automated network configuration and compliance management.
  • ManageEngine - Network Configuration Manager is a multi vendor network change, configuration and compliance management (NCCCM) solution for switches, routers, firewalls and other network devices.
  • Rconfig - Free, open source network device configuration management tool, customizable to your needs!
  • Unimus - Network-wide configuration search and config diff over time in an easy to use web GUI.

Books

  • Ansible: Up and Running - Automating Configuration Management and Deployment the Easy Way
  • Git Pocket Guide - This pocket guide is the perfect on-the-job companion to Git, the distributed version control system. It provides a compact, readable introduction to Git for new users, as well as a reference to common commands and procedures for those of you with Git experience.
  • Mastering Python Networking - Become an expert in implementing advanced, network-related tasks with Python.
  • Network Programmability and Automation - Skills for the Next-Generation Network Engineer

Vendor Agnostic Products

  • Anuta Networks - Anuta NCX delivers network service orchestration for greenfield and brownfield deployments. NCX is an intent-driven platform with YANG service models for multiple domains such as Branch/CPE, Data Center, Virtual MPLS, Carrier Core Networks and Cloud Interconnects. NCX has built-in YANG device models for PNFs and VNFs from 35+ industry leading vendors supporting hundreds of L2-L7 network functions using CLI, NETCONF, YANG, REST and SNMP. See the complete list.
  • Apstra - The Apstra Operating System (AOS) is a vendor-agnostic distributed operating system for the data center network that enables business agility, dramatically scales operational efficiency, and reduces downtime.
  • Glue - With Gluware, the Glue Networks vision and team are continuing to trail-blaze at the forefront of the networking industry with multi-vendor orchestration solutions for Data Center, WAN and LAN networks.
  • Intelliment - Intelliment Security helps Network Operations teams to provide an application connectivity self-service for their agile customers, reducing firewall policy provisioning time while avoiding mistakes and ensuring the continuous enforcement of compliance guidelines. Inteliment works across both physical legacy infrastructure and virtualized silos, allowing them speak to each other.
  • PacketFront - PacketFront BECS and BBE is a vendor-agnostic network, service and resource orcestration system for residential, enterprise and data center networks.

Network Vendor Products

  • Cisco Merkai - Cisco Meraki is the leader in cloud controlled WiFi, routing, and security. Secure and scalable, Cisco Meraki enterprise networks simply work.
  • Cisco Viptela - Viptela provides Software-Defined Wide Area Network (SD-WAN) technology that allows global companies to build cost-effective WANs.
  • Talari - Talari Networks SD-WAN technology.

Podcasts

Podcasts Feeds

Podcasts Episodes

Contributing

Contributions about network automation are most welcome!

This list is just getting started, please contribute to make it super awesome.

License

Licensed under the Apache License, Version 2.0, see LICENSE file for more detail